.. | ||
entities | ||
models | ||
services | ||
__init__.py | ||
conftest.py | ||
README.md |
Testing
Backend
Organization
Tests for backend
code use Pytest and are organized in the backend/test
directory
with subdirectories that mirror the package structure.
The file backend/test/conftest.py
defines fixtures for automatically setting up and tearing down a test database for backend services to use.
At present, we do not have automated front-end testing instrumented; this remains a goal.
Pytest CLI
The pytest
command-line program will run all tests in the command-line.
To see print
output, run Pytest with the special extra output flag pytest -rP
.
To limit the scope of your tests to a specific file, include the path to the file following the command, eg:
pytest backend/test/services/user_test.py
To run a specific test within a test suite, use the -k
option of pytest
to match all or part of the filtered test name(s):
pytest backend/test/services/user_test.py -k test_get
Pytest VSCode with Debugger
VSCode's Python plugin has great support for testing. Click the test tube icon, configure VSCode to use Pytest and select the workspace.
When you refresh, you will see tests you can run individually, or in the debugger and with breakpoints. When you encounter a bug or failing test and having a difficult time pinning down exactly why it is failing, developing the instinct to run the test in the VSCode debugger, setting a break point, and stepping through is encouraged.
For more, see the official documentation.
Code Coverage
We expect 100% test coverage of backend services code and as much coverage for other code in the backend.
To generate a test coverage report, run the following command in your development container:
pytest --cov-report html:coverage --cov=backend/services backend/test/services
This command generates a directory with an HTML report. To view it, on your host machine, open the coverage
directory's index.html
file. Click on the service file you are working on to see the lines not covered by test cases if you are below 100%. After adding test cases that cover the missing lines, rerun the coverage command to generate a new report and confirm your progress.
Writing Tests
- Depending on what you are writing tests for, create the testing file in the associated directory (e.g. writing tests for services should be in the backend/tests/services directory
- Name the file as [tested_item]_test.py and any functions inside the file should be prefixed with test_[tested_function] to be recognized by pytest
- Tests should be created in a way to test the main functionality, edge cases, and error handling (look at test's on the csxl repo for inspiration)
- Run specific functions by running this command while in the /workspace directory
- pytest backend/test/[test_directory]/[test_file]::[function_name] -s
- -s flag allows you to show print statements in the console which is defaulted to not show