##// END OF EJS Templates
deps: bumped rhodecode-tools to 4.1.0
deps: bumped rhodecode-tools to 4.1.0

File last commit:

r5608:6d33e504 default
r5632:4f05ba39 default
Show More
test_admin_audit_logs.py
155 lines | 6.8 KiB | text/x-python | PythonLexer
/ rhodecode / apps / admin / tests / test_admin_audit_logs.py
core: updated copyright to 2024
r5608 # Copyright (C) 2010-2024 RhodeCode GmbH
audit-logs: introduced new view to replace admin journal....
r1758 #
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
import os
import csv
import datetime
import pytest
tests: fixed all tests for python3 BIG changes
r5087 from rhodecode.lib.str_utils import safe_str
audit-logs: introduced new view to replace admin journal....
r1758 from rhodecode.tests import *
tests: refactor code to use a single test url generator
r5173 from rhodecode.tests.routes import route_path
tests: fixed test suite for celery adoption
r5607 from rhodecode.tests.fixtures.rc_fixture import FIXTURES
audit-logs: introduced new view to replace admin journal....
r1758 from rhodecode.model.db import UserLog
from rhodecode.model.meta import Session
pylons: remove pylons as dependency...
r2351 @pytest.mark.usefixtures('app')
class TestAdminController(object):
audit-logs: introduced new view to replace admin journal....
r1758
@pytest.fixture(scope='class', autouse=True)
pylons: remove pylons as dependency...
r2351 def prepare(self, request, baseapp):
audit-logs: introduced new view to replace admin journal....
r1758 UserLog.query().delete()
Session().commit()
def strptime(val):
fmt = '%Y-%m-%d %H:%M:%S'
if '.' not in val:
return datetime.datetime.strptime(val, fmt)
nofrag, frag = val.split(".")
date = datetime.datetime.strptime(nofrag, fmt)
frag = frag[:6] # truncate to microseconds
frag += (6 - len(frag)) * '0' # add 0s
return date.replace(microsecond=int(frag))
with open(os.path.join(FIXTURES, 'journal_dump.csv')) as f:
for row in csv.DictReader(f):
ul = UserLog()
python3: removed usage of .iteritems()
r4932 for k, v in row.items():
tests: fixed all tests for python3 BIG changes
r5087 v = safe_str(v)
audit-logs: introduced new view to replace admin journal....
r1758 if k == 'action_date':
v = strptime(v)
if k in ['user_id', 'repository_id']:
# nullable due to FK problems
v = None
setattr(ul, k, v)
Session().add(ul)
Session().commit()
@request.addfinalizer
def cleanup():
UserLog.query().delete()
Session().commit()
pylons: remove pylons as dependency...
r2351 def test_index(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs'))
response.mustcontain('Admin audit logs')
pylons: remove pylons as dependency...
r2351 def test_filter_all_entries(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs'))
all_count = UserLog.query().count()
response.mustcontain('%s entries' % all_count)
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_exact_match_on_repository(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='repository:rhodecode')))
response.mustcontain('3 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_exact_match_on_repository_CamelCase(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='repository:RhodeCode')))
response.mustcontain('3 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_wildcard_on_repository(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='repository:*test*')))
response.mustcontain('862 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_prefix_on_repository(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='repository:test*')))
response.mustcontain('257 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_prefix_on_repository_CamelCase(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='repository:Test*')))
response.mustcontain('257 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_prefix_on_repository_and_user(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='repository:test* AND username:demo')))
response.mustcontain('130 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_prefix_on_repository_or_target_repo(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='repository:test* OR repository:rhodecode')))
response.mustcontain('260 entries') # 257 + 3
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_exact_match_on_username(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='username:demo')))
response.mustcontain('1087 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_exact_match_on_username_camelCase(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='username:DemO')))
response.mustcontain('1087 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_wildcard_on_username(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='username:*test*')))
entries_count = UserLog.query().filter(UserLog.username.ilike('%test%')).count()
response.mustcontain('{} entries'.format(entries_count))
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_prefix_on_username(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='username:demo*')))
response.mustcontain('1101 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_prefix_on_user_or_other_user(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='username:demo OR username:volcan')))
response.mustcontain('1095 entries') # 1087 + 8
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_wildcard_on_action(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='action:*pull_request*')))
response.mustcontain('187 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_on_date(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='date:20121010')))
response.mustcontain('47 entries')
pylons: remove pylons as dependency...
r2351 def test_filter_journal_filter_on_date_2(self, autologin_user):
audit-logs: introduced new view to replace admin journal....
r1758 response = self.app.get(route_path('admin_audit_logs',
params=dict(filter='date:20121020')))
response.mustcontain('17 entries')