123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- # -*- coding: utf-8 -*-
- # Copyright 2015 LasLabs Inc.
- # License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl.html).
- import time
- from openerp.tests.common import TransactionCase
- from ..exceptions import PassError
- class TestResUsers(TransactionCase):
- def setUp(self):
- super(TestResUsers, self).setUp()
- self.login = 'foslabs@example.com'
- self.partner_vals = {
- 'name': 'Partner',
- 'is_company': False,
- 'email': self.login,
- }
- self.password = 'asdQWE123$%^'
- self.main_comp = self.env.ref('base.main_company')
- self.vals = {
- 'name': 'User',
- 'login': self.login,
- 'password': self.password,
- 'company_id': self.main_comp.id
- }
- self.model_obj = self.env['res.users']
- def _new_record(self):
- partner_id = self.env['res.partner'].create(self.partner_vals)
- self.vals['partner_id'] = partner_id.id
- return self.model_obj.create(self.vals)
- def test_password_write_date_is_saved_on_create(self):
- rec_id = self._new_record()
- self.assertTrue(
- rec_id.password_write_date,
- 'Password write date was not saved to db.',
- )
- def test_password_write_date_is_updated_on_write(self):
- rec_id = self._new_record()
- old_write_date = rec_id.password_write_date
- time.sleep(2)
- rec_id.write({'password': 'asdQWE123$%^2'})
- rec_id.refresh()
- new_write_date = rec_id.password_write_date
- self.assertNotEqual(
- old_write_date, new_write_date,
- 'Password write date was not updated on write.',
- )
- def test_does_not_update_write_date_if_password_unchanged(self):
- rec_id = self._new_record()
- old_write_date = rec_id.password_write_date
- time.sleep(2)
- rec_id.write({'name': 'Luser'})
- rec_id.refresh()
- new_write_date = rec_id.password_write_date
- self.assertEqual(
- old_write_date, new_write_date,
- 'Password not changed but write date updated anyway.',
- )
- def test_check_password_returns_true_for_valid_password(self):
- rec_id = self._new_record()
- self.assertTrue(
- rec_id.check_password('asdQWE123$%^3'),
- 'Password is valid but check failed.',
- )
- def test_check_password_raises_error_for_invalid_password(self):
- rec_id = self._new_record()
- with self.assertRaises(PassError):
- rec_id.check_password('password')
- def test_save_password_crypt(self):
- rec_id = self._new_record()
- self.assertEqual(
- 1, len(rec_id.password_history_ids),
- )
- def test_check_password_crypt(self):
- """ It should raise PassError if previously used """
- rec_id = self._new_record()
- with self.assertRaises(PassError):
- rec_id.write({'password': self.password})
- def test_password_is_expired_if_record_has_no_write_date(self):
- rec_id = self._new_record()
- rec_id.write({'password_write_date': None})
- rec_id.refresh()
- self.assertTrue(
- rec_id._password_has_expired(),
- 'Record has no password write date but check failed.',
- )
- def test_an_old_password_is_expired(self):
- rec_id = self._new_record()
- old_write_date = '1970-01-01 00:00:00'
- rec_id.write({'password_write_date': old_write_date})
- rec_id.refresh()
- self.assertTrue(
- rec_id._password_has_expired(),
- 'Password is out of date but check failed.',
- )
- def test_a_new_password_is_not_expired(self):
- rec_id = self._new_record()
- self.assertFalse(
- rec_id._password_has_expired(),
- 'Password was just created but has already expired.',
- )
- def test_expire_password_generates_token(self):
- rec_id = self._new_record()
- rec_id.sudo().action_expire_password()
- rec_id.refresh()
- token = rec_id.partner_id.signup_token
- self.assertTrue(
- token,
- 'A token was not generated.',
- )
- def test_validate_pass_reset_error(self):
- """ It should throw PassError on reset inside min threshold """
- rec_id = self._new_record()
- with self.assertRaises(PassError):
- rec_id._validate_pass_reset()
- def test_validate_pass_reset_allow(self):
- """ It should allow reset pass when outside threshold """
- rec_id = self._new_record()
- rec_id.password_write_date = '2016-01-01'
- self.assertEqual(
- True, rec_id._validate_pass_reset(),
- )
- def test_validate_pass_reset_zero(self):
- """ It should allow reset pass when <= 0 """
- rec_id = self._new_record()
- rec_id.company_id.password_minimum = 0
- self.assertEqual(
- True, rec_id._validate_pass_reset(),
- )
|