#!/usr/bin/python3 import pytest from changedetectionio import changedetection_app from changedetectionio import store import os import sys from loguru import logger # https://github.com/pallets/flask/blob/1.1.2/examples/tutorial/tests/test_auth.py # Much better boilerplate than the docs # https://www.python-boilerplate.com/py3+flask+pytest/ global app # https://loguru.readthedocs.io/en/latest/resources/migration.html#replacing-caplog-fixture-from-pytest-library # Show loguru logs only if CICD pytest fails. from loguru import logger @pytest.fixture def reportlog(pytestconfig): logging_plugin = pytestconfig.pluginmanager.getplugin("logging-plugin") handler_id = logger.add(logging_plugin.report_handler, format="{message}") yield logger.remove(handler_id) def cleanup(datastore_path): import glob # Unlink test output files for g in ["*.txt", "*.json", "*.pdf"]: files = glob.glob(os.path.join(datastore_path, g)) for f in files: if 'proxies.json' in f: # Usually mounted by docker container during test time continue if os.path.isfile(f): os.unlink(f) @pytest.fixture(scope='session') def app(request): """Create application for the tests.""" datastore_path = "./test-datastore" # So they don't delay in fetching os.environ["MINIMUM_SECONDS_RECHECK_TIME"] = "0" try: os.mkdir(datastore_path) except FileExistsError: pass cleanup(datastore_path) app_config = {'datastore_path': datastore_path, 'disable_checkver' : True} cleanup(app_config['datastore_path']) logger_level = 'TRACE' logger.remove() log_level_for_stdout = { 'DEBUG', 'SUCCESS' } logger.configure(handlers=[ {"sink": sys.stdout, "level": logger_level, "filter" : lambda record: record['level'].name in log_level_for_stdout}, {"sink": sys.stderr, "level": logger_level, "filter": lambda record: record['level'].name not in log_level_for_stdout}, ]) datastore = store.ChangeDetectionStore(datastore_path=app_config['datastore_path'], include_default_watches=False) app = changedetection_app(app_config, datastore) # Disable CSRF while running tests app.config['WTF_CSRF_ENABLED'] = False app.config['STOP_THREADS'] = True def teardown(): datastore.stop_thread = True app.config.exit.set() cleanup(app_config['datastore_path']) request.addfinalizer(teardown) yield app