diff options
author | Takeshi KOMIYA <i.tkomiya@gmail.com> | 2020-11-10 23:21:51 +0900 |
---|---|---|
committer | Takeshi KOMIYA <i.tkomiya@gmail.com> | 2020-11-10 23:21:51 +0900 |
commit | 1254b8011347b309af122dbe91a9439cc56f4381 (patch) | |
tree | 241b3f47ed71c3500330690118de5a7c7e55e2d4 /tests/utils.py | |
parent | 7299d589c61d3558efb9777d03454f8e2a3dafd1 (diff) | |
parent | 229e11c488fc1fbd15b0a209782aa94dc6abdf58 (diff) | |
download | sphinx-git-1254b8011347b309af122dbe91a9439cc56f4381.tar.gz |
Merge branch '3.x'
Diffstat (limited to 'tests/utils.py')
-rw-r--r-- | tests/utils.py | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/tests/utils.py b/tests/utils.py new file mode 100644 index 000000000..182dc1df0 --- /dev/null +++ b/tests/utils.py @@ -0,0 +1,27 @@ +import contextlib +import http.server +import threading + + +class HttpServerThread(threading.Thread): + def __init__(self, handler, *args, **kwargs): + super().__init__(*args, **kwargs) + self.server = http.server.HTTPServer(("localhost", 7777), handler) + + def run(self): + self.server.serve_forever(poll_interval=0.01) + + def terminate(self): + self.server.shutdown() + self.server.server_close() + self.join() + + +@contextlib.contextmanager +def http_server(handler): + server_thread = HttpServerThread(handler, daemon=True) + server_thread.start() + try: + yield server_thread + finally: + server_thread.terminate() |