PowerfulSeal uses tox to test multiple Python versions in a straightforward manner, which is especially useful due to the application's compatibility with both Python 2.7 and Python 3.
In order to use tox
, tox
must be installed and Python binaries for the versions listed in tox.ini (2.7, 3.4, 3.6, 3.7 as of writing) must be visible in your PATH.
Due to the difficulty in maintaining the required libraries for so many Python versions, it is recommended to use pyenv to install and manage multiple versions of Python.
The recommended installation steps are:
- Install pyenv using the Basic GitHub Checkout method
- Run
pyenv install --list
- For every version specified in
tox.ini
, find the latest patch version corresponding to the version (e.g.,2.7
->2.7.15
) and runpyenv install [version]
- In this project's root directory, run
pyenv local [versions]
, where[versions]
is a space-separated list of every version you just installed (e.g.,pyenv install 2.7.15 3.4.8 3.6.5 3.7.0
) - Run
pyenv which 2.7
,pyenv which 3.4
, etc. and ensure there are no errors and the output path is a.pyenv
directory
With the installation complete, simply run tox
(or the analagous make test
). If you are running on a machine with inotifywait
installed (i.e., a UNIX machine), you can run make watch
and run tests automatically when you run changes.
You can also run tests for specific versions by running tox -e [version(s)]
(e.g., tox -e py36
). Additionally, if you need to reinstall dependencies, you can use the -r
flag.
The web interface is a Vue application and can be tested independently of the backend by changing directory to powerfulseal/web/ui
, installing dependencies using npm install
and running npm run serve
.
In order to test the backend while using npm run serve
, the web server needs to be run under the default host and port of localhost:9000
. This default can be changed under powerfulseal/web/ui/src/main.js
.
To build the production files, either run make web
under the repository's root directory or run npm run build
under the ui
directory.