##// END OF EJS Templates
core: avoid using rhodecode.test packages inside main packages as tests are removed during build which can cause some problems in some edge case calls
core: avoid using rhodecode.test packages inside main packages as tests are removed during build which can cause some problems in some edge case calls

File last commit:

r5608:6d33e504 default
r5618:bdbdb63f default
Show More
test_repo.py
169 lines | 5.7 KiB | text/x-python | PythonLexer
core: updated copyright to 2024
r5608 # Copyright (C) 2010-2024 RhodeCode GmbH
dan
events: add event system for RepoEvents
r375 #
# 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
tests: fixed some tests
r4704 from rhodecode.events import UserPermissionsChange
events: added support for pull-request-comment and commit-comment events....
r4314 from rhodecode.lib.utils2 import StrictAttributeDict
dan
events: use context manager for testing fired events
r376 from rhodecode.tests.events.conftest import EventCatcher
dan
events: add event system for RepoEvents
r375
from rhodecode.lib import hooks_base, utils2
from rhodecode.model.repo import RepoModel
from rhodecode.events.repo import (
RepoPrePullEvent, RepoPullEvent,
RepoPrePushEvent, RepoPushEvent,
dan
integrations: add integration support...
r411 RepoPreCreateEvent, RepoCreateEvent,
comments: added new events for comment editing to handle them in integrations.
r4444 RepoPreDeleteEvent, RepoDeleteEvent,
RepoCommitCommentEvent, RepoCommitCommentEditEvent
dan
events: add event system for RepoEvents
r375 )
pytest: use consistent way of creating a fixture by using pytest.fixture()
r3946 @pytest.fixture()
dan
events: add event system for RepoEvents
r375 def scm_extras(user_regular, repo_stub):
extras = utils2.AttributeDict({
'ip': '127.0.0.1',
'username': user_regular.username,
vcs-ops: store user_id inside the extras for vcs context operations....
r2411 'user_id': user_regular.user_id,
dan
events: add event system for RepoEvents
r375 'action': '',
'repository': repo_stub.repo_name,
'scm': repo_stub.scm_instance().alias,
'config': '',
hooks: pass in store_path into env for hooks.
r3094 'repo_store': '',
dan
events: add event system for RepoEvents
r375 'server_url': 'http://example.com',
'make_lock': None,
rcextensions: new builtin rcextensions....
r3133 'user_agent': 'some-client',
dan
events: add event system for RepoEvents
r375 'locked_by': [None],
'commit_ids': ['a' * 40] * 3,
rcextensions: new builtin rcextensions....
r3133 'hook_type': 'scm_extras_test',
Martin Bornhold
tests: Add new attribute `is_shadow_repo` to test dummy extra data.
r909 'is_shadow_repo': False,
dan
events: add event system for RepoEvents
r375 })
return extras
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389 # TODO: dan: make the serialization tests complete json comparisons
@pytest.mark.parametrize('EventClass', [
dan
integrations: add integration support...
r411 RepoPreCreateEvent, RepoCreateEvent,
RepoPreDeleteEvent, RepoDeleteEvent,
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389 ])
repo-summary: re-implemented summary view as pyramid....
r1785 def test_repo_events_serialized(config_stub, repo_stub, EventClass):
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389 event = EventClass(repo_stub)
data = event.as_dict()
assert data['name'] == EventClass.name
assert data['repo']['repo_name'] == repo_stub.repo_name
dan
events: fix bug, 'url' was not in dict
r392 assert data['repo']['url']
events: expose permalink urls for different set of object....
r1788 assert data['repo']['permalink_url']
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389
@pytest.mark.parametrize('EventClass', [
RepoPrePullEvent, RepoPullEvent, RepoPrePushEvent
])
repo-summary: re-implemented summary view as pyramid....
r1785 def test_vcs_repo_events_serialize(config_stub, repo_stub, scm_extras, EventClass):
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389 event = EventClass(repo_name=repo_stub.repo_name, extras=scm_extras)
data = event.as_dict()
assert data['name'] == EventClass.name
assert data['repo']['repo_name'] == repo_stub.repo_name
dan
events: fix bug, 'url' was not in dict
r392 assert data['repo']['url']
events: expose permalink urls for different set of object....
r1788 assert data['repo']['permalink_url']
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389
@pytest.mark.parametrize('EventClass', [RepoPushEvent])
repo-summary: re-implemented summary view as pyramid....
r1785 def test_vcs_repo_push_event_serialize(config_stub, repo_stub, scm_extras, EventClass):
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389 event = EventClass(repo_name=repo_stub.repo_name,
pushed_commit_ids=scm_extras['commit_ids'],
extras=scm_extras)
data = event.as_dict()
assert data['name'] == EventClass.name
assert data['repo']['repo_name'] == repo_stub.repo_name
dan
events: fix bug, 'url' was not in dict
r392 assert data['repo']['url']
events: expose permalink urls for different set of object....
r1788 assert data['repo']['permalink_url']
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389
dan
events: add event system for RepoEvents
r375 def test_create_delete_repo_fires_events(backend):
dan
events: use context manager for testing fired events
r376 with EventCatcher() as event_catcher:
repo = backend.create_repo()
tests: fixed some tests
r4704 assert event_catcher.events_types == [RepoPreCreateEvent, RepoCreateEvent, UserPermissionsChange]
dan
events: use context manager for testing fired events
r376
with EventCatcher() as event_catcher:
RepoModel().delete(repo)
dan
integrations: add integration support...
r411 assert event_catcher.events_types == [RepoPreDeleteEvent, RepoDeleteEvent]
dan
events: add event system for RepoEvents
r375
def test_pull_fires_events(scm_extras):
dan
events: use context manager for testing fired events
r376 with EventCatcher() as event_catcher:
hooks_base.pre_push(scm_extras)
dan
events: rename event_type to events_types as it's multiple
r377 assert event_catcher.events_types == [RepoPrePushEvent]
dan
events: use context manager for testing fired events
r376
with EventCatcher() as event_catcher:
hooks_base.post_push(scm_extras)
dan
events: rename event_type to events_types as it's multiple
r377 assert event_catcher.events_types == [RepoPushEvent]
dan
events: add event system for RepoEvents
r375
def test_push_fires_events(scm_extras):
dan
events: use context manager for testing fired events
r376 with EventCatcher() as event_catcher:
hooks_base.pre_pull(scm_extras)
dan
events: rename event_type to events_types as it's multiple
r377 assert event_catcher.events_types == [RepoPrePullEvent]
dan
events: use context manager for testing fired events
r376
with EventCatcher() as event_catcher:
hooks_base.post_pull(scm_extras)
dan
events: rename event_type to events_types as it's multiple
r377 assert event_catcher.events_types == [RepoPullEvent]
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389
events: added support for pull-request-comment and commit-comment events....
r4314
@pytest.mark.parametrize('EventClass', [RepoCommitCommentEvent])
def test_repo_commit_event(config_stub, repo_stub, EventClass):
commit = StrictAttributeDict({
'raw_id': 'raw_id',
'message': 'message',
'branch': 'branch',
})
comment = StrictAttributeDict({
'comment_id': 'comment_id',
'text': 'text',
'comment_type': 'comment_type',
'f_path': 'f_path',
'line_no': 'line_no',
comments: added new events for comment editing to handle them in integrations.
r4444 'last_version': 0,
events: added support for pull-request-comment and commit-comment events....
r4314 })
event = EventClass(repo=repo_stub, commit=commit, comment=comment)
data = event.as_dict()
assert data['commit']['commit_id']
assert data['comment']['comment_id']
comments: added new events for comment editing to handle them in integrations.
r4444
@pytest.mark.parametrize('EventClass', [RepoCommitCommentEditEvent])
def test_repo_commit_edit_event(config_stub, repo_stub, EventClass):
commit = StrictAttributeDict({
'raw_id': 'raw_id',
'message': 'message',
'branch': 'branch',
})
comment = StrictAttributeDict({
'comment_id': 'comment_id',
'text': 'text',
'comment_type': 'comment_type',
'f_path': 'f_path',
'line_no': 'line_no',
'last_version': 0,
})
event = EventClass(repo=repo_stub, commit=commit, comment=comment)
data = event.as_dict()
assert data['commit']['commit_id']
assert data['comment']['comment_id']