[tor-commits] [stem/master] Test requirement annotations

atagar at torproject.org atagar at torproject.org
Sun Nov 17 23:40:39 UTC 2019


commit 632ba7f66e0174de392227e85b4be08f01626789
Author: Damian Johnson <atagar at 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
 





More information about the tor-commits mailing list