forked from aio-libs/aiohttp
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_web_runner.py
More file actions
116 lines (87 loc) · 3.2 KB
/
test_web_runner.py
File metadata and controls
116 lines (87 loc) · 3.2 KB
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
import asyncio
import platform
import signal
import pytest
from aiohttp import web
from aiohttp.test_utils import get_unused_port_socket
@pytest.fixture
def app():
return web.Application()
@pytest.fixture
def make_runner(loop, app):
asyncio.set_event_loop(loop)
runners = []
def go(**kwargs):
runner = web.AppRunner(app, **kwargs)
runners.append(runner)
return runner
yield go
for runner in runners:
loop.run_until_complete(runner.cleanup())
async def test_site_for_nonfrozen_app(make_runner) -> None:
runner = make_runner()
with pytest.raises(RuntimeError):
web.TCPSite(runner)
assert len(runner.sites) == 0
@pytest.mark.skipif(platform.system() == "Windows",
reason="the test is not valid for Windows")
async def test_runner_setup_handle_signals(make_runner) -> None:
runner = make_runner(handle_signals=True)
await runner.setup()
assert signal.getsignal(signal.SIGTERM) is not signal.SIG_DFL
await runner.cleanup()
assert signal.getsignal(signal.SIGTERM) is signal.SIG_DFL
@pytest.mark.skipif(platform.system() == "Windows",
reason="the test is not valid for Windows")
async def test_runner_setup_without_signal_handling(make_runner) -> None:
runner = make_runner(handle_signals=False)
await runner.setup()
assert signal.getsignal(signal.SIGTERM) is signal.SIG_DFL
await runner.cleanup()
assert signal.getsignal(signal.SIGTERM) is signal.SIG_DFL
async def test_site_double_added(make_runner) -> None:
_sock = get_unused_port_socket('127.0.0.1')
runner = make_runner()
await runner.setup()
site = web.SockSite(runner, _sock)
await site.start()
with pytest.raises(RuntimeError):
await site.start()
assert len(runner.sites) == 1
async def test_site_stop_not_started(make_runner) -> None:
runner = make_runner()
await runner.setup()
site = web.TCPSite(runner)
with pytest.raises(RuntimeError):
await site.stop()
assert len(runner.sites) == 0
async def test_custom_log_format(make_runner) -> None:
runner = make_runner(access_log_format='abc')
await runner.setup()
assert runner.server._kwargs['access_log_format'] == 'abc'
async def test_unreg_site(make_runner) -> None:
runner = make_runner()
await runner.setup()
site = web.TCPSite(runner)
with pytest.raises(RuntimeError):
runner._unreg_site(site)
async def test_app_property(make_runner, app) -> None:
runner = make_runner()
assert runner.app is app
def test_non_app() -> None:
with pytest.raises(TypeError):
web.AppRunner(object())
@pytest.mark.skipif(platform.system() == "Windows",
reason="Unix socket support is required")
async def test_addresses(make_runner, tmpdir) -> None:
_sock = get_unused_port_socket('127.0.0.1')
runner = make_runner()
await runner.setup()
tcp = web.SockSite(runner, _sock)
await tcp.start()
path = str(tmpdir / 'tmp.sock')
unix = web.UnixSite(runner, path)
await unix.start()
actual_addrs = runner.addresses
expected_host, expected_post = _sock.getsockname()[:2]
assert actual_addrs == [(expected_host, expected_post), path]