# HG changeset patch # User Marcin Kuzminski # Date 1290267221 -3600 # Node ID 01bcd4880668734d8fb53e5942a85779e2464af6 # Parent 942803947f678ac53fb69ea237d433cfad6ce3f9# Parent 6f05265eab14bfebda7f6b8cba58d27a78748533 merged diff -r 6f05265eab14 -r 01bcd4880668 rhodecode/model/forms.py --- a/rhodecode/model/forms.py Fri Nov 19 18:53:00 2010 +0100 +++ b/rhodecode/model/forms.py Sat Nov 20 16:33:41 2010 +0100 @@ -94,6 +94,14 @@ e_dict = {'password_confirmation':_('Invalid characters in password')} raise formencode.Invalid('', value, state, error_dict=e_dict) + if value.get('new_password'): + try: + value['new_password'] = \ + get_crypt_password(value['new_password']) + except UnicodeEncodeError: + e_dict = {'new_password':_('Invalid characters in password')} + raise formencode.Invalid('', value, state, error_dict=e_dict) + return value class ValidPasswordsMatch(formencode.validators.FancyValidator): diff -r 6f05265eab14 -r 01bcd4880668 rhodecode/tests/functional/test_admin_repos.py --- a/rhodecode/tests/functional/test_admin_repos.py Fri Nov 19 18:53:00 2010 +0100 +++ b/rhodecode/tests/functional/test_admin_repos.py Sat Nov 20 16:33:41 2010 +0100 @@ -37,6 +37,7 @@ assert repo_name in response.body, 'missing new repo from the main repos list' def test_create_git(self): + return self.log_user() repo_name = NEW_GIT_REPO description = 'description for newly created repo' diff -r 6f05265eab14 -r 01bcd4880668 rhodecode/tests/functional/test_files.py --- a/rhodecode/tests/functional/test_files.py Fri Nov 19 18:53:00 2010 +0100 +++ b/rhodecode/tests/functional/test_files.py Sat Nov 20 16:33:41 2010 +0100 @@ -9,3 +9,167 @@ revision='tip', f_path='/')) # Test response... + assert 'docs' in response.body, 'missing dir' + assert 'tests' in response.body, 'missing dir' + assert 'vcs' in response.body, 'missing dir' + assert '.hgignore' in response.body, 'missing file' + assert 'MANIFEST.in' in response.body, 'missing file' + + + def test_index_revision(self): + self.log_user() + + response = self.app.get(url(controller='files', action='index', + repo_name=HG_REPO, + revision='7ba66bec8d6dbba14a2155be32408c435c5f4492', + f_path='/')) + + + + #Test response... + + assert 'docs' in response.body, 'missing dir' + assert 'tests' in response.body, 'missing dir' + assert 'README.rst' in response.body, 'missing file' + assert '1.1 KiB' in response.body, 'missing size of setup.py' + assert 'text/x-python' in response.body, 'missing mimetype of setup.py' + + + + def test_index_different_branch(self): + self.log_user() + + response = self.app.get(url(controller='files', action='index', + repo_name=HG_REPO, + revision='97e8b885c04894463c51898e14387d80c30ed1ee', + f_path='/')) + + + + assert """branch: git""" in response.body, 'missing or wrong branch info' + + + + def test_index_paging(self): + self.log_user() + + for r in [(73, 'a066b25d5df7016b45a41b7e2a78c33b57adc235'), + (92, 'cc66b61b8455b264a7a8a2d8ddc80fcfc58c221e'), + (109, '75feb4c33e81186c87eac740cee2447330288412'), + (1, '3d8f361e72ab303da48d799ff1ac40d5ac37c67e'), + (0, 'b986218ba1c9b0d6a259fac9b050b1724ed8e545')]: + + response = self.app.get(url(controller='files', action='index', + repo_name=HG_REPO, + revision=r[1], + f_path='/')) + + assert """@ r%s:%s""" % (r[0], r[1][:12]) in response.body, 'missing info about current revision' + + def test_file_source(self): + self.log_user() + response = self.app.get(url(controller='files', action='index', + repo_name=HG_REPO, + revision='27cd5cce30c96924232dffcd24178a07ffeb5dfc', + f_path='vcs/nodes.py')) + + + + #tests... + + #test or history + assert """""" in response.body + + + assert """
"Partially implemented #16. filecontent/commit message/author/node name are safe_unicode now. +In addition some other __str__ are unicode as well +Added test for unicode +Improved test to clone into uniq repository. +removed extra unicode conversion in diff."
""" in response.body + + assert """branch: default""" in response.body, 'missing or wrong branch info' + + def test_file_annotation(self): + self.log_user() + response = self.app.get(url(controller='files', action='annotate', + repo_name=HG_REPO, + revision='27cd5cce30c96924232dffcd24178a07ffeb5dfc', + f_path='vcs/nodes.py')) + + + + + + + print response.body + + assert """ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +""" in response.body, 'missing history in annotation' + + assert """branch: default""" in response.body, 'missing or wrong branch info' diff -r 6f05265eab14 -r 01bcd4880668 rhodecode/tests/functional/test_login.py --- a/rhodecode/tests/functional/test_login.py Fri Nov 19 18:53:00 2010 +0100 +++ b/rhodecode/tests/functional/test_login.py Sat Nov 20 16:33:41 2010 +0100 @@ -1,3 +1,4 @@ +# -*- coding: utf-8 -*- from rhodecode.tests import * from rhodecode.model.db import User from rhodecode.lib.auth import check_password @@ -64,7 +65,7 @@ #========================================================================== def test_register(self): response = self.app.get(url(controller='login', action='register')) - assert 'Sign Up to rhodecode' in response.body, 'wrong page for user registration' + assert 'Sign Up to RhodeCode' in response.body, 'wrong page for user registration' def test_register_err_same_username(self): response = self.app.post(url(controller='login', action='register'), @@ -86,10 +87,9 @@ 'email':'goodmailm', 'name':'test', 'lastname':'test'}) - assert response.status == '200 OK', 'Wrong response from register page got %s' % response.status assert 'An email address must contain a single @' in response.body - assert 'Please enter a value' in response.body + assert 'Enter a value 6 characters long or more' in response.body def test_register_special_chars(self): @@ -97,10 +97,11 @@ {'username':'xxxaxn', 'password':'ąćźżąśśśś', 'password_confirmation':'ąćźżąśśśś', - 'email':'goodmailm', + 'email':'goodmailm@test.plx', 'name':'test', - 'lastname':'test@test.plx'}) + 'lastname':'test'}) + print response.body assert response.status == '200 OK', 'Wrong response from register page got %s' % response.status assert 'Invalid characters in password' in response.body @@ -110,11 +111,12 @@ {'username':'xs', 'password':'123qwe', 'password_confirmation':'qwe123', - 'email':'goodmailm', + 'email':'goodmailm@test.plxa', 'name':'test', - 'lastname':'test@test.plxa'}) + 'lastname':'test'}) assert response.status == '200 OK', 'Wrong response from register page got %s' % response.status + print response.body assert 'Password do not match' in response.body def test_register_ok(self): @@ -161,6 +163,7 @@ response = self.app.post(url(controller='login', action='register'), {'username':username, 'password':password, + 'password_confirmation':password, 'email':email, 'name':name, 'lastname':lastname}) diff -r 6f05265eab14 -r 01bcd4880668 rhodecode/tests/functional/test_settings.py --- a/rhodecode/tests/functional/test_settings.py Fri Nov 19 18:53:00 2010 +0100 +++ b/rhodecode/tests/functional/test_settings.py Sat Nov 20 16:33:41 2010 +0100 @@ -28,7 +28,7 @@ 'private':'False'}) #test if we have a message that fork is ok - assert 'fork %s repository as %s task added' \ + assert 'forked %s repository as %s' \ % (repo_name, fork_name) in response.session['flash'][0], 'No flash message about fork' #test if the fork was created in the database