1
0
mirror of https://github.com/pi-hole/pi-hole synced 2025-01-26 16:01:17 +00:00
pi-hole/test
2023-07-18 08:04:33 +01:00
..
__init__.py
_centos_8.Dockerfile
_centos_9.Dockerfile Allow replacing conflicting existing packages from testing image 2022-10-17 14:58:42 -03:00
_debian_10.Dockerfile
_debian_11.Dockerfile
_debian_12.Dockerfile
_fedora_36.Dockerfile Add initscripts to Fedora 35 and 36 dockerfile 2022-10-01 10:03:13 +02:00
_fedora_37.Dockerfile
_fedora_38.Dockerfile Add Fedora 38 to the test suite 2023-04-19 21:03:12 +02:00
_ubuntu_20.Dockerfile
_ubuntu_22.Dockerfile
_ubuntu_23.Dockerfile
conftest.py
README.md
requirements.txt Drop docker-compose from requirements.txt, it's not used. This was the only thing preventing us from using pyyaml 6.0.1 which fixes issues we were seeing with tests not running (https://github.com/yaml/pyyaml/pull/702) 2023-07-18 08:04:33 +01:00
setup.py Format all /test files with black 2022-09-19 14:50:35 +02:00
test_any_automated_install.py Switch to new branch name for FTL v6 development 2023-06-18 22:05:18 +01:00
test_any_utils.py Switch to new branch name for FTL v6 development 2023-06-18 22:05:18 +01:00
test_centos_fedora_common_support.py
tox.centos_8.ini
tox.centos_9.ini Remove the EPEL related tests on centos/fedora - no longer neccasery 2023-05-27 11:51:16 +01:00
tox.debian_10.ini
tox.debian_11.ini
tox.debian_12.ini
tox.fedora_36.ini
tox.fedora_37.ini
tox.fedora_38.ini
tox.ubuntu_20.ini
tox.ubuntu_22.ini Use buildx to create docker test images 2023-02-16 21:43:30 +01:00
tox.ubuntu_23.ini Add Ubuntu 23 to test suite 2023-05-24 22:54:47 +02:00

Recommended way to run tests

Make sure you have Docker and Python w/pip package manager.

From command line all you need to do is:

  • pip install tox
  • tox

Tox handles setting up a virtual environment for python dependencies, installing dependencies, building the docker images used by tests, and finally running tests. It's an easy way to have travis-ci like build behavior locally.

Alternative py.test method of running tests

You're responsible for setting up your virtual env and dependencies in this situation.

py.test -vv -n auto -m "build_stage"
py.test -vv -n auto -m "not build_stage"

The build_stage tests have to run first to create the docker images, followed by the actual tests which utilize said images. Unless you're changing your dockerfiles you shouldn't have to run the build_stage every time - but it's a good idea to rebuild at least once a day in case the base Docker images or packages change.

How do I debug python?

Highly recommended: Setup PyCharm on a Docker enabled machine. Having a python debugger like PyCharm changes your life if you've never used it :)