PyMacaron supports standard python unittests but also custom blackbox tests that target your API endpoints. Those tests are located in two different directories inside your PyMacaron project:
. | | # Unitests, executed with nosetests └── test | └── test_pep8.py | | # Acceptance tests for your api, executed with run_acceptance_tests └── testaccept ├── test_v1_user_login.py └── test_version.py
Blackbox acceptance tests target the api endpoints, and are executed via the tool run_acceptance_tests that comes packaged with pymacaron.
It is recommended to name them after the endpoint they target. So one test file per tested API endpoint.
Acceptance tests are designed to be executed against a running instance of the API server, be it a server you are running locally in a separate terminal, a docker container, or a live instance in Elastic Beanstalk.
Those tests should therefore treat the API as a blackbox and focus solely on making API calls and testing the results. API calls should be made using test methods from pymacaron-unit.
See pymacaron-helloworld for an example of acceptance tests.