/libmarks

Software Assignment Marking Tool

Primary LanguagePythonMIT LicenseMIT

Libmarks: A Python framework for running functional tests on source code

Originally, this repository was created for Joel Addison's engineering major project in 2014 (Supervisors: Peter Sutton (EAIT) and Joel Fenwick).

Installation

The tool uses the Boost C++ library in order to function. Therefore, in order to install it, a version of Boost needs to be installed first. To install the Boost library, run the following:

./install-boost.sh install.boost.conf

The configuration file can be modified as required. Its purpose is to specify the version of boost to install, as well as where to install it.

The installation will create the following directory structure at the chosen location:

INSTALL_ROOT/
  + releases/                   <- Contains the zipped downloaded boost library
    + version.tar.bz2
  + extracted/                  <- Contains the content of the library once extracted
    + version/ (e.g. boost_1_73_0)
      + ...
  + builds/                     <- Contains the built library files
    + current                   <- A symlink pointing to the current active build
    + version/ (e.g. 1_73_0)
      + ...

Once the Boost library has been installed, libmarks can be installed as follows:

./install.sh install.libmarks.conf

The configuration file can be modified as required. Its purpose is to specify the python and boost libraries to use, as well as the installation location.

Using the library

The library uses Python files in order to specify test cases. These files should contain at least the following to function correctly:

!#/usr/bin/env python3
import sys
import pathlib

LIBMARKS_ROOT = pathlib.Path('/path/to/libmarks/install')

sys.path[0:0] = [str(LIBMARKS_ROOT)]
import marks    # This must come after the sys.path line

class TestClass(marks.TestCase):
    # One or more classes which extend marks.TestCase 
    # should be present

    @marks.marks('category', category_marks=X)
    def test_someTest(self):
        # Test cases are methods which start with test_
        # which are decorated using the marks.marks decorator
        ...
        
        # You can run a process using the self.process method
        proc = self.process([process, args])

        # And check its outputs / exit status
        self.assert_stdout_matches_file(proc, 'path/to/file')
        self.assert_stderr_matches_file(proc, 'path/to/file')
        self.assert_exit_status(proc, status)

if __name__ == "__main__":
    marks.main()

To run your tests, run the following from the directory containing your source code:

$ /path/to/python/test/file test

You should see output similar to the following:

$ /path/to/test/file test
Setting up environment...
Running tests

TestName                                                 OK/FAIL/ERROR
...

----------------------------------------------------------------------
Ran X tests: X success, X errors, X failures
Tearing down environment...

If you receive an ImportError regarding libboost_python you need to update your LD_LIBRARY_PATH variable to include your installed boost libraries. This can be done as follows:

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/path/to/boost/root/builds/current/lib