Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/certbot/certbot.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'acme/tests/jws_test.py')
-rw-r--r--acme/tests/jws_test.py67
1 files changed, 67 insertions, 0 deletions
diff --git a/acme/tests/jws_test.py b/acme/tests/jws_test.py
new file mode 100644
index 000000000..e43ed55e6
--- /dev/null
+++ b/acme/tests/jws_test.py
@@ -0,0 +1,67 @@
+"""Tests for acme.jws."""
+import unittest
+
+import josepy as jose
+
+import test_util
+
+
+KEY = jose.JWKRSA.load(test_util.load_vector('rsa512_key.pem'))
+
+
+class HeaderTest(unittest.TestCase):
+ """Tests for acme.jws.Header."""
+
+ good_nonce = jose.encode_b64jose(b'foo')
+ wrong_nonce = u'F'
+ # Following just makes sure wrong_nonce is wrong
+ try:
+ jose.b64decode(wrong_nonce)
+ except (ValueError, TypeError):
+ assert True
+ else:
+ assert False # pragma: no cover
+
+ def test_nonce_decoder(self):
+ from acme.jws import Header
+ nonce_field = Header._fields['nonce']
+
+ self.assertRaises(
+ jose.DeserializationError, nonce_field.decode, self.wrong_nonce)
+ self.assertEqual(b'foo', nonce_field.decode(self.good_nonce))
+
+
+class JWSTest(unittest.TestCase):
+ """Tests for acme.jws.JWS."""
+
+ def setUp(self):
+ self.privkey = KEY
+ self.pubkey = self.privkey.public_key()
+ self.nonce = jose.b64encode(b'Nonce')
+ self.url = 'hi'
+ self.kid = 'baaaaa'
+
+ def test_kid_serialize(self):
+ from acme.jws import JWS
+ jws = JWS.sign(payload=b'foo', key=self.privkey,
+ alg=jose.RS256, nonce=self.nonce,
+ url=self.url, kid=self.kid)
+ self.assertEqual(jws.signature.combined.nonce, self.nonce)
+ self.assertEqual(jws.signature.combined.url, self.url)
+ self.assertEqual(jws.signature.combined.kid, self.kid)
+ self.assertEqual(jws.signature.combined.jwk, None)
+ # TODO: check that nonce is in protected header
+
+ self.assertEqual(jws, JWS.from_json(jws.to_json()))
+
+ def test_jwk_serialize(self):
+ from acme.jws import JWS
+ jws = JWS.sign(payload=b'foo', key=self.privkey,
+ alg=jose.RS256, nonce=self.nonce,
+ url=self.url)
+ self.assertEqual(jws.signature.combined.kid, None)
+ self.assertEqual(jws.signature.combined.jwk, self.pubkey)
+
+
+if __name__ == '__main__':
+ unittest.main() # pragma: no cover