1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
from __future__ import annotations
import os
import pytest
from pytest_celery import CeleryTestWorker, defaults
from pytest_docker_tools import build, container, fxtr
from celery import Celery
from t.smoke.workers.dev import SmokeWorkerContainer
class AltSmokeWorkerContainer(SmokeWorkerContainer):
"""Alternative worker with different name, but same configurations."""
@classmethod
def worker_name(cls) -> str:
return "alt_smoke_tests_worker"
# Build the image like the dev worker
celery_alt_dev_worker_image = build(
path=".",
dockerfile="t/smoke/workers/docker/dev",
tag="t/smoke/worker:alt",
buildargs=AltSmokeWorkerContainer.buildargs(),
)
# Define container settings like the dev worker
alt_dev_worker_container = container(
image="{celery_alt_dev_worker_image.id}",
environment=fxtr("default_worker_env"),
network="{default_pytest_celery_network.name}",
volumes={
# Volume: Worker /app
"{default_worker_volume.name}": defaults.DEFAULT_WORKER_VOLUME,
# Mount: Celery source
os.path.abspath(os.getcwd()): {
"bind": "/celery",
"mode": "rw",
},
},
wrapper_class=AltSmokeWorkerContainer,
timeout=defaults.DEFAULT_WORKER_CONTAINER_TIMEOUT,
command=AltSmokeWorkerContainer.command(),
)
@pytest.fixture
def celery_alt_dev_worker(
alt_dev_worker_container: AltSmokeWorkerContainer,
celery_setup_app: Celery,
) -> CeleryTestWorker:
"""Creates a pytest-celery worker node from the worker container."""
worker = CeleryTestWorker(alt_dev_worker_container, app=celery_setup_app)
yield worker
worker.teardown()
|