##// END OF EJS Templates
todos: all todos needs to be resolved for merge to happen....
todos: all todos needs to be resolved for merge to happen. This will prevent the outdated todos beeing automatically marked as solved becuase of bigger diff changes. It's better to mark commits quickly as resolved instead of potentially have unresolved todos hidden because of invlidation logic.

File last commit:

r1271:47a44c03 default
r1342:44fc3039 default
Show More
test_repo.py
117 lines | 4.0 KiB | text/x-python | PythonLexer
dan
events: add event system for RepoEvents
r375 # -*- coding: utf-8 -*-
license: updated copyright year to 2017
r1271 # Copyright (C) 2010-2017 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
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,
RepoPreDeleteEvent, RepoDeleteEvent,
dan
events: add event system for RepoEvents
r375 )
@pytest.fixture
def scm_extras(user_regular, repo_stub):
extras = utils2.AttributeDict({
'ip': '127.0.0.1',
'username': user_regular.username,
'action': '',
'repository': repo_stub.repo_name,
'scm': repo_stub.scm_instance().alias,
'config': '',
'server_url': 'http://example.com',
'make_lock': None,
'locked_by': [None],
'commit_ids': ['a' * 40] * 3,
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 ])
def test_repo_events_serialized(repo_stub, EventClass):
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']
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389
@pytest.mark.parametrize('EventClass', [
RepoPrePullEvent, RepoPullEvent, RepoPrePushEvent
])
def test_vcs_repo_events_serialize(repo_stub, scm_extras, EventClass):
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']
dan
events: fix bugs with serialization of repo/pr events and add tests for those cases
r389
@pytest.mark.parametrize('EventClass', [RepoPushEvent])
dan
events: fix bug, 'url' was not in dict
r392 def test_vcs_repo_push_event_serialize(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']
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()
dan
integrations: add integration support...
r411 assert event_catcher.events_types == [RepoPreCreateEvent, RepoCreateEvent]
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