weblate/docs/contributing/tests.rst
2026-03-24 08:52:34 +01:00

140 lines
4.5 KiB
ReStructuredText

Weblate testsuite and continuous integration
--------------------------------------------
Testsuites exist for most of the current code, increase coverage by adding testcases for any new
functionality, and verify that it works.
.. _ci-tests:
Continuous integration
++++++++++++++++++++++
Weblate relies on `GitHub Actions`_ to run tests, build documentation, code
linting, and other tasks to ensure code quality.
`Codecov`_ collects the code coverage information from the tests that were run.
.. _GitHub Actions: https://github.com/WeblateOrg/weblate/actions
.. _Codecov: https://app.codecov.io/gh/WeblateOrg/weblate/
There are several jobs to verify different aspects:
* Unit and functional tests using `pytest <https://pytest.org/>`_.
* Documentation build and external links using `Sphinx <https://www.sphinx-doc.org/>`_.
* Code linting and quality assurance using `ruff <https://docs.astral.sh/ruff/>`_ and `pylint <https://www.pylint.org/>`_.
* Code security scanning using `CodeQL <https://codeql.github.com/>`_.
* Visual changes testing is utilizing `Argos CI <https://argos-ci.com>`_.
* Code formatting using `prek <https://pypi.org/project/prek/>`_, a faster
third-party reimplementation of the `pre-commit <https://pre-commit.com/>`_
framework.
* Migration testing from all supported releases
* Setup verification (ensures that generated dist files do not miss anything and can be tested)
The configuration for the CI is in :file:`.github/workflows` directory. It
heavily uses helper scripts stored in :file:`ci` directory. The scripts can be
also executed manually, but they require several environment variables, mostly
defining Django settings file to use and test database connection. The example
definition of that is in :file:`scripts/test-database.sh`:
.. literalinclude:: ../../scripts/test-database.sh
:language: sh
The simple execution can look like:
.. code-block:: sh
source scripts/test-database.sh
./ci/run-migrate
./ci/run-test
./ci/run-docs
.. _local-tests:
Local testing of Weblate
+++++++++++++++++++++++++
Before running test, please ensure test dependencies are installed. This can be done by ``pip install -e .[test]``.
Testing using pytest
~~~~~~~~~~~~~~~~~~~~
Prior to running tests you should collect static files as some tests rely on them being present:
.. code-block:: sh
DJANGO_SETTINGS_MODULE=weblate.settings_test ./manage.py collectstatic
You can use `pytest` to run a testsuite locally:
.. code-block:: sh
pytest weblate
Running an individual test file:
.. code-block:: sh
pytest weblate/utils/tests/test_search.py
.. hint::
You will need a database (PostgreSQL) server to be used for tests. By
default Django creates separate database to run tests with ``test_`` prefix,
so in case your settings is configured to use ``weblate``, the tests will
use ``test_weblate`` database. See :ref:`database-setup` for setup
instructions.
The :file:`weblate/settings_test.py` is used in CI environment as well (see
:ref:`ci-tests`) and can be tuned using environment variables:
.. code-block:: sh
export CI_DB_USER=weblate
export CI_DB_PASSWORD=weblate
export CI_DB_HOST=127.0.0.1
export CI_DB_PORT=60000
export DJANGO_SETTINGS_MODULE=weblate.settings_test
.. hint::
The tests can also be executed inside developer docker container, see :ref:`dev-docker`.
.. seealso::
See :doc:`django:topics/testing/index` for more info on running and
writing tests for Django.
Local testing of Weblate modules
--------------------------------
The tests are executed using :program:`py.test`. First you need to install test requirements:
.. code-block:: sh
uv pip install -e '.[dev]'
You can then execute the testsuite in the repository checkout:
.. code-block:: sh
py.test
.. _test-data:
Testing repository
------------------
Many of the tests in the Weblate test suite use the test repository. The test
suite repository is maintained at https://github.com/WeblateOrg/test. The
script :file:`scripts/pack-test-data.sh` is then used to generate a tarball
with a repository for each of the supported version control systems. These are
stored as :file:`weblate/trans/tests/data/test-base-repo.git.tar`,
:file:`weblate/trans/tests/data/test-base-repo.hg.tar`, and
:file:`weblate/trans/tests/data/test-base-repo.svn.tar` in the Weblate
repository.
The https://github.com/WeblateOrg/test repository is tagged at the release
time, which ensures that the release tags can be used to access test data used
at the release time. The script tries to create reproducible tarballs as much
as possible.