test_importer.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. # ============================================================================
  2. # This file is part of Pwman3.
  3. #
  4. # Pwman3 is free software; you can redistribute iut and/or modify
  5. # it under the terms of the GNU General Public License, version 2
  6. # as published by the Free Software Foundation;
  7. #
  8. # Pwman3 is distributed in the hope that it will be useful,
  9. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. # GNU General Public License for more details.
  12. #
  13. # You should have received a copy of the GNU General Public License
  14. # along with Pwman3; if not, write to the Free Software
  15. # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  16. # ============================================================================
  17. # Copyright (C) 2012, 2013, 2014 Oz Nahum Tiram <nahumoz@gmail.com>
  18. # ============================================================================
  19. import os
  20. import unittest
  21. from collections import namedtuple
  22. import pwman.data.factory
  23. from pwman.util.crypto_engine import CryptoEngine
  24. from pwman.exchange.importer import CSVImporter, Importer
  25. from pwman.data.drivers.sqlite import SQLite
  26. from .test_crypto_engine import give_key, DummyCallback
  27. import_example = """
  28. Username;URL;Password;Notes;Tags
  29. alice;wonderland.com;secert;scratch;foo,bar
  30. hatman;behindthemirror.com;pa33w0rd;scratch;foo,bar
  31. """
  32. class TestImporter(unittest.TestCase):
  33. @classmethod
  34. def setUpClass(cls):
  35. f = open('import_file.csv', 'w')
  36. f.write(import_example)
  37. f.close()
  38. @classmethod
  39. def tearDownClass(cls):
  40. for item in ('import_file.csv', 'test-importer.db',
  41. 'testfile.conf', 'importdummy.db'):
  42. try:
  43. os.unlink(item)
  44. except OSError:
  45. continue
  46. def setUp(self):
  47. config = {}
  48. db = SQLite('test-importer.db')
  49. Args = namedtuple('args', 'file_delim')
  50. args = Args(file_delim=['import_file.csv', ';'])
  51. self.importer = CSVImporter(args,
  52. config, db)
  53. def test_1_read_file(self):
  54. lines = self.importer._read_file()
  55. self.assertNotIn(["Username", "URL", "Password", "Notes", " Tags"],
  56. lines)
  57. def test_2_create_node(self):
  58. # create a node , should be encrypted, but not yet inserted to db
  59. n = "alice;wonderland.com;secert;scratch;foo,bar".split(";")
  60. node = self.importer._create_node(n)
  61. ce = CryptoEngine.get()
  62. self.assertEqual(ce.decrypt(node._username).decode(), u'alice')
  63. self.assertEqual([b'foo', b'bar'], [t for t in node.tags])
  64. def test_3_insert_node(self):
  65. self.importer._open_db()
  66. n = "alice;wonderland.com;secert;scratch;foo,bar".split(";")
  67. node = self.importer._create_node(n)
  68. # do the actual insert of the node to the databse
  69. self.importer._insert_node(node)
  70. def test_4_runner(self):
  71. # test the whole procees:
  72. """
  73. open csv
  74. open db
  75. for line in csv:
  76. create node
  77. insert node
  78. close db
  79. """
  80. # args need import_file , db,
  81. Args = namedtuple('Args', 'file_delim, db')
  82. if os.path.exists('importdummy.db'):
  83. os.unlink('importdummy.db')
  84. args = Args(file_delim=['import_file.csv', ';'], db='importdummy.db')
  85. db = pwman.data.factory.createdb('sqlite:///' + os.getcwd() +
  86. '/importdummy.db', 0.6)
  87. importer = Importer((args, '', db))
  88. importer.importer.run(callback=DummyCallback)
  89. if __name__ == '__main__':
  90. ce = CryptoEngine.get()
  91. ce.callback = DummyCallback()
  92. ce.changepassword(reader=give_key)
  93. unittest.main(verbosity=2, failfast=True)