mirror of
https://github.com/certbot/certbot.git
synced 2026-01-21 19:01:07 +03:00
Conflicts: letsencrypt/continuity_auth.py letsencrypt_nginx/configurator.py letsencrypt_nginx/dvsni.py letsencrypt_nginx/tests/configurator_test.py letsencrypt_nginx/tests/dvsni_test.py
105 lines
3.5 KiB
Python
105 lines
3.5 KiB
Python
"""Test the ContinuityAuthenticator dispatcher."""
|
|
import unittest
|
|
|
|
import mock
|
|
|
|
from acme import challenges
|
|
|
|
from letsencrypt import achallenges
|
|
from letsencrypt import errors
|
|
|
|
|
|
class PerformTest(unittest.TestCase):
|
|
"""Test client perform function."""
|
|
|
|
def setUp(self):
|
|
from letsencrypt.continuity_auth import ContinuityAuthenticator
|
|
|
|
self.auth = ContinuityAuthenticator(
|
|
mock.MagicMock(server="demo_server.org"), None)
|
|
self.auth.rec_token.perform = mock.MagicMock(
|
|
name="rec_token_perform", side_effect=gen_client_resp)
|
|
self.auth.proof_of_pos.perform = mock.MagicMock(
|
|
name="proof_of_pos_perform", side_effect=gen_client_resp)
|
|
|
|
def test_rec_token1(self):
|
|
token = achallenges.RecoveryToken(challb=None, domain="0")
|
|
responses = self.auth.perform([token])
|
|
self.assertEqual(responses, ["RecoveryToken0"])
|
|
|
|
def test_rec_token5(self):
|
|
tokens = []
|
|
for i in xrange(5):
|
|
tokens.append(achallenges.RecoveryToken(challb=None, domain=str(i)))
|
|
|
|
responses = self.auth.perform(tokens)
|
|
|
|
self.assertEqual(len(responses), 5)
|
|
for i in xrange(5):
|
|
self.assertEqual(responses[i], "RecoveryToken%d" % i)
|
|
|
|
def test_pop_and_rec_token(self):
|
|
achalls = []
|
|
for i in xrange(4):
|
|
if i % 2 == 0:
|
|
achalls.append(achallenges.RecoveryToken(challb=None,
|
|
domain=str(i)))
|
|
else:
|
|
achalls.append(achallenges.ProofOfPossession(challb=None,
|
|
domain=str(i)))
|
|
responses = self.auth.perform(achalls)
|
|
|
|
self.assertEqual(len(responses), 4)
|
|
for i in xrange(4):
|
|
if i % 2 == 0:
|
|
self.assertEqual(responses[i], "RecoveryToken%d" % i)
|
|
else:
|
|
self.assertEqual(responses[i], "ProofOfPossession%d" % i)
|
|
|
|
def test_unexpected(self):
|
|
self.assertRaises(
|
|
errors.LetsEncryptContAuthError, self.auth.perform, [
|
|
achallenges.DVSNI(challb=None, domain="0", key="invalid_key")])
|
|
|
|
def test_chall_pref(self):
|
|
self.assertEqual(
|
|
self.auth.get_chall_pref("example.com"),
|
|
[challenges.ProofOfPossession, challenges.RecoveryToken])
|
|
|
|
|
|
class CleanupTest(unittest.TestCase):
|
|
"""Test the Authenticator cleanup function."""
|
|
|
|
def setUp(self):
|
|
from letsencrypt.continuity_auth import ContinuityAuthenticator
|
|
|
|
self.auth = ContinuityAuthenticator(
|
|
mock.MagicMock(server="demo_server.org"), None)
|
|
self.mock_cleanup = mock.MagicMock(name="rec_token_cleanup")
|
|
self.auth.rec_token.cleanup = self.mock_cleanup
|
|
|
|
def test_rec_token2(self):
|
|
token1 = achallenges.RecoveryToken(challb=None, domain="0")
|
|
token2 = achallenges.RecoveryToken(challb=None, domain="1")
|
|
|
|
self.auth.cleanup([token1, token2])
|
|
|
|
self.assertEqual(self.mock_cleanup.call_args_list,
|
|
[mock.call(token1), mock.call(token2)])
|
|
|
|
def test_unexpected(self):
|
|
token = achallenges.RecoveryToken(challb=None, domain="0")
|
|
unexpected = achallenges.DVSNI(challb=None, domain="0", key="dummy_key")
|
|
|
|
self.assertRaises(errors.LetsEncryptContAuthError,
|
|
self.auth.cleanup, [token, unexpected])
|
|
|
|
|
|
def gen_client_resp(chall):
|
|
"""Generate a dummy response."""
|
|
return "%s%s" % (chall.__class__.__name__, chall.domain)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main() # pragma: no cover
|