[tor-commits] [sbws/master] fix: v3bwfile: Add tor_version KeyValue
juga at torproject.org
juga at torproject.org
Mon Mar 9 14:38:43 UTC 2020
commit 6843145a2887fb2496a2b5cef30ffabae2402cda
Author: juga0 <juga at riseup.net>
Date: Sun Feb 9 17:03:13 2020 +0000
fix: v3bwfile: Add tor_version KeyValue
- Create new KeyValues constants for the new v1.5.0 KeyValues
- Instanciate State in Header.from_results so that there is no need
to create new methods for all the header KeyValues that are read
from the state file
- Add tor_version to the kwargs to initialize the Header
- Write tor_version in the state file when the scanner is started
Closes: #30196.
---
sbws/core/scanner.py | 7 ++++++-
sbws/lib/v3bwfile.py | 19 +++++++++++++++++++
tests/unit/lib/test_v3bwfile.py | 15 +++++++++++----
3 files changed, 36 insertions(+), 5 deletions(-)
diff --git a/sbws/core/scanner.py b/sbws/core/scanner.py
index d3ed5b1..3178594 100644
--- a/sbws/core/scanner.py
+++ b/sbws/core/scanner.py
@@ -679,9 +679,14 @@ def run_speedtest(args, conf):
# When there will be a refactor where conf is global, this can be removed
# from here.
state = State(conf.getpath('paths', 'state_fname'))
+ # XXX: tech-debt: create new function to obtain the controller and to
+ # write the state, so that a unit test to check the state tor version can
+ # be created
+ # Store tor version whenever the scanner starts.
+ state['tor_version'] = str(controller.get_version())
# Call only once to initialize http_headers
settings.init_http_headers(conf.get('scanner', 'nickname'), state['uuid'],
- str(controller.get_version()))
+ state['tor_version'])
# To do not have to pass args and conf to RelayList, pass an extra
# argument with the data_period
measurements_period = conf.getint('general', 'data_period')
diff --git a/sbws/lib/v3bwfile.py b/sbws/lib/v3bwfile.py
index 49015c0..2f34376 100644
--- a/sbws/lib/v3bwfile.py
+++ b/sbws/lib/v3bwfile.py
@@ -121,12 +121,21 @@ HEADER_KEYS_V1_4 = [
'time_to_report_half_network',
] + HEADER_RECENT_MEASUREMENTS_EXCLUDED_KEYS
+# KeyValues added in the Bandwidth File v1.5.0
+# XXX: Change SPEC_VERSION when all the v1.5.0 keys are added, before a new
+# sbws release.
+# Tor version will be obtained from the state file, so it won't be pass as an
+# argument, but will be self-initialized.
+HEADER_KEYS_V1_5_TO_INIT = ['tor_version']
+HEADER_KEYS_V1_5 = HEADER_KEYS_V1_5_TO_INIT
+
# KeyValues that are initialized from arguments, not self-initialized.
HEADER_INIT_KEYS = (
HEADER_KEYS_V1_1_TO_INIT
+ HEADER_KEYS_V1_3
+ HEADER_KEYS_V1_2
+ HEADER_KEYS_V1_4
+ + HEADER_KEYS_V1_5_TO_INIT
)
HEADER_INT_KEYS = HEADER_KEYS_V1_2 + HEADER_KEYS_V1_4
@@ -137,6 +146,7 @@ HEADER_UNORDERED_KEYS = (
+ HEADER_KEYS_V1_3
+ HEADER_KEYS_V1_2
+ HEADER_KEYS_V1_4
+ + HEADER_KEYS_V1_5
)
# List of all the KeyValues currently being used to generate the file
HEADER_ALL_KEYS = HEADER_KEYS_V1_1_ORDERED + HEADER_UNORDERED_KEYS
@@ -331,6 +341,15 @@ class V3BWHeader(object):
generator_started = cls.generator_started_from_file(state_fpath)
recent_consensus_count = cls.consensus_count_from_file(state_fpath)
timestamp = str(latest_bandwidth)
+
+ # XXX: tech-debt: obtain the other values from the state file using
+ # this state variable.
+ # Store the state as an attribute of the object?
+ state = State(state_fpath)
+ tor_version = state.get('tor_version', None)
+ if tor_version:
+ kwargs['tor_version'] = tor_version
+
kwargs['latest_bandwidth'] = unixts_to_isodt_str(latest_bandwidth)
kwargs['earliest_bandwidth'] = unixts_to_isodt_str(earliest_bandwidth)
if generator_started is not None:
diff --git a/tests/unit/lib/test_v3bwfile.py b/tests/unit/lib/test_v3bwfile.py
index 40ffe16..566cc8d 100644
--- a/tests/unit/lib/test_v3bwfile.py
+++ b/tests/unit/lib/test_v3bwfile.py
@@ -50,10 +50,14 @@ earliest_bandwidth_l = KEYVALUE_SEP_V1.join(['earliest_bandwidth',
generator_started = '2018-04-16T14:09:05'
generator_started_l = KEYVALUE_SEP_V1.join(['generator_started',
generator_started])
+tor_version = '0.4.2.5'
+tor_version_l = KEYVALUE_SEP_V1.join(['tor_version', tor_version])
+
header_extra_ls = [timestamp_l, version_l,
earliest_bandwidth_l, file_created_l, generator_started_l,
latest_bandwidth_l,
- software_l, software_version_l, TERMINATOR]
+ software_l, software_version_l, tor_version_l,
+ TERMINATOR]
header_extra_str = LINE_SEP.join(header_extra_ls) + LINE_SEP
# Line produced without any scaling.
@@ -90,7 +94,8 @@ def test_v3bwheader_extra_str():
header = V3BWHeader(timestamp_l,
file_created=file_created,
generator_started=generator_started,
- earliest_bandwidth=earliest_bandwidth)
+ earliest_bandwidth=earliest_bandwidth,
+ tor_version=tor_version)
assert header_extra_str == str(header)
@@ -98,7 +103,8 @@ def test_v3bwheader_from_lines():
header_obj = V3BWHeader(timestamp_l,
file_created=file_created,
generator_started=generator_started,
- earliest_bandwidth=earliest_bandwidth)
+ earliest_bandwidth=earliest_bandwidth,
+ tor_version=tor_version)
header, _ = V3BWHeader.from_lines_v1(header_extra_ls)
assert str(header_obj) == str(header)
@@ -107,7 +113,8 @@ def test_v3bwheader_from_text():
header_obj = V3BWHeader(timestamp_l,
file_created=file_created,
generator_started=generator_started,
- earliest_bandwidth=earliest_bandwidth)
+ earliest_bandwidth=earliest_bandwidth,
+ tor_version=tor_version)
header, _ = V3BWHeader.from_text_v1(header_extra_str)
assert str(header_obj) == str(header)
More information about the tor-commits
mailing list