[tor-commits] [sbws/master] Create args, confs and other fixtures

pastly at torproject.org pastly at torproject.org
Wed Jul 11 15:05:40 UTC 2018


commit 4f5fd8f5729ef8f734efb8a96b7adbcb585c1252
Author: juga0 <juga at riseup.net>
Date:   Thu Jul 5 14:58:32 2018 +0000

    Create args, confs and other fixtures
---
 tests/integration/conftest.py | 115 +++++++++++++++++++++++++++++++++---------
 1 file changed, 91 insertions(+), 24 deletions(-)

diff --git a/tests/integration/conftest.py b/tests/integration/conftest.py
index cfd0e28..1294624 100644
--- a/tests/integration/conftest.py
+++ b/tests/integration/conftest.py
@@ -1,37 +1,72 @@
+"""pytest configuration for integration tests."""
+import argparse
 import pytest
-from tempfile import TemporaryDirectory
-from sbws.util.parser import create_parser
-from sbws.util.config import get_config
-from sbws.util.stem import launch_tor
-import sbws.core.init
 import os
 
+from sbws.core import init
+from sbws.lib.circuitbuilder import GapsCircuitBuilder as CB
+from sbws.lib.destination import DestinationList
+from sbws.lib.relaylist import RelayList
+from sbws.util.config import _get_default_config
+from sbws.util.stem import launch_tor
+
+
+class _PseudoArguments(argparse.Namespace):
+
+    """Just enough of the argparse.Namespace (what you get when you do
+    args = parser.parse_args()) to make get_config() happy
+
+    >>> args = _PseudoArguments(directory='/home/matt/.sbws')
+    >>> args.directory
+    '/home/matt/.sbws'
+
+    """
+
+    def __init__(self, **kw):
+        for key in kw:
+            setattr(self, key, kw[key])
+
+
+ at pytest.fixture(scope='session')
+def tmpdir(tmpdir_factory, request):
+    """Create a tmp dir for the tests"""
+    base = str(hash(request.node.nodeid))[:3]
+    bn = tmpdir_factory.mktemp(base)
+    return bn
+
 
 @pytest.fixture(scope='session')
-def parser():
-    return create_parser()
+def sbwshome_empty(tmpdir):
+    """Create sbws home inside of the tests tmp dir without initializing."""
+    home = tmpdir.join('.sbws')
+    os.makedirs(home.strpath, exist_ok=True)
+    return home.strpath
 
 
 @pytest.fixture(scope='session')
-def persistent_empty_dotsbws(parser):
-    '''
-    Creates a ~/.sbws with nothing in it but a config.ini and a datadir/
-    '''
-    d = TemporaryDirectory()
-    args = parser.parse_args(
-        '-d {} --log-level debug init'.format(d.name).split())
-    conf = get_config(args)
-    sbws.core.init.main(args, conf)
-    os.makedirs(os.path.join(d.name, 'datadir'))
-    return d
+def sbwshome_dir(sbwshome_empty):
+    """Create sbws home inside of the tests tmp dir without initializing."""
+    os.makedirs(os.path.join(sbwshome_empty, 'datadir'), exist_ok=True)
+    return sbwshome_empty
 
 
 @pytest.fixture(scope='session')
-def persistent_launch_tor(parser, persistent_empty_dotsbws):
-    d = persistent_empty_dotsbws
-    args = parser.parse_args('-d {}'.format(d.name).split())
-    conf = get_config(args)
-    conf['tor']['extra_lines'] = '''  # noqa: E501
+def args(sbwshome_dir, parser):
+    """Args with sbws home in the tests tmp dir."""
+    args = _PseudoArguments(directory=sbwshome_dir, output=sbwshome_dir,
+                            scale=False, log_level='debug')
+    return args
+
+
+ at pytest.fixture(scope='session')
+def conf(sbwshome_dir):
+    """Default configuration with sbws home in the tmp test dir."""
+    conf = _get_default_config()
+    conf['paths']['sbws_home'] = sbwshome_dir
+    conf['destinations']['foo'] = 'on'
+    conf['destinations.foo'] = {}
+    conf['destinations.foo']['url'] = 'http://127.0.0.1:28888/sbws.bin'
+    conf['tor']['extra_lines'] = """  # noqa: E501
 DirAuthority auth1 orport=2002 no-v2 v3ident=D7DBC517EFD2BA1A5012CF1BD0BB38F17C8160BD 127.10.0.1:2003 AA45C13025C037F056E734169891878ED0880231
 DirAuthority auth2 orport=2002 no-v2 v3ident=4EE103A081F400E6622F5461D51782B876BB5C24 127.10.0.2:2003 E7B3C9A0040D628DAC88B0251AE6334D28E8F531
 DirAuthority auth3 orport=2002 no-v2 v3ident=8B85069C7FC0593801E6491A34100264FCE28980 127.10.0.3:2003 35E3B8BB71C81355649AEC5862ECB7ED7EFDBC5C
@@ -39,6 +74,38 @@ TestingTorNetwork 1
 NumCPUs 1
 LogTimeGranularity 1
 SafeLogging 0
-'''
+"""
+    return conf
+
+
+ at pytest.fixture(scope='session')
+def sbwshome(sbwshome_dir, args, conf):
+    init.main(args, conf)
+    return sbwshome_dir
+
+
+ at pytest.fixture(scope='session')
+def persistent_launch_tor(conf):
     cont = launch_tor(conf)
     return cont
+
+
+ at pytest.fixture(scope='session')
+def rl(args, conf, persistent_launch_tor):
+    return RelayList(args, conf, persistent_launch_tor)
+
+
+ at pytest.fixture(scope='session')
+def cb(args, conf, persistent_launch_tor, rl):
+    return CB(args, conf, persistent_launch_tor, rl)
+
+
+ at pytest.fixture(scope='session')
+def dests(args, conf, persistent_launch_tor, cb, rl):
+    dests, error_msg = DestinationList.from_config(conf, cb, rl,
+                                                   persistent_launch_tor)
+    assert dests, error_msg
+    return dests
+
+
+# @pytest.fixture(scope='session')





More information about the tor-commits mailing list