[tor-commits] [sbws/master] fix: tests: Check the files generated in test net

juga at torproject.org juga at torproject.org
Tue Apr 14 13:54:37 UTC 2020


commit 4e2ccf3c34df54139954256528813305b48596c0
Author: juga0 <juga at riseup.net>
Date:   Sun Mar 22 16:28:16 2020 +0000

    fix: tests: Check the files generated in test net
    
    Test that the results, state and bandwidth file generated by running
    the scanner and the generator in the test network are correct.
---
 tests/integration/conftest.py   | 11 ++++-----
 tests/integration/test_files.py | 49 +++++++++++++++++++++++++++++++++++++++++
 2 files changed, 55 insertions(+), 5 deletions(-)

diff --git a/tests/integration/conftest.py b/tests/integration/conftest.py
index b1312d9..170ea51 100644
--- a/tests/integration/conftest.py
+++ b/tests/integration/conftest.py
@@ -36,15 +36,15 @@ def tmpdir(tmpdir_factory, request):
 
 @pytest.fixture(scope='session')
 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
+    """Create sbws home inside of the test net tmp dir without initializing."""
+    home = "/tmp/.sbws"
+    os.makedirs(home, exist_ok=True)
+    return home
 
 
 @pytest.fixture(scope='session')
 def sbwshome_dir(sbwshome_empty):
-    """Create sbws home inside of the tests tmp dir without initializing."""
+    """Create sbws home inside of the test net tmp dir without initializing."""
     os.makedirs(os.path.join(sbwshome_empty, 'datadir'), exist_ok=True)
     return sbwshome_empty
 
@@ -69,6 +69,7 @@ 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["paths"]["state_fpath"] = os.path.join(sbwshome_dir, "state.dat")
     conf['tor']['run_dpath'] = os.path.join(sbwshome_dir, 'tor', 'run')
     conf['destinations']['foo'] = 'on'
     conf['destinations.foo'] = {}
diff --git a/tests/integration/test_files.py b/tests/integration/test_files.py
new file mode 100644
index 0000000..aa7973d
--- /dev/null
+++ b/tests/integration/test_files.py
@@ -0,0 +1,49 @@
+"""
+Integration tests for the files with data to be used by the bandwidth file.
+
+"""
+from sbws.lib.resultdump import load_recent_results_in_datadir
+from sbws.lib.v3bwfile import V3BWFile
+from sbws.util.state import State
+
+
+def test_results(conf):
+    results = load_recent_results_in_datadir(5, conf["paths"]["datadir"])
+    for fp, values in results.items():
+        count = max(
+            [
+                len(getattr(r, "relay_recent_measurement_attempt", []))
+                for r in values
+            ]
+        )
+        assert count == 1
+        count = max(
+            [len(getattr(r, "relay_in_recent_consensus", [])) for r in values]
+        )
+        assert count == 1
+        count = max(
+            [len(getattr(r, "relay_recent_priority_list", [])) for r in values]
+        )
+        assert count == 1
+
+
+def test_state(conf):
+    state = State(conf["paths"]["state_fpath"])
+    assert 1 == state.count("recent_consensus")
+    assert 1 == state.count("recent_priority_list")
+    assert 15 == state.count("recent_priority_relay")
+    assert 15 == state.count("recent_measurement_attempt")
+
+
+def test_v3bwfile(conf):
+    bwfile = V3BWFile.from_v1_fpath(
+        conf["paths"]["v3bw_fname"].format("latest")
+    )
+    assert "1" == bwfile.header.recent_consensus_count
+    assert "1" == bwfile.header.recent_priority_list_count
+    assert "15" == bwfile.header.recent_priority_relay_count
+    assert "15" == bwfile.header.recent_measurement_attempt_count
+    for bwline in bwfile.bw_lines:
+        assert 1 == bwline.relay_in_recent_consensus_count
+        assert 1 == bwline.relay_recent_priority_list_count
+        assert 1 == bwline.relay_recent_measurement_attempt_count





More information about the tor-commits mailing list