test_crypto_engine.py 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. import unittest
  2. import os
  3. import time
  4. import string
  5. from pwman.util.callback import Callback
  6. from pwman.util.crypto_engine import (CryptoEngine, CryptoException,
  7. generate_password)
  8. # set cls_timout to negative number (e.g. -1) to disable
  9. default_config = {'Global': {'umask': '0100', 'colors': 'yes',
  10. 'cls_timeout': '5'
  11. },
  12. 'Database': {'type': 'SQLite',
  13. 'filename': os.path.join("tests", "pwman.db")},
  14. 'Encryption': {'algorithm': 'AES'},
  15. 'Readline': {'history': os.path.join("tests",
  16. "history")}
  17. }
  18. #config.set_defaults(default_config)
  19. give_key = lambda msg: "12345"
  20. give_wrong_key = lambda msg: "verywrongtkey"
  21. salt = b'cUDHNMJdTRxiIDPXuT163UMvi4fd2pXz/bRg2Zm8ajE='
  22. digest = b'9eaec7dc1ee647338406739c54dbf9c4881c74702008eb978622811cfc46a07f'
  23. class DummyCallback(Callback):
  24. def getinput(self, question):
  25. return u'12345'
  26. def getsecret(self, question):
  27. return u'12345'
  28. def getnewsecret(self, question):
  29. return u'12345'
  30. class TestPassGenerator(unittest.TestCase):
  31. def test_len(self):
  32. self.assertEqual(13, len(generate_password(pass_len=13)))
  33. def test_has_upper(self):
  34. password = generate_password(uppercase=True, lowercase=False)
  35. lower = set(string.ascii_lowercase)
  36. it = lower.intersection(set(password))
  37. print(it)
  38. self.assertTrue(len(it) == 0)
  39. def test_has_digits(self):
  40. password = generate_password(uppercase=True, lowercase=False)
  41. digits = set(string.digits)
  42. it = digits.intersection(password)
  43. print(it)
  44. try:
  45. self.assertTrue(len(it) >= 0)
  46. except unittest.AssetionError:
  47. print(it)
  48. def test_has_no_digits(self):
  49. password = generate_password(uppercase=True, digits=False,
  50. lowercase=False)
  51. digits = set(string.digits)
  52. it = digits.intersection(password)
  53. print(it)
  54. try:
  55. self.assertTrue(len(it) == 0)
  56. except unittest.AssetionError:
  57. print(it)
  58. class CryptoEngineTest(unittest.TestCase):
  59. def test4_d_get_crypto(self):
  60. ce = CryptoEngine.get()
  61. ce.callback = DummyCallback()
  62. secret2 = ce.changepassword(reader=give_key)
  63. secret1 = ce.changepassword(reader=give_key)
  64. # althouth the same secret key is used,
  65. # the secret hash is not the same, because a
  66. # different random seed is used when calling
  67. # CryptoEngine._get_digest
  68. self.assertNotEqual(secret1, secret2)
  69. def test5_e_authenticate(self):
  70. ce = CryptoEngine.get()
  71. ce._reader = give_key
  72. self.assertFalse(ce.authenticate('verywrong'))
  73. self.assertTrue(ce.authenticate('12345'))
  74. ce._timeout = -1
  75. self.assertTrue(ce._is_authenticated())
  76. def test6_is_timedout(self):
  77. ce = CryptoEngine.get()
  78. ce._timeout = 1
  79. time.sleep(1.1)
  80. self.assertTrue(ce._is_timedout())
  81. self.assertIsNone(ce._cipher)
  82. self.assertFalse(ce._is_authenticated())
  83. def test_f_encrypt_decrypt(self):
  84. ce = CryptoEngine.get()
  85. ce._reader = give_key
  86. if not ce._salt:
  87. ce._salt = salt
  88. secret = ce.encrypt("topsecret")
  89. decrypt = ce.decrypt(secret)
  90. self.assertEqual(decrypt.decode(), "topsecret")
  91. ce._cipher = None
  92. secret = ce.encrypt("topsecret")
  93. decrypt = ce.decrypt(secret)
  94. self.assertEqual(decrypt.decode(), "topsecret")
  95. def test_g_encrypt_decrypt_wrong_pass(self):
  96. ce = CryptoEngine.get()
  97. ce._cipher = None
  98. ce._getsecret = give_wrong_key
  99. self.assertRaises(CryptoException, ce.encrypt, "secret")
  100. ce._getsecret = lambda x: u'12345'
  101. secret = ce.encrypt(u"topsecret")
  102. decrypt = ce.decrypt(secret)
  103. self.assertEqual(decrypt.decode(), "topsecret")
  104. if __name__ == '__main__':
  105. unittest.main(verbosity=2, failfast=True)