12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- import os
- import unittest
- from pwman.data.drivers.sqlite import SQLite
- from pwman.data.nodes import Node
- from pwman.util.crypto_engine import CryptoEngine
- class TestSQLite(unittest.TestCase):
- def setUp(self):
- self.db = SQLite('test.db')
- self.db._open()
- def test_1_create_tables(self):
- self.db._create_tables()
- self.db._con.commit()
-
- self.db.save_crypto_info("foo", "bar")
- self.db._create_tables()
- def test_1a_create_tables(self):
- self.db._create_tables()
- def test_2_crypto_info(self):
- self.db._create_tables()
- self.db.save_crypto_info("foo", "bar")
- f = self.db.fetch_crypto_info()
- self.assertListEqual([u'foo', u'bar'], list(f))
- def test_3_add_node(self):
- node = Node(clear_text=True,
- **{'username': u"alice", 'password': u"secret",
- 'url': u"wonderland.com",
- 'notes': u"a really great place",
- 'tags': [u'foo', u'bar']})
- self.db.add_node(node)
- rv = self.db._cur.execute("select * from node")
-
-
- ce = CryptoEngine.get()
- res = rv.fetchone()
- self.assertIn(ce.encrypt(u'alice'), res[1])
- def test_4_test_tags(self):
- node = Node(clear_text=True,
- **{'username': u"alice", 'password': u"secret",
- 'url': u"wonderland.com",
- 'notes': u"a really great place",
- 'tags': [u'foo', u'bar']})
- ce = CryptoEngine.get()
- self.db._get_or_create_tag(node._tags[0])
- self.assertEqual(1, self.db._get_or_create_tag(node._tags[0]))
- self.assertEqual(3, self.db._get_or_create_tag(ce.encrypt('baz')))
- def tearDown(self):
- self.db.close()
- if __name__ == '__main__':
- try:
- unittest.main(verbosity=2)
- except SystemExit:
- os.remove('test.db')
|