test_admin_settings.py
213 lines
| 8.8 KiB
| text/x-python
|
PythonLexer
r1366 | # -*- coding: utf-8 -*- | |||
r754 | from rhodecode.lib.auth import get_crypt_password, check_password | |||
r1633 | from rhodecode.model.db import User, RhodeCodeSetting | |||
r547 | from rhodecode.tests import * | |||
r2467 | from rhodecode.lib import helpers as h | |||
r2544 | from rhodecode.model.user import UserModel | |||
r2467 | ||||
r547 | ||||
r691 | class TestAdminSettingsController(TestController): | |||
r547 | ||||
def test_index(self): | ||||
response = self.app.get(url('admin_settings')) | ||||
# Test response... | ||||
def test_index_as_xml(self): | ||||
response = self.app.get(url('formatted_admin_settings', format='xml')) | ||||
def test_create(self): | ||||
response = self.app.post(url('admin_settings')) | ||||
def test_new(self): | ||||
response = self.app.get(url('admin_new_setting')) | ||||
def test_new_as_xml(self): | ||||
response = self.app.get(url('formatted_admin_new_setting', format='xml')) | ||||
def test_update(self): | ||||
response = self.app.put(url('admin_setting', setting_id=1)) | ||||
def test_update_browser_fakeout(self): | ||||
response = self.app.post(url('admin_setting', setting_id=1), params=dict(_method='put')) | ||||
def test_delete(self): | ||||
response = self.app.delete(url('admin_setting', setting_id=1)) | ||||
def test_delete_browser_fakeout(self): | ||||
response = self.app.post(url('admin_setting', setting_id=1), params=dict(_method='delete')) | ||||
def test_show(self): | ||||
response = self.app.get(url('admin_setting', setting_id=1)) | ||||
def test_show_as_xml(self): | ||||
response = self.app.get(url('formatted_admin_setting', setting_id=1, format='xml')) | ||||
def test_edit(self): | ||||
response = self.app.get(url('admin_edit_setting', setting_id=1)) | ||||
def test_edit_as_xml(self): | ||||
r1366 | response = self.app.get(url('formatted_admin_edit_setting', | |||
setting_id=1, format='xml')) | ||||
r547 | ||||
r893 | def test_ga_code_active(self): | |||
self.log_user() | ||||
old_title = 'RhodeCode' | ||||
old_realm = 'RhodeCode authentication' | ||||
new_ga_code = 'ga-test-123456789' | ||||
response = self.app.post(url('admin_setting', setting_id='global'), | ||||
params=dict( | ||||
_method='put', | ||||
rhodecode_title=old_title, | ||||
rhodecode_realm=old_realm, | ||||
rhodecode_ga_code=new_ga_code | ||||
)) | ||||
r1382 | self.checkSessionFlash(response, 'Updated application settings') | |||
r1633 | self.assertEqual(RhodeCodeSetting | |||
r1366 | .get_app_settings()['rhodecode_ga_code'], new_ga_code) | |||
r893 | ||||
response = response.follow() | ||||
r2544 | response.mustcontain("""_gaq.push(['_setAccount', '%s']);""" % new_ga_code) | |||
r893 | ||||
def test_ga_code_inactive(self): | ||||
self.log_user() | ||||
old_title = 'RhodeCode' | ||||
old_realm = 'RhodeCode authentication' | ||||
new_ga_code = '' | ||||
response = self.app.post(url('admin_setting', setting_id='global'), | ||||
params=dict( | ||||
_method='put', | ||||
rhodecode_title=old_title, | ||||
rhodecode_realm=old_realm, | ||||
rhodecode_ga_code=new_ga_code | ||||
)) | ||||
r1366 | self.assertTrue('Updated application settings' in | |||
response.session['flash'][0][1]) | ||||
r1633 | self.assertEqual(RhodeCodeSetting | |||
r1366 | .get_app_settings()['rhodecode_ga_code'], new_ga_code) | |||
r893 | ||||
response = response.follow() | ||||
r2544 | self.assertFalse("""_gaq.push(['_setAccount', '%s']);""" % new_ga_code | |||
in response.body) | ||||
r893 | ||||
def test_title_change(self): | ||||
self.log_user() | ||||
old_title = 'RhodeCode' | ||||
new_title = old_title + '_changed' | ||||
old_realm = 'RhodeCode authentication' | ||||
r1366 | ||||
for new_title in ['Changed', 'Żółwik', old_title]: | ||||
response = self.app.post(url('admin_setting', setting_id='global'), | ||||
params=dict( | ||||
_method='put', | ||||
rhodecode_title=new_title, | ||||
rhodecode_realm=old_realm, | ||||
rhodecode_ga_code='' | ||||
)) | ||||
r893 | ||||
r1382 | self.checkSessionFlash(response, 'Updated application settings') | |||
r1633 | self.assertEqual(RhodeCodeSetting | |||
r1366 | .get_app_settings()['rhodecode_title'], | |||
new_title.decode('utf-8')) | ||||
r893 | ||||
r1366 | response = response.follow() | |||
r2544 | response.mustcontain("""<h1><a href="/">%s</a></h1>""" % new_title) | |||
r893 | ||||
r547 | def test_my_account(self): | |||
self.log_user() | ||||
response = self.app.get(url('admin_settings_my_account')) | ||||
r1366 | ||||
self.assertTrue('value="test_admin' in response.body) | ||||
r691 | ||||
r2544 | @parameterized.expand([('firstname', 'new_username'), | |||
('lastname', 'new_username'), | ||||
('admin', True), | ||||
('admin', False), | ||||
('ldap_dn', 'test'), | ||||
('ldap_dn', None), | ||||
('active', False), | ||||
('active', True), | ||||
('email', 'some@email.com'), | ||||
]) | ||||
def test_my_account_update(self, name, expected): | ||||
uname = 'testme' | ||||
usr = UserModel().create_or_update(username=uname, password='qweqwe', | ||||
email='testme@rhodecod.org') | ||||
self.Session().commit() | ||||
params = usr.get_api_data() | ||||
user_id = usr.user_id | ||||
self.log_user(username=uname, password='qweqwe') | ||||
params.update({name: expected}) | ||||
params.update({'password_confirmation': ''}) | ||||
params.update({'new_password': ''}) | ||||
r754 | ||||
r2544 | try: | |||
response = self.app.put(url('admin_settings_my_account_update', | ||||
id=user_id), params) | ||||
r691 | ||||
r2544 | self.checkSessionFlash(response, | |||
'Your account was updated successfully') | ||||
updated_user = User.get_by_username(uname) | ||||
updated_params = updated_user.get_api_data() | ||||
updated_params.update({'password_confirmation': ''}) | ||||
updated_params.update({'new_password': ''}) | ||||
r691 | ||||
r2544 | params['last_login'] = updated_params['last_login'] | |||
if name == 'email': | ||||
params['emails'] = [expected] | ||||
if name == 'ldap_dn': | ||||
#cannot update this via form | ||||
params['ldap_dn'] = None | ||||
if name == 'active': | ||||
#my account cannot deactivate account | ||||
params['active'] = True | ||||
if name == 'admin': | ||||
#my account cannot make you an admin ! | ||||
params['admin'] = False | ||||
r754 | ||||
r2544 | self.assertEqual(params, updated_params) | |||
r1382 | ||||
r2544 | finally: | |||
UserModel().delete('testme') | ||||
r691 | ||||
r547 | def test_my_account_update_err_email_exists(self): | |||
self.log_user() | ||||
r691 | ||||
r2467 | new_email = 'test_regular@mail.com' # already exisitn email | |||
r2544 | response = self.app.put(url('admin_settings_my_account_update'), | |||
params=dict( | ||||
username='test_admin', | ||||
new_password='test12', | ||||
password_confirmation='test122', | ||||
firstname='NewName', | ||||
lastname='NewLastname', | ||||
email=new_email,) | ||||
) | ||||
r691 | ||||
r2544 | response.mustcontain('This e-mail address is already taken') | |||
r691 | ||||
r547 | def test_my_account_update_err(self): | |||
self.log_user('test_regular2', 'test12') | ||||
r691 | ||||
r547 | new_email = 'newmail.pl' | |||
r2467 | response = self.app.post(url('admin_settings_my_account_update'), | |||
params=dict( | ||||
_method='put', | ||||
username='test_admin', | ||||
new_password='test12', | ||||
password_confirmation='test122', | ||||
r2544 | firstname='NewName', | |||
r2467 | lastname='NewLastname', | |||
email=new_email,) | ||||
) | ||||
response.mustcontain('An email address must contain a single @') | ||||
from rhodecode.model import validators | ||||
msg = validators.ValidUsername(edit=False, | ||||
old_data={})._messages['username_exists'] | ||||
msg = h.html_escape(msg % {'username': 'test_admin'}) | ||||
response.mustcontain(u"%s" % msg) | ||||