commit 632ba7f66e0174de392227e85b4be08f01626789 Author: Damian Johnson atagar@torproject.org Date: Sun Oct 20 14:55:10 2019 -0700
Test requirement annotations
Oops, forgot that we have these test requirement annotations. --- test/require.py | 1 + test/unit/descriptor/hidden_service_v3.py | 41 +++++++++++-------------------- 2 files changed, 15 insertions(+), 27 deletions(-)
diff --git a/test/require.py b/test/require.py index af33359f..ca5fe3ea 100644 --- a/test/require.py +++ b/test/require.py @@ -12,6 +12,7 @@ run. |- needs - skips the test unless a requirement is met | |- cryptography - skips test unless the cryptography module is present + |- ed25519_support - skips test unless cryptography has ed25519 support |- command - requires a command to be on the path |- proc - requires the platform to have recognized /proc contents | diff --git a/test/unit/descriptor/hidden_service_v3.py b/test/unit/descriptor/hidden_service_v3.py index 499064f9..203cd3c3 100644 --- a/test/unit/descriptor/hidden_service_v3.py +++ b/test/unit/descriptor/hidden_service_v3.py @@ -11,6 +11,8 @@ import stem.client.datatype import stem.descriptor import stem.prereq
+import test.require + from stem.descriptor.hidden_service import ( CHECKSUM_CONSTANT, REQUIRED_V3_FIELDS, @@ -29,9 +31,12 @@ from test.unit.descriptor import (
try: # added in python 3.3 - from unittest.mock import patch, Mock, MagicMock + from unittest.mock import patch, Mock except ImportError: - from mock import patch, Mock, MagicMock + from mock import patch, Mock + +require_sha3 = test.require.needs(stem.prereq._is_sha3_available, 'requires sha3') +require_x25519 = test.require.needs(lambda: X25519_AVAILABLE, 'requires openssl x5509')
expect_invalid_attr = functools.partial(base_expect_invalid_attr, HiddenServiceDescriptorV3, 'version', 3) expect_invalid_attr_for_text = functools.partial(base_expect_invalid_attr_for_text, HiddenServiceDescriptorV3, 'version', 3) @@ -127,18 +132,13 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase): self.assertTrue('eaH8VdaTKS' in desc.superencrypted) self.assertEqual('aglChCQF+lbzKgyxJJTpYGVShV/GMDRJ4+cRGCp+a2y/yX/tLSh7hzqI7rVZrUoGj74Xr1CLMYO3fXYCS+DPDQ', desc.signature)
+ @require_sha3 + @test.require.ed25519_support def test_decryption(self): """ Decrypt our descriptor and validate its content. """
- if not stem.prereq.is_crypto_available(ed25519 = True): - self.skipTest('(requires cryptography ed25519 support)') - return - elif not stem.prereq._is_sha3_available(): - self.skipTest('(requires sha3 support)') - return - desc = HiddenServiceDescriptorV3.from_str(HS_DESC_STR) inner_layer = desc.decrypt(HS_ADDRESS)
@@ -259,30 +259,20 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase): for test_value in test_values: expect_invalid_attr(self, {'revision-counter': test_value}, 'revision_counter')
+ @require_sha3 + @test.require.ed25519_support def test_public_key_from_address(self): - if not stem.prereq.is_crypto_available(ed25519 = True): - self.skipTest('(requires cryptography ed25519 support)') - return - elif not stem.prereq._is_sha3_available(): - self.skipTest('(requires sha3 support)') - return - self.assertEqual(b'\x92\xe6\x80\xfaWU.}HL\x9d*>\xdbF\xfb\xc0v\xe5N\xa9\x0bw\xbb\x84\xe3\xe6\xd5e}R\xa1', HiddenServiceDescriptorV3._public_key_from_address(HS_ADDRESS)) self.assertRaisesWith(ValueError, "'boom.onion' isn't a valid hidden service v3 address", HiddenServiceDescriptorV3._public_key_from_address, 'boom') self.assertRaisesWith(ValueError, 'Bad checksum (expected def7 but was 842e)', HiddenServiceDescriptorV3._public_key_from_address, '5' * 56)
+ @require_x25519 + @test.require.ed25519_support def test_intro_point_crypto(self): """ Retrieve IntroductionPointV3 cryptographic materials. """
- if not stem.prereq.is_crypto_available(): - self.skipTest('(requires cryptography support)') - return - elif not X25519_AVAILABLE: - self.skipTest('(openssl requires X25519 support)') - return - from cryptography.hazmat.backends.openssl.x25519 import X25519PublicKey from cryptography.hazmat.primitives import serialization
@@ -316,6 +306,7 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase): intro_point = InnerLayer(INNER_LAYER_STR).introduction_points[0] self.assertRaisesWith(ImportError, 'cryptography module unavailable', intro_point.onion_key)
+ @test.require.ed25519_support def test_encode_decode_descriptor(self): """ Encode an HSv3 descriptor and then decode it and make sure you get the intended results. @@ -325,10 +316,6 @@ class TestHiddenServiceDescriptorV3(unittest.TestCase): making onion service descriptors. """
- if not stem.prereq.is_crypto_available(ed25519 = True): - self.skipTest('(requires cryptography ed25519 support)') - return - from cryptography.hazmat.primitives.asymmetric.ed25519 import Ed25519PublicKey, Ed25519PrivateKey from cryptography.hazmat.primitives import serialization