test_repo_issue_tracker.py
134 lines
| 5.5 KiB
| text/x-python
|
PythonLexer
r2014 | ||||
r5088 | # Copyright (C) 2010-2023 RhodeCode GmbH | |||
r2014 | # | |||
# 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 pytest | ||||
r5087 | from rhodecode.lib.hash_utils import md5_safe | |||
r2014 | from rhodecode.model.db import Repository | |||
from rhodecode.model.meta import Session | ||||
from rhodecode.model.settings import SettingsModel, IssueTrackerSettingsModel | ||||
r5173 | from rhodecode.tests.routes import route_path | |||
r2014 | ||||
@pytest.mark.usefixtures("app") | ||||
class TestRepoIssueTracker(object): | ||||
def test_issuetracker_index(self, autologin_user, backend): | ||||
repo = backend.create_repo() | ||||
response = self.app.get(route_path('edit_repo_issuetracker', | ||||
repo_name=repo.repo_name)) | ||||
assert response.status_code == 200 | ||||
def test_add_and_test_issuetracker_patterns( | ||||
self, autologin_user, backend, csrf_token, request, xhr_header): | ||||
pattern = 'issuetracker_pat' | ||||
another_pattern = pattern+'1' | ||||
post_url = route_path( | ||||
'edit_repo_issuetracker_update', repo_name=backend.repo.repo_name) | ||||
post_data = { | ||||
'new_pattern_pattern_0': pattern, | ||||
r2334 | 'new_pattern_url_0': 'http://url', | |||
r2014 | 'new_pattern_prefix_0': 'prefix', | |||
'new_pattern_description_0': 'description', | ||||
'new_pattern_pattern_1': another_pattern, | ||||
r2334 | 'new_pattern_url_1': '/url1', | |||
r2014 | 'new_pattern_prefix_1': 'prefix1', | |||
'new_pattern_description_1': 'description1', | ||||
'csrf_token': csrf_token | ||||
} | ||||
self.app.post(post_url, post_data, status=302) | ||||
self.settings_model = IssueTrackerSettingsModel(repo=backend.repo) | ||||
settings = self.settings_model.get_repo_settings() | ||||
r5087 | self.uid = md5_safe(pattern) | |||
r2014 | assert settings[self.uid]['pat'] == pattern | |||
r5087 | self.another_uid = md5_safe(another_pattern) | |||
r2014 | assert settings[self.another_uid]['pat'] == another_pattern | |||
# test pattern | ||||
data = {'test_text': 'example of issuetracker_pat replacement', | ||||
'csrf_token': csrf_token} | ||||
response = self.app.post( | ||||
route_path('edit_repo_issuetracker_test', | ||||
repo_name=backend.repo.repo_name), | ||||
extra_environ=xhr_header, params=data) | ||||
r4994 | assert response.text == \ | |||
r4033 | 'example of <a class="tooltip issue-tracker-link" href="http://url" title="description">prefix</a> replacement' | |||
r2014 | ||||
@request.addfinalizer | ||||
def cleanup(): | ||||
self.settings_model.delete_entries(self.uid) | ||||
self.settings_model.delete_entries(self.another_uid) | ||||
def test_edit_issuetracker_pattern( | ||||
self, autologin_user, backend, csrf_token, request): | ||||
entry_key = 'issuetracker_pat_' | ||||
pattern = 'issuetracker_pat2' | ||||
old_pattern = 'issuetracker_pat' | ||||
r5087 | old_uid = md5_safe(old_pattern) | |||
r2014 | ||||
sett = SettingsModel(repo=backend.repo).create_or_update_setting( | ||||
entry_key+old_uid, old_pattern, 'unicode') | ||||
Session().add(sett) | ||||
Session().commit() | ||||
post_url = route_path( | ||||
'edit_repo_issuetracker_update', repo_name=backend.repo.repo_name) | ||||
post_data = { | ||||
'new_pattern_pattern_0': pattern, | ||||
r2334 | 'new_pattern_url_0': '/url', | |||
r2014 | 'new_pattern_prefix_0': 'prefix', | |||
'new_pattern_description_0': 'description', | ||||
'uid': old_uid, | ||||
'csrf_token': csrf_token | ||||
} | ||||
self.app.post(post_url, post_data, status=302) | ||||
self.settings_model = IssueTrackerSettingsModel(repo=backend.repo) | ||||
settings = self.settings_model.get_repo_settings() | ||||
r5087 | self.uid = md5_safe(pattern) | |||
r2014 | assert settings[self.uid]['pat'] == pattern | |||
with pytest.raises(KeyError): | ||||
key = settings[old_uid] | ||||
@request.addfinalizer | ||||
def cleanup(): | ||||
self.settings_model.delete_entries(self.uid) | ||||
def test_delete_issuetracker_pattern( | ||||
r4111 | self, autologin_user, backend, csrf_token, settings_util, xhr_header): | |||
r2014 | repo = backend.create_repo() | |||
repo_name = repo.repo_name | ||||
entry_key = 'issuetracker_pat_' | ||||
pattern = 'issuetracker_pat3' | ||||
r5087 | uid = md5_safe(pattern) | |||
r2014 | settings_util.create_repo_rhodecode_setting( | |||
repo=backend.repo, name=entry_key+uid, | ||||
value=entry_key, type_='unicode', cleanup=False) | ||||
self.app.post( | ||||
route_path( | ||||
'edit_repo_issuetracker_delete', | ||||
repo_name=backend.repo.repo_name), | ||||
{ | ||||
'uid': uid, | ||||
r4111 | 'csrf_token': csrf_token, | |||
'': '' | ||||
}, extra_environ=xhr_header, status=200) | ||||
r2014 | settings = IssueTrackerSettingsModel( | |||
repo=Repository.get_by_repo_name(repo_name)).get_repo_settings() | ||||
assert 'rhodecode_%s%s' % (entry_key, uid) not in settings | ||||