test_complete_ui.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. #============================================================================
  2. # This file is part of Pwman3.
  3. #
  4. # Pwman3 is free software; you can redistribute it 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-2014 Oz Nahum <nahumoz@gmail.com>
  18. #============================================================================
  19. # pylint: disable=I0011
  20. import pexpect
  21. import unittest
  22. import os
  23. import shutil
  24. OLD_DB_PATH = os.path.join(os.path.dirname(__file__), 'pwman.v0.0.8.db')
  25. NEW_DB_PATH = os.path.join(os.path.dirname(__file__), 'pwman.v0.0.8-newdb.db')
  26. _db_warn = ("pwman3 detected that you are using the old database format")
  27. class Ferrum(unittest.TestCase):
  28. def clean_files(self):
  29. lfile = 'convert-test.log'
  30. with open(lfile) as l:
  31. lines = l.readlines()
  32. orig = lines[0].split(':')[-1].strip()
  33. backup = lines[1].split()[-1].strip()
  34. shutil.copy(backup, orig)
  35. # do some cleaning
  36. os.remove(lfile)
  37. os.remove('test-chg_passwd.log')
  38. os.remove(backup)
  39. def test_a_db_warning(self):
  40. "when trying to run with old db, we should see warning"
  41. lfile = 'convert-test.log'
  42. logfile = open(lfile, 'w')
  43. child = pexpect.spawn(os.path.join(os.path.dirname(__file__),
  44. '../../scripts/pwman3') +
  45. ' -d '+OLD_DB_PATH, logfile=logfile)
  46. rv = child.expect(_db_warn, timeout=5)
  47. if rv != 0:
  48. lfile.seek(0)
  49. print lfile.readlines()
  50. self.assertEqual(0, rv)
  51. def test_b_run_convert(self):
  52. "invoke pwman with -k option to convert the old data"
  53. lfile = 'convert-test.log'
  54. logfile = open(lfile, 'w')
  55. child = pexpect.spawn(os.path.join(os.path.dirname(__file__),
  56. '../../scripts/pwman3') +
  57. ' -k -e Blowfish -d '+OLD_DB_PATH,
  58. logfile=logfile)
  59. child.expect('[\s|\S]+Please enter your password:', timeout=10)
  60. self.assertEqual(6, child.sendline('12345'))
  61. rv = child.expect('pwman successfully converted the old database')
  62. self.assertEqual(0, rv)
  63. # if successfully converted, reset the converted database
  64. # todo - add test to run auto_convert
  65. def test_c_change_pass(self):
  66. lfile = 'test-chg_passwd.log'
  67. logfile = open(lfile, 'w')
  68. child = pexpect.spawn(os.path.join(os.path.dirname(__file__),
  69. '../../scripts/pwman3') +
  70. ' -e Blowfish -d '+OLD_DB_PATH, logfile=logfile)
  71. child.sendline('passwd')
  72. child.expect("Please enter your current password:")
  73. child.sendline('12345')
  74. child.sendline('foobar')
  75. child.sendline('foobar')
  76. self.clean_files()
  77. def suite():
  78. loader = unittest.TestLoader()
  79. suite = unittest.TestSuite()
  80. suite.addTest(loader.loadTestsFromTestCase(Ferrum))
  81. return suite
  82. if __name__ == '__main__':
  83. unittest.TextTestRunner(verbosity=2).run(suite())
  84. os.remove(NEW_DB_PATH)