diff options
author | Kali Kaneko <kali@leap.se> | 2014-10-09 17:35:15 +0200 |
---|---|---|
committer | Kali Kaneko <kali@leap.se> | 2014-10-09 17:35:15 +0200 |
commit | 55b6d38c14fd5fbbc2a56e4edec7a8715cc3253d (patch) | |
tree | 0918cb5bc1d35170ea57685ecd7ee45af4248297 /src | |
parent | 613e59c5a34e99e669e727caff00e1516369e3d0 (diff) | |
parent | 13eafd0ad9a34581f37f5c0adde4ab59d13f0b85 (diff) |
Merge remote-tracking branch 'meskio/feature/put_key_ascii' into develop
Diffstat (limited to 'src')
-rw-r--r-- | src/leap/keymanager/__init__.py | 9 | ||||
-rw-r--r-- | src/leap/keymanager/tests/test_keymanager.py | 11 |
2 files changed, 17 insertions, 3 deletions
diff --git a/src/leap/keymanager/__init__.py b/src/leap/keymanager/__init__.py index bd85c2d..da679ac 100644 --- a/src/leap/keymanager/__init__.py +++ b/src/leap/keymanager/__init__.py @@ -515,11 +515,14 @@ class KeyManager(object): """ Put C{key} in local storage. - :param key: The key to be stored. - :type key: OpenPGPKey + :param key: The key to be stored. It can be ascii key or an OpenPGPKey + :type key: str or OpenPGPKey """ try: - self._wrapper_map[type(key)].put_key(key) + if isinstance(key, basestring): + self._wrapper_map[OpenPGPKey].put_ascii_key(key) + else: + self._wrapper_map[type(key)].put_key(key) except IndexError as e: leap_assert(False, "Unsupported key type. Error {0!r}".format(e)) diff --git a/src/leap/keymanager/tests/test_keymanager.py b/src/leap/keymanager/tests/test_keymanager.py index 7192bfb..39b729d 100644 --- a/src/leap/keymanager/tests/test_keymanager.py +++ b/src/leap/keymanager/tests/test_keymanager.py @@ -466,6 +466,17 @@ class KeyManagerKeyManagementTestCase(KeyManagerWithSoledadTestCase): self.assertIsInstance(key, OpenPGPKey) self.assertEqual(ADDRESS, key.address) + def test_put_key_ascii(self): + """ + Test that putting ascii key works + """ + km = self._key_manager(url='http://nickserver.domain') + + km.put_key(PUBLIC_KEY) + key = km.get_key(ADDRESS, OpenPGPKey) + self.assertIsInstance(key, OpenPGPKey) + self.assertEqual(ADDRESS, key.address) + class KeyManagerCryptoTestCase(KeyManagerWithSoledadTestCase): |