commit aa920512752b1b1b844b45af1b58e4f838c6d42a
Author: Arturo Filastò <arturo(a)filasto.net>
Date: Thu Feb 4 17:42:15 2016 +0100
Fixes to unittests of report to changes in backend
* Minor refactoring of unittests
* Fix a backward compatibility bug spotted in unittesting
---
oonib/report/handlers.py | 27 ++++++++++--------
oonib/test/test_report.py | 71 +++++++++++++++++------------------------------
2 files changed, 41 insertions(+), 57 deletions(-)
diff --git a/oonib/report/handlers.py b/oonib/report/handlers.py
index 6594805..e35b60a 100644
--- a/oonib/report/handlers.py
+++ b/oonib/report/handlers.py
@@ -303,17 +303,22 @@ class NewReportHandlerFile(ReportHandler, UpdateReportMixin):
self.checkPolicy()
data = None
- if 'content' in report_data:
- if report_data['format'] == 'json':
- content = report_data['content']
- content['backend_version'] = config.backend_version
- data = json_dumps(content)
- elif report_data['format'] == 'yaml':
- content = yaml.safe_load(report_data['content'])
- content['backend_version'] = config.backend_version
- data = "---\n" + yaml.dump(content) + "...\n"
- else:
- raise e.InvalidFormatField
+ if 'content' in report_data and report_data['format'] == 'json':
+ content = report_data['content']
+ content['backend_version'] = config.backend_version
+ data = json_dumps(content)
+ elif report_data['format'] == 'yaml':
+ content = {
+ 'software_name': str(report_data['software_name']),
+ 'software_version': str(report_data['software_version']),
+ 'probe_asn': str(report_data['probe_asn']),
+ 'probe_cc': str(report_data['probe_cc']),
+ 'test_name': self.testName,
+ 'test_version': self.testVersion,
+ 'input_hashes': self.inputHashes,
+ 'start_time': report_data.get('start_time', time.time())
+ }
+ data = "---\n" + yaml.dump(content) + "...\n"
report_id = otime.timestamp() + '_' \
+ report_data.get('probe_asn', 'AS0') + '_' \
diff --git a/oonib/test/test_report.py b/oonib/test/test_report.py
index 9da8b08..55f78be 100644
--- a/oonib/test/test_report.py
+++ b/oonib/test/test_report.py
@@ -1,7 +1,9 @@
-import os
+import time
import json
import yaml
+from copy import deepcopy
+
from twisted.internet import defer
from cyclone import web
@@ -72,6 +74,16 @@ test_version: 0.1.0
...
"""
+dummy_data = {
+ 'software_name': 'ooni-test',
+ 'software_version': '0.1',
+ 'test_name': 'some-test',
+ 'test_version': '0.1',
+ 'probe_asn': 'AS0',
+ 'probe_cc': 'ZZ',
+ 'start_time': time.time()
+}
+
for _, handler in reportAPI:
handler.initialize = mock_initialize
@@ -92,14 +104,7 @@ class TestReport(HandlerTestCase):
@defer.inlineCallbacks
def test_create_valid_report(self):
- data = {
- 'software_name': 'ooni-test',
- 'software_version': '0.1',
- 'test_name': 'some-test',
- 'test_version': '0.1',
- 'probe_asn': 'AS0'
- }
- response = yield self.request('/report', "POST", data)
+ response = yield self.request('/report', "POST", dummy_data)
response_body = json.loads(response.body)
self.assertIn('backend_version', response_body)
self.assertIn('report_id', response_body)
@@ -107,14 +112,8 @@ class TestReport(HandlerTestCase):
@defer.inlineCallbacks
def test_create_valid_report_with_content(self):
- data = {
- 'software_name': 'ooni-test',
- 'software_version': '0.1',
- 'test_name': 'some-test',
- 'test_version': '0.1',
- 'probe_asn': 'AS0',
- 'content': sample_report_header
- }
+ data = deepcopy(dummy_data)
+ data['content'] = sample_report_header
response = yield self.request('/report', "POST", data)
response_body = json.loads(response.body)
self.assertIn('backend_version', response_body)
@@ -123,13 +122,8 @@ class TestReport(HandlerTestCase):
@defer.inlineCallbacks
def test_create_invalid_report(self):
- data = {
- 'software_name': 'ooni-test',
- 'software_version': '0.1',
- 'test_name': 'some-test',
- 'test_version': '0.1',
- 'probe_asn': 'XXX'
- }
+ data = deepcopy(dummy_data)
+ data['probe_asn'] = 'XXXINVALID'
response = yield self.request('/report', "POST", data)
response_body = json.loads(response.body)
self.assertIn('error', response_body)
@@ -138,14 +132,7 @@ class TestReport(HandlerTestCase):
@defer.inlineCallbacks
def test_create_and_update_report(self):
- report_header = {
- 'software_name': 'ooni-test',
- 'software_version': '0.1',
- 'test_name': 'some-test',
- 'test_version': '0.1',
- 'probe_asn': 'AS0'
- }
- response = yield self.request('/report', "POST", report_header)
+ response = yield self.request('/report', "POST", dummy_data)
response_body = json.loads(response.body)
self.assertIn('backend_version', response_body)
self.assertIn('report_id', response_body)
@@ -159,21 +146,14 @@ class TestReport(HandlerTestCase):
written_report = yaml.safe_load_all(f)
written_report_header = written_report.next()
- for key in report_header.keys():
- self.assertEqual(written_report_header[key], report_header[key])
+ for key in dummy_data.keys():
+ self.assertEqual(written_report_header[key], dummy_data[key])
self.assertEqual(yaml.safe_load(sample_report_entry),
written_report.next())
@defer.inlineCallbacks
def test_create_update_and_close_report(self):
- report_header = {
- 'software_name': 'ooni-test',
- 'software_version': '0.1',
- 'test_name': 'some-test',
- 'test_version': '0.1',
- 'probe_asn': 'AS0'
- }
- response = yield self.request('/report', "POST", report_header)
+ response = yield self.request('/report', "POST", dummy_data)
response_body = json.loads(response.body)
self.assertIn('backend_version', response_body)
self.assertIn('report_id', response_body)
@@ -188,15 +168,16 @@ class TestReport(HandlerTestCase):
written_report = yaml.safe_load_all(f)
written_report_header = written_report.next()
- for key in report_header.keys():
+ for key in dummy_data.keys():
self.assertEqual(written_report_header[key],
- report_header[key])
+ dummy_data[key])
self.assertEqual(yaml.safe_load(sample_report_entry),
written_report.next())
response = yield self.request('/report/%s/close' % report_id, "POST")
+ written_report_header['format'] = 'yaml'
written_report_path = report_file_name(".", written_report_header)
with open(written_report_path) as f:
self.filenames.add(written_report_path)
@@ -206,5 +187,3 @@ class TestReport(HandlerTestCase):
for i in range(report_entry_count):
self.assertEqual(yaml.safe_load(sample_report_entry),
written_report.next())
-
- self.directories.add('ZZ')