Move daemon fixture up to conftest
parent
0d9483376d
commit
2ccaa94c60
|
@ -1,9 +1,13 @@
|
||||||
"""
|
"""
|
||||||
``tractor`` testing!!
|
``tractor`` testing!!
|
||||||
"""
|
"""
|
||||||
|
import sys
|
||||||
|
import subprocess
|
||||||
import os
|
import os
|
||||||
import random
|
import random
|
||||||
|
import signal
|
||||||
import platform
|
import platform
|
||||||
|
import time
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
import tractor
|
import tractor
|
||||||
|
@ -16,6 +20,19 @@ pytest_plugins = ['pytester']
|
||||||
_arb_addr = '127.0.0.1', random.randint(1000, 9999)
|
_arb_addr = '127.0.0.1', random.randint(1000, 9999)
|
||||||
|
|
||||||
|
|
||||||
|
# Sending signal.SIGINT on subprocess fails on windows. Use CTRL_* alternatives
|
||||||
|
if platform.system() == 'Windows':
|
||||||
|
_KILL_SIGNAL = signal.CTRL_BREAK_EVENT
|
||||||
|
_INT_SIGNAL = signal.CTRL_C_EVENT
|
||||||
|
_INT_RETURN_CODE = 3221225786
|
||||||
|
_PROC_SPAWN_WAIT = 2
|
||||||
|
else:
|
||||||
|
_KILL_SIGNAL = signal.SIGKILL
|
||||||
|
_INT_SIGNAL = signal.SIGINT
|
||||||
|
_INT_RETURN_CODE = 1 if sys.version_info < (3, 8) else -signal.SIGINT.value
|
||||||
|
_PROC_SPAWN_WAIT = 0.6 if sys.version_info < (3, 7) else 0.4
|
||||||
|
|
||||||
|
|
||||||
no_windows = pytest.mark.skipif(
|
no_windows = pytest.mark.skipif(
|
||||||
platform.system() == "Windows",
|
platform.system() == "Windows",
|
||||||
reason="Test is unsupported on windows",
|
reason="Test is unsupported on windows",
|
||||||
|
@ -89,3 +106,43 @@ def pytest_generate_tests(metafunc):
|
||||||
methods = ['trio']
|
methods = ['trio']
|
||||||
|
|
||||||
metafunc.parametrize("start_method", methods, scope='module')
|
metafunc.parametrize("start_method", methods, scope='module')
|
||||||
|
|
||||||
|
|
||||||
|
def sig_prog(proc, sig):
|
||||||
|
"Kill the actor-process with ``sig``."
|
||||||
|
proc.send_signal(sig)
|
||||||
|
time.sleep(0.1)
|
||||||
|
if not proc.poll():
|
||||||
|
# TODO: why sometimes does SIGINT not work on teardown?
|
||||||
|
# seems to happen only when trace logging enabled?
|
||||||
|
proc.send_signal(_KILL_SIGNAL)
|
||||||
|
ret = proc.wait()
|
||||||
|
assert ret
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def daemon(loglevel, testdir, arb_addr):
|
||||||
|
"""Run a daemon actor as a "remote arbiter".
|
||||||
|
"""
|
||||||
|
cmdargs = [
|
||||||
|
sys.executable, '-c',
|
||||||
|
"import tractor; tractor.run_daemon((), arbiter_addr={}, loglevel={})"
|
||||||
|
.format(
|
||||||
|
arb_addr,
|
||||||
|
"'{}'".format(loglevel) if loglevel else None)
|
||||||
|
]
|
||||||
|
kwargs = dict()
|
||||||
|
if platform.system() == 'Windows':
|
||||||
|
# without this, tests hang on windows forever
|
||||||
|
kwargs['creationflags'] = subprocess.CREATE_NEW_PROCESS_GROUP
|
||||||
|
|
||||||
|
proc = testdir.popen(
|
||||||
|
cmdargs,
|
||||||
|
stdout=subprocess.PIPE,
|
||||||
|
stderr=subprocess.PIPE,
|
||||||
|
**kwargs,
|
||||||
|
)
|
||||||
|
assert not proc.returncode
|
||||||
|
time.sleep(_PROC_SPAWN_WAIT)
|
||||||
|
yield proc
|
||||||
|
sig_prog(proc, _INT_SIGNAL)
|
||||||
|
|
|
@ -2,64 +2,16 @@
|
||||||
Multiple python programs invoking ``tractor.run()``
|
Multiple python programs invoking ``tractor.run()``
|
||||||
"""
|
"""
|
||||||
import platform
|
import platform
|
||||||
import sys
|
|
||||||
import time
|
import time
|
||||||
import signal
|
|
||||||
import subprocess
|
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
import tractor
|
import tractor
|
||||||
from conftest import tractor_test
|
from conftest import (
|
||||||
|
tractor_test,
|
||||||
# Sending signal.SIGINT on subprocess fails on windows. Use CTRL_* alternatives
|
sig_prog,
|
||||||
if platform.system() == 'Windows':
|
_INT_SIGNAL,
|
||||||
_KILL_SIGNAL = signal.CTRL_BREAK_EVENT
|
_INT_RETURN_CODE,
|
||||||
_INT_SIGNAL = signal.CTRL_C_EVENT
|
)
|
||||||
_INT_RETURN_CODE = 3221225786
|
|
||||||
_PROC_SPAWN_WAIT = 2
|
|
||||||
else:
|
|
||||||
_KILL_SIGNAL = signal.SIGKILL
|
|
||||||
_INT_SIGNAL = signal.SIGINT
|
|
||||||
_INT_RETURN_CODE = 1 if sys.version_info < (3, 8) else -signal.SIGINT.value
|
|
||||||
_PROC_SPAWN_WAIT = 0.6 if sys.version_info < (3, 7) else 0.4
|
|
||||||
|
|
||||||
|
|
||||||
def sig_prog(proc, sig):
|
|
||||||
"Kill the actor-process with ``sig``."
|
|
||||||
proc.send_signal(sig)
|
|
||||||
time.sleep(0.1)
|
|
||||||
if not proc.poll():
|
|
||||||
# TODO: why sometimes does SIGINT not work on teardown?
|
|
||||||
# seems to happen only when trace logging enabled?
|
|
||||||
proc.send_signal(_KILL_SIGNAL)
|
|
||||||
ret = proc.wait()
|
|
||||||
assert ret
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
|
||||||
def daemon(loglevel, testdir, arb_addr):
|
|
||||||
cmdargs = [
|
|
||||||
sys.executable, '-c',
|
|
||||||
"import tractor; tractor.run_daemon((), arbiter_addr={}, loglevel={})"
|
|
||||||
.format(
|
|
||||||
arb_addr,
|
|
||||||
"'{}'".format(loglevel) if loglevel else None)
|
|
||||||
]
|
|
||||||
kwargs = dict()
|
|
||||||
if platform.system() == 'Windows':
|
|
||||||
# without this, tests hang on windows forever
|
|
||||||
kwargs['creationflags'] = subprocess.CREATE_NEW_PROCESS_GROUP
|
|
||||||
|
|
||||||
proc = testdir.popen(
|
|
||||||
cmdargs,
|
|
||||||
stdout=subprocess.PIPE,
|
|
||||||
stderr=subprocess.PIPE,
|
|
||||||
**kwargs,
|
|
||||||
)
|
|
||||||
assert not proc.returncode
|
|
||||||
time.sleep(_PROC_SPAWN_WAIT)
|
|
||||||
yield proc
|
|
||||||
sig_prog(proc, _INT_SIGNAL)
|
|
||||||
|
|
||||||
|
|
||||||
def test_abort_on_sigint(daemon):
|
def test_abort_on_sigint(daemon):
|
||||||
|
@ -67,6 +19,7 @@ def test_abort_on_sigint(daemon):
|
||||||
time.sleep(0.1)
|
time.sleep(0.1)
|
||||||
sig_prog(daemon, _INT_SIGNAL)
|
sig_prog(daemon, _INT_SIGNAL)
|
||||||
assert daemon.returncode == _INT_RETURN_CODE
|
assert daemon.returncode == _INT_RETURN_CODE
|
||||||
|
|
||||||
# XXX: oddly, couldn't get capfd.readouterr() to work here?
|
# XXX: oddly, couldn't get capfd.readouterr() to work here?
|
||||||
if platform.system() != 'Windows':
|
if platform.system() != 'Windows':
|
||||||
# don't check stderr on windows as its empty when sending CTRL_C_EVENT
|
# don't check stderr on windows as its empty when sending CTRL_C_EVENT
|
||||||
|
|
Loading…
Reference in New Issue