commit d3dfb5b2deccb4ff057f89a5c209050e2c69c1dc
Author: Karsten Loesing <karsten.loesing(a)gmx.net>
Date: Thu May 14 21:40:20 2020 +0200
Update analysis results file version to 2.0.
Implements #34224.
---
README_JSON.md | 4 +++-
onionperf/analysis.py | 8 ++++----
2 files changed, 7 insertions(+), 5 deletions(-)
diff --git a/README_JSON.md b/README_JSON.md
index d057bb1..f0ad281 100644
--- a/README_JSON.md
+++ b/README_JSON.md
@@ -207,5 +207,7 @@ The structure is given here with variable keys marked as such.
}
}
}
- }
+ },
+ "type": "onionperf", # document type
+ "version": "2.0" # document version
}
diff --git a/onionperf/analysis.py b/onionperf/analysis.py
index 83f993d..a380027 100644
--- a/onionperf/analysis.py
+++ b/onionperf/analysis.py
@@ -37,7 +37,7 @@ class Analysis(object):
self.nickname = nickname
self.measurement_ip = ip_address
self.hostname = gethostname().split('.')[0]
- self.json_db = {'type':'onionperf', 'version':1.0, 'data':{}}
+ self.json_db = {'type':'onionperf', 'version':'2.0', 'data':{}}
self.tgen_filepaths = []
self.torctl_filepaths = []
self.date_filter = None
@@ -102,7 +102,7 @@ class Analysis(object):
else:
self.json_db['data'][nickname] = analysis.json_db['data'][nickname]
- def save(self, filename=None, output_prefix=os.getcwd(), do_compress=True, version=1.0):
+ def save(self, filename=None, output_prefix=os.getcwd(), do_compress=True):
if filename is None:
if self.date_filter is None:
filename = "onionperf.analysis.json.xz"
@@ -122,7 +122,7 @@ class Analysis(object):
logging.info("done!")
@classmethod
- def load(cls, filename="onionperf.analysis.json.xz", input_prefix=os.getcwd(), version=1.0):
+ def load(cls, filename="onionperf.analysis.json.xz", input_prefix=os.getcwd()):
filepath = os.path.abspath(os.path.expanduser("{0}".format(filename)))
if not os.path.exists(filepath):
filepath = os.path.abspath(os.path.expanduser("{0}/{1}".format(input_prefix, filename)))
@@ -142,7 +142,7 @@ class Analysis(object):
if 'type' not in db or 'version' not in db:
logging.warning("'type' or 'version' not present in database")
return None
- elif db['type'] != 'onionperf' or db['version'] != 1.0:
+ elif db['type'] != 'onionperf' or str(db['version']) >= '3.':
logging.warning("type or version not supported (type={0}, version={1})".format(db['type'], db['version']))
return None
else: