Do some Eliot logging in the integration test suite

This commit is contained in:
Jean-Paul Calderone 2019-02-27 09:12:00 -05:00
parent 29503c5648
commit 432aaa2904
1 changed files with 83 additions and 40 deletions

View File

@ -8,6 +8,12 @@ from os.path import join, exists
from tempfile import mkdtemp, mktemp from tempfile import mkdtemp, mktemp
from functools import partial from functools import partial
from eliot import (
to_file,
log_call,
start_action,
)
from twisted.python.procutils import which from twisted.python.procutils import which
from twisted.internet.error import ( from twisted.internet.error import (
ProcessExitedAlready, ProcessExitedAlready,
@ -36,14 +42,21 @@ def pytest_addoption(parser):
help="Keep the tmpdir with the client directories (introducer, etc)", help="Keep the tmpdir with the client directories (introducer, etc)",
) )
@pytest.fixture(autouse=True, scope='session')
def eliot_logging():
with open("integration.eliot.json", "w") as f:
to_file(f)
yield
# I've mostly defined these fixtures from "easiest" to "most # I've mostly defined these fixtures from "easiest" to "most
# complicated", and the dependencies basically go "down the # complicated", and the dependencies basically go "down the
# page". They're all session-scoped which has the "pro" that we only # page". They're all session-scoped which has the "pro" that we only
# set up the grid once, but the "con" that each test has to be a # set up the grid once, but the "con" that each test has to be a
# little careful they're not stepping on toes etc :/ # little careful they're not stepping on toes etc :/
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(action_type=u"integration:reactor", include_result=False)
def reactor(): def reactor():
# this is a fixture in case we might want to try different # this is a fixture in case we might want to try different
# reactors for some reason. # reactors for some reason.
@ -52,6 +65,7 @@ def reactor():
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(action_type=u"integration:temp_dir", include_args=[])
def temp_dir(request): def temp_dir(request):
""" """
Invoke like 'py.test --keep-tempdir ...' to avoid deleting the temp-dir Invoke like 'py.test --keep-tempdir ...' to avoid deleting the temp-dir
@ -76,11 +90,13 @@ def temp_dir(request):
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(action_type=u"integration:flog_binary", include_args=[])
def flog_binary(): def flog_binary():
return which('flogtool')[0] return which('flogtool')[0]
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(action_type=u"integration:flog_gatherer", include_args=[])
def flog_gatherer(reactor, temp_dir, flog_binary, request): def flog_gatherer(reactor, temp_dir, flog_binary, request):
out_protocol = _CollectOutputProtocol() out_protocol = _CollectOutputProtocol()
gather_dir = join(temp_dir, 'flog_gather') gather_dir = join(temp_dir, 'flog_gather')
@ -139,6 +155,11 @@ def flog_gatherer(reactor, temp_dir, flog_binary, request):
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(
action_type=u"integration:introducer",
include_args=["temp_dir", "flog_gatherer"],
include_result=False,
)
def introducer(reactor, temp_dir, flog_gatherer, request): def introducer(reactor, temp_dir, flog_gatherer, request):
config = ''' config = '''
[node] [node]
@ -190,6 +211,7 @@ log_gatherer.furl = {log_furl}
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(action_type=u"integration:introducer:furl", include_args=["temp_dir"])
def introducer_furl(introducer, temp_dir): def introducer_furl(introducer, temp_dir):
furl_fname = join(temp_dir, 'introducer', 'private', 'introducer.furl') furl_fname = join(temp_dir, 'introducer', 'private', 'introducer.furl')
while not exists(furl_fname): while not exists(furl_fname):
@ -200,6 +222,11 @@ def introducer_furl(introducer, temp_dir):
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(
action_type=u"integration:tor:introducer",
include_args=["temp_dir", "flog_gatherer"],
include_result=False,
)
def tor_introducer(reactor, temp_dir, flog_gatherer, request): def tor_introducer(reactor, temp_dir, flog_gatherer, request):
config = ''' config = '''
[node] [node]
@ -268,6 +295,11 @@ def tor_introducer_furl(tor_introducer, temp_dir):
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(
action_type=u"integration:storage_nodes",
include_args=["temp_dir", "introducer_furl", "flog_gatherer"],
include_result=False,
)
def storage_nodes(reactor, temp_dir, introducer, introducer_furl, flog_gatherer, request): def storage_nodes(reactor, temp_dir, introducer, introducer_furl, flog_gatherer, request):
nodes = [] nodes = []
# start all 5 nodes in parallel # start all 5 nodes in parallel
@ -287,6 +319,7 @@ def storage_nodes(reactor, temp_dir, introducer, introducer_furl, flog_gatherer,
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(action_type=u"integration:alice", include_args=[], include_result=False)
def alice(reactor, temp_dir, introducer_furl, flog_gatherer, storage_nodes, request): def alice(reactor, temp_dir, introducer_furl, flog_gatherer, storage_nodes, request):
try: try:
mkdir(join(temp_dir, 'magic-alice')) mkdir(join(temp_dir, 'magic-alice'))
@ -304,6 +337,7 @@ def alice(reactor, temp_dir, introducer_furl, flog_gatherer, storage_nodes, requ
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(action_type=u"integration:bob", include_args=[], include_result=False)
def bob(reactor, temp_dir, introducer_furl, flog_gatherer, storage_nodes, request): def bob(reactor, temp_dir, introducer_furl, flog_gatherer, storage_nodes, request):
try: try:
mkdir(join(temp_dir, 'magic-bob')) mkdir(join(temp_dir, 'magic-bob'))
@ -321,54 +355,63 @@ def bob(reactor, temp_dir, introducer_furl, flog_gatherer, storage_nodes, reques
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(action_type=u"integration:alice:invite", include_args=["temp_dir"])
def alice_invite(reactor, alice, temp_dir, request): def alice_invite(reactor, alice, temp_dir, request):
node_dir = join(temp_dir, 'alice') node_dir = join(temp_dir, 'alice')
# FIXME XXX by the time we see "client running" in the logs, the with start_action(action_type=u"integration:alice:magic_folder:create"):
# storage servers aren't "really" ready to roll yet (uploads # FIXME XXX by the time we see "client running" in the logs, the
# fairly consistently fail if we don't hack in this pause...) # storage servers aren't "really" ready to roll yet (uploads fairly
import time ; time.sleep(5) # consistently fail if we don't hack in this pause...)
proto = _CollectOutputProtocol() import time ; time.sleep(5)
reactor.spawnProcess( proto = _CollectOutputProtocol()
proto, reactor.spawnProcess(
sys.executable, proto,
[ sys.executable,
sys.executable, '-m', 'allmydata.scripts.runner', [
'magic-folder', 'create', sys.executable, '-m', 'allmydata.scripts.runner',
'--poll-interval', '2', 'magic-folder', 'create',
'--basedir', node_dir, 'magik:', 'alice', '--poll-interval', '2',
join(temp_dir, 'magic-alice'), '--basedir', node_dir, 'magik:', 'alice',
] join(temp_dir, 'magic-alice'),
) ]
pytest_twisted.blockon(proto.done) )
pytest_twisted.blockon(proto.done)
proto = _CollectOutputProtocol() with start_action(action_type=u"integration:alice:magic_folder:invite") as a:
reactor.spawnProcess( proto = _CollectOutputProtocol()
proto, reactor.spawnProcess(
sys.executable, proto,
[ sys.executable,
sys.executable, '-m', 'allmydata.scripts.runner', [
'magic-folder', 'invite', sys.executable, '-m', 'allmydata.scripts.runner',
'--basedir', node_dir, 'magik:', 'bob', 'magic-folder', 'invite',
] '--basedir', node_dir, 'magik:', 'bob',
) ]
pytest_twisted.blockon(proto.done) )
invite = proto.output.getvalue() pytest_twisted.blockon(proto.done)
print("invite from alice", invite) invite = proto.output.getvalue()
a.add_success_fields(invite=invite)
# before magic-folder works, we have to stop and restart (this is with start_action(action_type=u"integration:alice:magic_folder:restart"):
# crappy for the tests -- can we fix it in magic-folder?) # before magic-folder works, we have to stop and restart (this is
try: # crappy for the tests -- can we fix it in magic-folder?)
alice.signalProcess('TERM') try:
pytest_twisted.blockon(alice.exited) alice.signalProcess('TERM')
except ProcessExitedAlready: pytest_twisted.blockon(alice.exited)
pass except ProcessExitedAlready:
magic_text = 'Completed initial Magic Folder scan successfully' pass
pytest_twisted.blockon(_run_node(reactor, node_dir, request, magic_text)) with start_action(action_type=u"integration:alice:magic_folder:magic-text"):
magic_text = 'Completed initial Magic Folder scan successfully'
pytest_twisted.blockon(_run_node(reactor, node_dir, request, magic_text))
return invite return invite
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
@log_call(
action_type=u"integration:magic_folder",
include_args=["alice_invite", "temp_dir"],
)
def magic_folder(reactor, alice_invite, alice, bob, temp_dir, request): def magic_folder(reactor, alice_invite, alice, bob, temp_dir, request):
print("pairing magic-folder") print("pairing magic-folder")
bob_dir = join(temp_dir, 'bob') bob_dir = join(temp_dir, 'bob')