From 43a97878ce14b72f0981164f87f2e35e14151312 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 11:22:09 +0200 Subject: Adding upstream version 110.0.1. Signed-off-by: Daniel Baumann --- .../tests/tools/serve/test_functional.py | 81 ++++++++++++++++++++++ 1 file changed, 81 insertions(+) create mode 100644 testing/web-platform/tests/tools/serve/test_functional.py (limited to 'testing/web-platform/tests/tools/serve/test_functional.py') diff --git a/testing/web-platform/tests/tools/serve/test_functional.py b/testing/web-platform/tests/tools/serve/test_functional.py new file mode 100644 index 0000000000..94bedb60f7 --- /dev/null +++ b/testing/web-platform/tests/tools/serve/test_functional.py @@ -0,0 +1,81 @@ +# mypy: allow-untyped-defs + +try: + from importlib import reload +except ImportError: + pass +import json +import os +import queue +import tempfile +import threading + +import pytest + +from . import serve +from wptserve import logger + + +class ServerProcSpy(serve.ServerProc): + instances = None + + def start(self, *args, **kwargs): + result = super().start(*args, **kwargs) + + if ServerProcSpy.instances is not None: + ServerProcSpy.instances.put(self) + + return result + + +serve.ServerProc = ServerProcSpy # type: ignore + + +@pytest.fixture() +def server_subprocesses(): + ServerProcSpy.instances = queue.Queue() + yield ServerProcSpy.instances + ServerProcSpy.instances = None + + +@pytest.fixture() +def tempfile_name(): + fd, name = tempfile.mkstemp() + yield name + os.close(fd) + os.remove(name) + + +def test_subprocess_exit(server_subprocesses, tempfile_name): + timeout = 30 + + def target(): + # By default, the server initially creates a child process to validate + # local system configuration. That process is unrelated to the behavior + # under test, but at the time of this writing, the parent uses the same + # constructor that is also used to create the long-running processes + # which are relevant to this functionality. Disable the check so that + # the constructor is only used to create relevant processes. + with open(tempfile_name, 'w') as handle: + json.dump({"check_subdomains": False, "bind_address": False}, handle) + + # The `logger` module from the wptserver package uses a singleton + # pattern which resists testing. In order to avoid conflicting with + # other tests which rely on that module, pre-existing state is + # discarded through an explicit "reload" operation. + reload(logger) + + serve.run(config_path=tempfile_name) + + thread = threading.Thread(target=target) + + thread.start() + + server_subprocesses.get(True, timeout) + subprocess = server_subprocesses.get(True, timeout) + subprocess.request_shutdown() + subprocess.wait() + + thread.join(timeout) + + assert not thread.is_alive() -- cgit v1.2.3