[tor-commits] [stem/master] Resume hidden service tests
atagar at torproject.org
atagar at torproject.org
Sun Nov 17 23:40:39 UTC 2019
commit 13e166b54eb3b7c1c8d4e4960d08df6571f93f00
Author: Damian Johnson <atagar at torproject.org>
Date: Sun Nov 17 14:46:38 2019 -0800
Resume hidden service tests
Resuming our HSv3 tests, with blinding mocked out so we don't negatively impact
runtime (without these mocks the unit tests jump from 6s => 51s).
---
test/unit/descriptor/hidden_service_v3.py | 41 ++++++++++++++-----------------
1 file changed, 19 insertions(+), 22 deletions(-)
diff --git a/test/unit/descriptor/hidden_service_v3.py b/test/unit/descriptor/hidden_service_v3.py
index 34108188..6a838c8a 100644
--- a/test/unit/descriptor/hidden_service_v3.py
+++ b/test/unit/descriptor/hidden_service_v3.py
@@ -80,14 +80,21 @@ with open(get_resource('hidden_service_v3_intro_point')) as intro_point_file:
INTRO_POINT_STR = intro_point_file.read()
-# TODO: Blinded key creation and signing are horribly slow. 1.5 seconds each,
-# making each call to HiddenServiceDescriptorV3.create() take over three
-# seconds.
-#
-# Obviously we need to address this, but for the moment skipping the slow tests
-# don't slow branch development.
+def disable_blinding(func):
+ """
+ Blinded key creation and signing are horribly slow. 1.5 seconds each,
+ making each call to HiddenServiceDescriptorV3.create() take over three
+ seconds.
-SKIP_SLOW_TESTS = True
+ As such disabling it in most tests.
+ """
+
+ def wrapped(*args, **kwargs):
+ with patch('stem.descriptor.hidden_service._blinded_pubkey', Mock(return_value = b'k' * 32)):
+ with patch('stem.descriptor.hidden_service._blinded_sign', Mock(return_value = b'a' * 64)):
+ return func(*args, **kwargs)
+
+ return wrapped
class TestHiddenServiceDescriptorV3(unittest.TestCase):
@@ -171,15 +178,13 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase):
self.assertEqual(None, intro_point.legacy_key_raw)
self.assertEqual(None, intro_point.legacy_key_cert)
+ @disable_blinding
@test.require.ed25519_support
def test_required_fields(self):
"""
Check that we require the mandatory fields.
"""
- if SKIP_SLOW_TESTS:
- return
-
line_to_attr = {
'hs-descriptor': 'version',
'descriptor-lifetime': 'lifetime',
@@ -193,15 +198,13 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase):
desc_text = HiddenServiceDescriptorV3.content(exclude = (line,))
expect_invalid_attr_for_text(self, desc_text, line_to_attr[line], None)
+ @disable_blinding
@test.require.ed25519_support
def test_invalid_version(self):
"""
Checks that our version field expects a numeric value.
"""
- if SKIP_SLOW_TESTS:
- return
-
test_values = (
'',
'-10',
@@ -211,15 +214,13 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase):
for test_value in test_values:
expect_invalid_attr(self, {'hs-descriptor': test_value}, 'version')
+ @disable_blinding
@test.require.ed25519_support
def test_invalid_lifetime(self):
"""
Checks that our lifetime field expects a numeric value.
"""
- if SKIP_SLOW_TESTS:
- return
-
test_values = (
'',
'-10',
@@ -229,15 +230,13 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase):
for test_value in test_values:
expect_invalid_attr(self, {'descriptor-lifetime': test_value}, 'lifetime')
+ @disable_blinding
@test.require.ed25519_support
def test_invalid_revision_counter(self):
"""
Checks that our revision counter field expects a numeric value.
"""
- if SKIP_SLOW_TESTS:
- return
-
test_values = (
'',
'-10',
@@ -428,15 +427,13 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase):
self.assertEqual(1, len(inner_layer.introduction_points))
self.assertEqual('1.1.1.1', inner_layer.introduction_points[0].link_specifiers[0].address)
+ @disable_blinding
@test.require.ed25519_support
def test_descriptor_creation(self):
"""
HiddenServiceDescriptorV3 creation.
"""
- if SKIP_SLOW_TESTS:
- return
-
# minimal descriptor
self.assertTrue(HiddenServiceDescriptorV3.content().startswith('hs-descriptor 3\ndescriptor-lifetime 180\n'))
More information about the tor-commits
mailing list