15.2.6. Testing frameworkο
NextGIS Web testing framework is based on pytest library with some additions (predefined fixtures, marks) and conventions. It supports unit and functional tests.
15.2.6.1. File layoutο
Each NextGIS Web component have its own set of tests located inside test
directory. Consider the directory structure on the example for package
package
and component component
.
π # Repository root directory
βββ π package # Package source root
β βββ π component # Component root directory
β β βββ π test # Test root directory
β β β βββ π data # Test data directory
β β β βββ π __init__.py # Dummy __init__ module
β β β βββ π test_*.py # Test module files
β β βββ π __init__.py # And other component files
β βββ π __init__.py # Package files and other components
βββ π setup.py # Setuptools configuration file
15.2.6.2. Unit testsο
Unit tests are designed for testing modules and usually donβt require additional configuration. Refer pytest documentation and Writing tests section.
# package/component/test/test_unit.py
from .. import some_function
def test_some_function():
assert some_function(1) == 0
15.2.6.3. Functional testsο
Functional tests operate on data, and NextGIS Web must be configured and have
the database initialized via nextgisweb initialize_db
. Some tests modify
data, so donβt run these tests in a production environment.
15.2.6.3.1. Server-sideο
Server-side tests are executed in the same context as other NextGIS Web console
scripts. The environment can be loaded with ngw_env
fixture, which
initializes components and the environment.
# package/component/test/test_env.py
def test_component(ngw_env):
ngw_env.component.some_component_method()
Tests inside a transaction can be performed using ngw_txn
fixture. It begins
a new transaction and rollbacks it at exit, flushing changes to the database
before that.
# package/component/test/test_txn.py
from ..model import SomeModel
def test_transaction(ngw_txn):
SomeModel(field='value').persist() # Dummy record insert
15.2.6.3.2. Web applicationο
For testing via HTTP requests fixture ngw_webtest_app
can be used. Itβs
represents WebTest
TestApp
instance which can be used for doing requests.
# package/component/test/test_webapp.py
def test_api_method(ngw_webtest_app):
ngw_webtest_app.get('/api/component/component/method')
15.2.6.4. Writing testsο
15.2.6.4.1. Naming conventionsο
Follow pytest default naming conventions - test modules and functions must have
test_
prefix.
Note
Do not forget to add a dummy __init__.py
file to the test
directory.
15.2.6.5. Running testsο
$ export NEXTGISWEB_CONFIG=path/to/config.ini
$ python -m pytest package # All tests from package
$ python -m pytest package/component # Only tests from component
$ python -m pytest --pyargs package.component # Same but by Python module name
Note
The last option with --pyargs
might be useful when running tests in Crater
/ NGWDocker environment. Path-based options wonβt work because of symlinks
inside site-packages
directory.