test_crypto_engine.py 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. import unittest
  2. import pwman.util.config as config
  3. import os
  4. from pwman.util.crypto_engine import (write_password, save_a_secret_message,
  5. read_a_secret_message,
  6. CryptoEngine, CryptoException)
  7. import time
  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: "verysecretkey"
  20. give_wrong_key = lambda msg: "verywrongtkey"
  21. class CryptoEngineTest(unittest.TestCase):
  22. def test1_a_write_password(self):
  23. write_password(reader=give_key)
  24. def test2_b_save_secret(self):
  25. save_a_secret_message(reader=give_key)
  26. def test3_c_read_secret(self):
  27. read_a_secret_message(reader=give_key)
  28. def test4_d_get_crypto(self):
  29. ce = CryptoEngine.get()
  30. secret2 = ce.changepassword(reader=give_key)
  31. secret1 = ce.changepassword(reader=give_key)
  32. # althouth the same secret key is used,
  33. # the secret hash is not the same, because a
  34. # different random seed is used when calling
  35. # CryptoEngine._get_digest
  36. self.assertNotEqual(secret1, secret2)
  37. def test5_e_authenticate(self):
  38. ce = CryptoEngine.get()
  39. self.assertFalse(ce.authenticate('verywrong'))
  40. self.assertTrue(ce.authenticate('verysecretkey'))
  41. ce._timeout = -1
  42. self.assertTrue(ce._is_authenticated())
  43. def test6_hhh_is_timedout(self):
  44. ce = CryptoEngine.get()
  45. ce._timeout = 1
  46. time.sleep(1.1)
  47. self.assertTrue(ce._is_timedout())
  48. self.assertIsNone(ce._cipher)
  49. self.assertFalse(ce._is_authenticated())
  50. def test_f_encrypt_decrypt(self):
  51. ce = CryptoEngine.get()
  52. ce._reader = give_key
  53. secret = ce.encrypt("topsecret")
  54. decrypt = ce.decrypt(secret)
  55. self.assertEqual(decrypt, "topsecret")
  56. ce._cipher = None
  57. secret = ce.encrypt("topsecret")
  58. decrypt = ce.decrypt(secret)
  59. self.assertEqual(decrypt, "topsecret")
  60. def test_g_encrypt_decrypt_wrong_pass(self):
  61. ce = CryptoEngine.get()
  62. ce._cipher = None
  63. ce._reader = give_wrong_key
  64. self.assertRaises(CryptoException, ce.encrypt, "secret")
  65. ce._reader = give_key
  66. secret = ce.encrypt("topsecret")
  67. decrypt = ce.decrypt(secret)
  68. self.assertEqual(decrypt, "topsecret")