##// END OF EJS Templates
diffs: use whole chunk diff to calculate if it's oversized or not....
diffs: use whole chunk diff to calculate if it's oversized or not. - This fixes an issue if a file is added that has very large number of small lines. In this case the time to detect if the diff should be limited was very very long and CPU intensive.

File last commit:

r1721:0dad6b04 default
r2070:7939c6bf default
Show More
test_repo_groups.py
79 lines | 2.7 KiB | text/x-python | PythonLexer
project: added all source files and assets
r1 # -*- coding: utf-8 -*-
license: updated copyright year to 2017
r1271 # Copyright (C) 2010-2017 RhodeCode GmbH
project: added all source files and assets
r1 #
# 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 mock
import pylons
import pytest
from pylons import tmpl_context as c
@pytest.fixture
def current_user(request, user_util):
user = user_util.create_user()
request_mock = mock.Mock(user=user)
pylons.request._push_object(request_mock)
@request.addfinalizer
def cleanup():
pylons.request._pop_object()
return user
@pytest.fixture
def personal_group_with_parent(user_util, current_user):
group_read_only = user_util.create_repo_group()
user_util.grant_user_permission_to_repo_group(
group_read_only, current_user, 'group.read')
# TODO: johbo: This should go into the business models
group_as_admin = user_util.create_repo_group(
owner=current_user)
group_as_admin.parent_group = group_read_only
group_as_admin.group_name = group_as_admin.get_new_name(
group_as_admin.group_name)
return group_as_admin
@pytest.fixture
def controller():
from rhodecode.controllers.admin import repo_groups
return repo_groups.RepoGroupsController()
def test_repo_groups_load_defaults(
current_user, personal_group_with_parent, controller):
personal_group = personal_group_with_parent
controller._RepoGroupsController__load_defaults(True, personal_group)
tests: fixed tests for new repo settings...
r1721 expected_list = [-1, personal_group.parent_group.group_id]
project: added all source files and assets
r1 returned_group_ids = [group[0] for group in c.repo_groups]
assert returned_group_ids == expected_list
def test_repo_groups_load_defaults_with_missing_group(
current_user, personal_group_with_parent, controller):
personal_group = personal_group_with_parent
controller._RepoGroupsController__load_defaults(True)
tests: fixed tests for new repo settings...
r1721 expected_list = sorted([-1, personal_group.group_id])
project: added all source files and assets
r1 returned_group_ids = sorted([group[0] for group in c.repo_groups])
assert returned_group_ids == expected_list