|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
# Copyright (C) 2010-2017 RhodeCode GmbH
|
|
|
#
|
|
|
# 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
|
|
|
|
|
|
from rhodecode.tests import *
|
|
|
from rhodecode.model.db import UserLog
|
|
|
from rhodecode.model.meta import Session
|
|
|
from rhodecode.lib.utils2 import safe_unicode
|
|
|
|
|
|
dn = os.path.dirname
|
|
|
FIXTURES = os.path.join(dn(dn(os.path.abspath(__file__))), 'fixtures')
|
|
|
|
|
|
|
|
|
class TestAdminController(TestController):
|
|
|
|
|
|
@pytest.fixture(scope='class', autouse=True)
|
|
|
def prepare(self, request, pylonsapp):
|
|
|
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()
|
|
|
for k, v in row.iteritems():
|
|
|
v = safe_unicode(v)
|
|
|
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()
|
|
|
|
|
|
def test_index(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index'))
|
|
|
response.mustcontain('Admin journal')
|
|
|
|
|
|
def test_filter_all_entries(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',))
|
|
|
response.mustcontain('2034 entries')
|
|
|
|
|
|
def test_filter_journal_filter_exact_match_on_repository(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='repository:rhodecode'))
|
|
|
response.mustcontain('3 entries')
|
|
|
|
|
|
def test_filter_journal_filter_exact_match_on_repository_CamelCase(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='repository:RhodeCode'))
|
|
|
response.mustcontain('3 entries')
|
|
|
|
|
|
def test_filter_journal_filter_wildcard_on_repository(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='repository:*test*'))
|
|
|
response.mustcontain('862 entries')
|
|
|
|
|
|
def test_filter_journal_filter_prefix_on_repository(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='repository:test*'))
|
|
|
response.mustcontain('257 entries')
|
|
|
|
|
|
def test_filter_journal_filter_prefix_on_repository_CamelCase(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='repository:Test*'))
|
|
|
response.mustcontain('257 entries')
|
|
|
|
|
|
def test_filter_journal_filter_prefix_on_repository_and_user(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='repository:test* AND username:demo'))
|
|
|
response.mustcontain('130 entries')
|
|
|
|
|
|
def test_filter_journal_filter_prefix_on_repository_or_target_repo(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='repository:test* OR repository:rhodecode'))
|
|
|
response.mustcontain('260 entries') # 257 + 3
|
|
|
|
|
|
def test_filter_journal_filter_exact_match_on_username(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='username:demo'))
|
|
|
response.mustcontain('1087 entries')
|
|
|
|
|
|
def test_filter_journal_filter_exact_match_on_username_camelCase(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='username:DemO'))
|
|
|
response.mustcontain('1087 entries')
|
|
|
|
|
|
def test_filter_journal_filter_wildcard_on_username(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='username:*test*'))
|
|
|
response.mustcontain('100 entries')
|
|
|
|
|
|
def test_filter_journal_filter_prefix_on_username(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='username:demo*'))
|
|
|
response.mustcontain('1101 entries')
|
|
|
|
|
|
def test_filter_journal_filter_prefix_on_user_or_other_user(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='username:demo OR username:volcan'))
|
|
|
response.mustcontain('1095 entries') # 1087 + 8
|
|
|
|
|
|
def test_filter_journal_filter_wildcard_on_action(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='action:*pull_request*'))
|
|
|
response.mustcontain('187 entries')
|
|
|
|
|
|
def test_filter_journal_filter_on_date(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='date:20121010'))
|
|
|
response.mustcontain('47 entries')
|
|
|
|
|
|
def test_filter_journal_filter_on_date_2(self):
|
|
|
self.log_user()
|
|
|
response = self.app.get(url(controller='admin/admin', action='index',
|
|
|
filter='date:20121020'))
|
|
|
response.mustcontain('17 entries')
|
|
|
|