Merge "Enable settings/change password on keystone v3"
This commit is contained in:
commit
ea1a39d173
@ -396,11 +396,11 @@ def user_update_password(request, user, password, admin=True):
|
|||||||
|
|
||||||
def user_update_own_password(request, origpassword, password):
|
def user_update_own_password(request, origpassword, password):
|
||||||
client = keystoneclient(request, admin=False)
|
client = keystoneclient(request, admin=False)
|
||||||
if VERSIONS.active < 3:
|
|
||||||
client.user_id = request.user.id
|
client.user_id = request.user.id
|
||||||
|
if VERSIONS.active < 3:
|
||||||
return client.users.update_own_password(origpassword, password)
|
return client.users.update_own_password(origpassword, password)
|
||||||
else:
|
else:
|
||||||
return client.users.update(request.user.id, password=password)
|
return client.users.update_password(origpassword, password)
|
||||||
|
|
||||||
|
|
||||||
def user_update_tenant(request, user, project, admin=True):
|
def user_update_tenant(request, user, project, admin=True):
|
||||||
|
@ -18,7 +18,6 @@ from django.utils.translation import ugettext_lazy as _
|
|||||||
|
|
||||||
import horizon
|
import horizon
|
||||||
|
|
||||||
from openstack_dashboard.api import keystone
|
|
||||||
from openstack_dashboard.dashboards.settings import dashboard
|
from openstack_dashboard.dashboards.settings import dashboard
|
||||||
|
|
||||||
|
|
||||||
@ -26,7 +25,5 @@ class PasswordPanel(horizon.Panel):
|
|||||||
name = _("Change Password")
|
name = _("Change Password")
|
||||||
slug = 'password'
|
slug = 'password'
|
||||||
|
|
||||||
# TODO(mrunge): remove restriction, when keystone v3 has a update own user
|
|
||||||
# function and checks passwords properly.
|
dashboard.Settings.register(PasswordPanel)
|
||||||
if keystone.VERSIONS.active == 2:
|
|
||||||
dashboard.Settings.register(PasswordPanel)
|
|
||||||
|
@ -23,19 +23,14 @@ from mox import IsA # noqa
|
|||||||
from openstack_dashboard import api
|
from openstack_dashboard import api
|
||||||
from openstack_dashboard.test import helpers as test
|
from openstack_dashboard.test import helpers as test
|
||||||
|
|
||||||
# TODO(mrunge): remove, when keystone v3 supports
|
|
||||||
# change_own_password, incl. password validation
|
INDEX_URL = reverse('horizon:settings:password:index')
|
||||||
kver = api.keystone.VERSIONS.active
|
|
||||||
if kver == 2:
|
|
||||||
INDEX_URL = reverse('horizon:settings:password:index')
|
|
||||||
|
|
||||||
|
|
||||||
class ChangePasswordTests(test.TestCase):
|
class ChangePasswordTests(test.TestCase):
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('user_update_own_password', )})
|
@test.create_stubs({api.keystone: ('user_update_own_password', )})
|
||||||
def test_change_password(self):
|
def test_change_password(self):
|
||||||
if kver == 3:
|
|
||||||
self.skipTest('Password change in keystone v3 unsupported')
|
|
||||||
api.keystone.user_update_own_password(IsA(http.HttpRequest),
|
api.keystone.user_update_own_password(IsA(http.HttpRequest),
|
||||||
'oldpwd',
|
'oldpwd',
|
||||||
'normalpwd',).AndReturn(None)
|
'normalpwd',).AndReturn(None)
|
||||||
@ -50,8 +45,6 @@ class ChangePasswordTests(test.TestCase):
|
|||||||
self.assertNoFormErrors(res)
|
self.assertNoFormErrors(res)
|
||||||
|
|
||||||
def test_change_validation_passwords_not_matching(self):
|
def test_change_validation_passwords_not_matching(self):
|
||||||
if kver == 3:
|
|
||||||
self.skipTest('Password change in keystone v3 unsupported')
|
|
||||||
formData = {'method': 'PasswordForm',
|
formData = {'method': 'PasswordForm',
|
||||||
'current_password': 'currpasswd',
|
'current_password': 'currpasswd',
|
||||||
'new_password': 'testpassword',
|
'new_password': 'testpassword',
|
||||||
@ -62,8 +55,6 @@ class ChangePasswordTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.keystone: ('user_update_own_password', )})
|
@test.create_stubs({api.keystone: ('user_update_own_password', )})
|
||||||
def test_change_password_shows_message_on_login_page(self):
|
def test_change_password_shows_message_on_login_page(self):
|
||||||
if kver == 3:
|
|
||||||
self.skipTest('Password change in keystone v3 unsupported')
|
|
||||||
api.keystone.user_update_own_password(IsA(http.HttpRequest),
|
api.keystone.user_update_own_password(IsA(http.HttpRequest),
|
||||||
'oldpwd',
|
'oldpwd',
|
||||||
'normalpwd').AndReturn(None)
|
'normalpwd').AndReturn(None)
|
||||||
@ -77,9 +68,3 @@ class ChangePasswordTests(test.TestCase):
|
|||||||
|
|
||||||
info_msg = "Password changed. Please log in again to continue."
|
info_msg = "Password changed. Please log in again to continue."
|
||||||
self.assertContains(res, info_msg)
|
self.assertContains(res, info_msg)
|
||||||
|
|
||||||
def test_on_keystone_v3_disabled(self):
|
|
||||||
try:
|
|
||||||
reverse('horizon:settings:password:index')
|
|
||||||
except NoReverseMatch:
|
|
||||||
pass
|
|
||||||
|
@ -211,3 +211,6 @@ FLAVOR_EXTRA_KEYS = {
|
|||||||
('quota:outbound_average', 'Quota: Outbound average'),
|
('quota:outbound_average', 'Quota: Outbound average'),
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# The openstack_auth.user.Token object isn't JSON-serializable ATM
|
||||||
|
SESSION_SERIALIZER = 'django.contrib.sessions.serializers.PickleSerializer'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user