test_complete_ui.py 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  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. cmd = os.path.join(os.path.dirname(__file__), '../../scripts/pwman3'
  44. ) + ' -d '+OLD_DB_PATH
  45. child = pexpect.spawn(cmd, 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. cmd = (os.path.join(os.path.dirname(__file__), '../../scripts/pwman3'
  56. ) + ' -k -e Blowfish -d ' + OLD_DB_PATH)
  57. child = pexpect.spawn(cmd, logfile=logfile)
  58. child.expect('[\s|\S]+Please enter your password:', timeout=10)
  59. self.assertEqual(6, child.sendline('12345'))
  60. rv = child.expect('pwman successfully converted the old database')
  61. self.assertEqual(0, rv)
  62. # if successfully converted, reset the converted database
  63. # todo - add test to run auto_convert
  64. def test_c_change_pass(self):
  65. lfile = 'test-chg_passwd.log'
  66. logfile = open(lfile, 'w')
  67. child = pexpect.spawn(os.path.join(os.path.dirname(__file__),
  68. '../../scripts/pwman3') +
  69. ' -e Blowfish -d '+OLD_DB_PATH, logfile=logfile)
  70. child.sendline('passwd')
  71. child.expect("Please enter your current password:")
  72. child.sendline('12345')
  73. child.sendline('foobar')
  74. child.sendline('foobar')
  75. self.clean_files()
  76. def suite():
  77. loader = unittest.TestLoader()
  78. suite = unittest.TestSuite()
  79. suite.addTest(loader.loadTestsFromTestCase(Ferrum))
  80. return suite
  81. if __name__ == '__main__':
  82. unittest.TextTestRunner(verbosity=2).run(suite())
  83. os.remove(NEW_DB_PATH)