Testing Code
Developing and running unit tests
Introducing Test Cases
Ghostwriter follows Django’s best practices and recommendations for unit testing. You can read more about Django unit tests here:
The project organizes unit tests by application. Each application (e.g., Rolodex, Shepherd) has a tests folder that contains scripts for testing forms, views, and models. Each type of test case includes a baseline of unit tests that are detailed below.
Running Tests & Examining Coverage
Tests are run through Django’s manage.py and the test
command. You can run all tests, a subset of tests, or individual tests. See below for examples:
A successful run of all unit tests may still display errors. Many of the unit tests intentionally trigger errors by passing invalid data to the server. The logger output can be disabled but this is generally unnecessary. A successful run will output something like this at the end:
A test run with failures or errors will report the number of each at the end. Review the test output to see which test(s) failed to determine what needs to be fixed.
Test Coverage
The above commands include the usage of Python’s coverage library. Coverage compares the executed tests against the codebase to identify lines of code that were not tested.
A Coverage report can be generated once a test run is complete. This command will generate a command line report that displays the lines that were missed during testing:
docker-compose -f local.yml run django coverage report -m
A GitHub Action executes unit tests, generates an XML Coverage report, and uploads the report to CodeCov. This Action fires after commits to the master
branch and whenever a PR is submitted to the repository. CodeCov tracks unit test coverage and makes it easier to view which folders, files, and individual lines of code need more unit testing.