annotate rhodecode/tests/functional/test_admin.py @ 3063:ca2b21819dfd beta

Implemented better support for Wildcard queries add username column to journal for caching logs after user deletion added tests for admin journal migrations
author Marcin Kuzminski <marcin@python-works.com>
date Wed, 05 Dec 2012 23:59:13 +0100
parents dd06bdf974c8
children cc7eedb5323c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3063
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
1 import os
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
2 import csv
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
3 import datetime
547
1e757ac98988 renamed project to rhodecode
Marcin Kuzminski <marcin@python-works.com>
parents: 473
diff changeset
4 from rhodecode.tests import *
3063
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
5 from rhodecode.model.db import UserLog
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
6 from rhodecode.model.meta import Session
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
7 from rhodecode.lib.utils2 import safe_unicode
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
8
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
9 dn = os.path.dirname
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
10 FIXTURES = os.path.join(dn(dn(os.path.abspath(__file__))), 'fixtures')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
11
43
2e1247e62c5b changed for pylons 0.1 / 1.0
marcink
parents:
diff changeset
12
2e1247e62c5b changed for pylons 0.1 / 1.0
marcink
parents:
diff changeset
13 class TestAdminController(TestController):
2e1247e62c5b changed for pylons 0.1 / 1.0
marcink
parents:
diff changeset
14
3063
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
15 @classmethod
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
16 def setup_class(cls):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
17 UserLog.query().delete()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
18 Session().commit()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
19 with open(os.path.join(FIXTURES, 'journal_dump.csv')) as f:
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
20 for row in csv.DictReader(f):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
21 ul = UserLog()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
22 for k, v in row.iteritems():
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
23 v = safe_unicode(v)
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
24 if k == 'action_date':
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
25 v = datetime.datetime.strptime(v, '%Y-%m-%d %H:%M:%S.%f')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
26 setattr(ul, k, v)
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
27 Session().add(ul)
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
28 Session().commit()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
29
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
30 @classmethod
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
31 def teardown_class(cls):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
32 UserLog.query().delete()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
33 Session().commit()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
34
43
2e1247e62c5b changed for pylons 0.1 / 1.0
marcink
parents:
diff changeset
35 def test_index(self):
473
6b934c9607e7 Improved testing scenarios. Made test env creator
Marcin Kuzminski <marcin@python-works.com>
parents: 459
diff changeset
36 self.log_user()
459
7c978511c951 implemented basic (startup) nose test suite.
Marcin Kuzminski <marcin@python-works.com>
parents: 43
diff changeset
37 response = self.app.get(url(controller='admin/admin', action='index'))
3063
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
38 response.mustcontain('Admin journal')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
39
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
40 def test_filter_all_entries(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
41 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
42 response = self.app.get(url(controller='admin/admin', action='index',))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
43 response.mustcontain('2034 entries')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
44
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
45 def test_filter_journal_filter_exact_match_on_repository(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
46 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
47 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
48 filter='repository:rhodecode'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
49 response.mustcontain('3 entries')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
50
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
51 def test_filter_journal_filter_wildcard_on_repository(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
52 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
53 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
54 filter='repository:*test*'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
55 response.mustcontain('862 entries')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
56
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
57 def test_filter_journal_filter_prefix_on_repository(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
58 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
59 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
60 filter='repository:test*'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
61 response.mustcontain('257 entries')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
62
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
63 def test_filter_journal_filter_prefix_on_repository_and_user(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
64 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
65 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
66 filter='repository:test* AND username:demo'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
67 response.mustcontain('130 entries')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
68
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
69 def test_filter_journal_filter_prefix_on_repository_or_other_repo(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
70 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
71 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
72 filter='repository:test* OR repository:rhodecode'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
73 response.mustcontain('260 entries') # 257 + 3
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
74
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
75 def test_filter_journal_filter_exact_match_on_username(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
76 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
77 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
78 filter='username:demo'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
79 response.mustcontain('1087 entries')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
80
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
81 def test_filter_journal_filter_wildcard_on_username(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
82 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
83 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
84 filter='username:*test*'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
85 response.mustcontain('100 entries')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
86
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
87 def test_filter_journal_filter_prefix_on_username(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
88 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
89 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
90 filter='username:demo*'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
91 response.mustcontain('1101 entries')
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
92
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
93 def test_filter_journal_filter_prefix_on_user_or_other_user(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
94 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
95 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
96 filter='username:demo OR username:volcan'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
97 response.mustcontain('1095 entries') # 1087 + 8
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
98
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
99 def test_filter_journal_filter_wildcard_on_action(self):
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
100 self.log_user()
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
101 response = self.app.get(url(controller='admin/admin', action='index',
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
102 filter='action:*pull_request*'))
ca2b21819dfd Implemented better support for Wildcard queries
Marcin Kuzminski <marcin@python-works.com>
parents: 628
diff changeset
103 response.mustcontain('187 entries')