summaryrefslogtreecommitdiff
path: root/tests/utils.py
diff options
context:
space:
mode:
authorTakeshi KOMIYA <i.tkomiya@gmail.com>2020-11-21 01:01:36 +0900
committerTakeshi KOMIYA <i.tkomiya@gmail.com>2020-11-21 01:01:36 +0900
commit3a4ae2092a6f236e2d71fdedb4b66f594e30d4e7 (patch)
treeafa4f774e0f8660d5ce247f01cace9deaa848d58 /tests/utils.py
parentf3a6004f822b05e352372a77f449332ad230d21e (diff)
parent18b2707b2ac621f23f8ee6a7ca19bf1590be7826 (diff)
downloadsphinx-git-3a4ae2092a6f236e2d71fdedb4b66f594e30d4e7.tar.gz
Merge branch '3.x'
Diffstat (limited to 'tests/utils.py')
-rw-r--r--tests/utils.py48
1 files changed, 43 insertions, 5 deletions
diff --git a/tests/utils.py b/tests/utils.py
index 182dc1df0..eb2c40c52 100644
--- a/tests/utils.py
+++ b/tests/utils.py
@@ -1,7 +1,15 @@
import contextlib
import http.server
+import os
+import pathlib
+import ssl
import threading
+# Generated with:
+# $ openssl req -new -x509 -days 3650 -nodes -out cert.pem \
+# -keyout cert.pem -addext "subjectAltName = DNS:localhost"
+CERT_FILE = str(pathlib.Path(__file__).parent / "certs" / "cert.pem")
+
class HttpServerThread(threading.Thread):
def __init__(self, handler, *args, **kwargs):
@@ -17,11 +25,41 @@ class HttpServerThread(threading.Thread):
self.join()
+class HttpsServerThread(HttpServerThread):
+ def __init__(self, handler, *args, **kwargs):
+ super().__init__(handler, *args, **kwargs)
+ self.server.socket = ssl.wrap_socket(
+ self.server.socket,
+ certfile=CERT_FILE,
+ server_side=True,
+ )
+
+
+def create_server(thread_class):
+ def server(handler):
+ server_thread = thread_class(handler, daemon=True)
+ server_thread.start()
+ try:
+ yield server_thread
+ finally:
+ server_thread.terminate()
+ return contextlib.contextmanager(server)
+
+
+http_server = create_server(HttpServerThread)
+https_server = create_server(HttpsServerThread)
+
+
@contextlib.contextmanager
-def http_server(handler):
- server_thread = HttpServerThread(handler, daemon=True)
- server_thread.start()
+def modify_env(**env):
+ original_env = os.environ.copy()
+ for k, v in env.items():
+ os.environ[k] = v
try:
- yield server_thread
+ yield
finally:
- server_thread.terminate()
+ for k in env:
+ try:
+ os.environ[k] = original_env[k]
+ except KeyError:
+ os.unsetenv(k)