Commit cac1377a authored by Jérome Perrin's avatar Jérome Perrin

testAuthenticationPolicy: don't use reference on persons

This may hide problems with code still expecting that person's reference
is same as login. I did not find such problematic code, but I thought
that it would be better anyway.
parent a0c2b666
No related merge requests found
...@@ -66,8 +66,9 @@ class TestAuthenticationPolicy(ERP5TypeTestCase): ...@@ -66,8 +66,9 @@ class TestAuthenticationPolicy(ERP5TypeTestCase):
uf = portal.acl_users uf = portal.acl_users
uf._doAddUser(self.manager_username, self.manager_password, ['Manager'], []) uf._doAddUser(self.manager_username, self.manager_password, ['Manager'], [])
self.loginByUserName(self.manager_username) self.loginByUserName(self.manager_username)
kw = dict(portal_type='Person',
reference = 'test') kw = dict(portal_type='ERP5 Login',
reference='test')
if portal.portal_catalog.getResultValue(**kw) is None: if portal.portal_catalog.getResultValue(**kw) is None:
# add a loggable Person # add a loggable Person
person = self.createUser( person = self.createUser(
...@@ -80,7 +81,6 @@ class TestAuthenticationPolicy(ERP5TypeTestCase): ...@@ -80,7 +81,6 @@ class TestAuthenticationPolicy(ERP5TypeTestCase):
assignment = person.newContent(portal_type = 'Assignment') assignment = person.newContent(portal_type = 'Assignment')
assignment.open() assignment.open()
# Reset and Setup auth policy # Reset and Setup auth policy
old_preference = portal.portal_catalog.getResultValue( old_preference = portal.portal_catalog.getResultValue(
portal_type='System Preference', portal_type='System Preference',
...@@ -114,19 +114,21 @@ class TestAuthenticationPolicy(ERP5TypeTestCase): ...@@ -114,19 +114,21 @@ class TestAuthenticationPolicy(ERP5TypeTestCase):
self.portal.system_event_module.manage_delObjects([x.getId() for x in self._getPasswordEventList(login)]) self.portal.system_event_module.manage_delObjects([x.getId() for x in self._getPasswordEventList(login)])
def createUser(self, reference, password=None, person_kw=None): def createUser(self, username, password=None, person_kw=None):
""" """
Modified version from ERP5TypeTestCase, that does set reference as Modified version from ERP5TypeTestCase, that does not set reference as
password when password is None. password when password is None and does not set the same reference on
person, so that we can reveal problems with code assuming that person's
reference is same as login, which use to be true before ERP5 Login were
introduced.
""" """
if person_kw is None: if person_kw is None:
person_kw = {} person_kw = {}
self.createUser
person = self.portal.person_module.newContent(portal_type='Person', person = self.portal.person_module.newContent(
reference=reference, portal_type='Person', **person_kw)
**person_kw)
login = person.newContent(portal_type='ERP5 Login', login = person.newContent(portal_type='ERP5 Login',
reference=reference, reference=username,
password=password) password=password)
login.validate() login.validate()
return person return person
...@@ -138,9 +140,10 @@ class TestAuthenticationPolicy(ERP5TypeTestCase): ...@@ -138,9 +140,10 @@ class TestAuthenticationPolicy(ERP5TypeTestCase):
portal = self.getPortal() portal = self.getPortal()
self.assertTrue(portal.portal_preferences.isAuthenticationPolicyEnabled()) self.assertTrue(portal.portal_preferences.isAuthenticationPolicyEnabled())
person = portal.portal_catalog.getResultValue(portal_type = 'Person', login = portal.portal_catalog.getResultValue(
reference = 'test') portal_type='ERP5 Login',
login = person.objectValues(portal_type='ERP5 Login')[0] reference='test')
self.assertIsNotNone(login)
preference = portal.portal_catalog.getResultValue(portal_type = 'System Preference', preference = portal.portal_catalog.getResultValue(portal_type = 'System Preference',
title = 'Authentication',) title = 'Authentication',)
# login should be allowed # login should be allowed
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment