Mercurial > kallithea
diff rhodecode/tests/models/test_repos_groups.py @ 3647:8a86836fad64 beta
more usage of fixture tools
in tests
author | Marcin Kuzminski <marcin@python-works.com> |
---|---|
date | Mon, 01 Apr 2013 23:45:25 +0200 |
parents | 94f251fda314 |
children | 3563bb7b4b82 5067d6e826a5 |
line wrap: on
line diff
--- a/rhodecode/tests/models/test_repos_groups.py Sun Mar 31 21:44:27 2013 +0200 +++ b/rhodecode/tests/models/test_repos_groups.py Mon Apr 01 23:45:25 2013 +0200 @@ -1,43 +1,29 @@ import os import unittest +from sqlalchemy.exc import IntegrityError + from rhodecode.tests import * +from rhodecode.tests.fixture import Fixture from rhodecode.model.repos_group import ReposGroupModel from rhodecode.model.repo import RepoModel -from rhodecode.model.db import RepoGroup, User +from rhodecode.model.db import RepoGroup from rhodecode.model.meta import Session -from sqlalchemy.exc import IntegrityError -def _make_group(path, desc='desc', parent_id=None, - skip_if_exists=False): - - gr = RepoGroup.get_by_group_name(path) - if gr and skip_if_exists: - return gr - if isinstance(parent_id, RepoGroup): - parent_id = parent_id.group_id - gr = ReposGroupModel().create(path, desc, TEST_USER_ADMIN_LOGIN, parent_id) - return gr +fixture = Fixture() def _update_group(id_, group_name, desc='desc', parent_id=None): - form_data = _get_group_create_params(group_name=group_name, - group_desc=desc, - group_parent_id=parent_id) + form_data = fixture._get_group_create_params(group_name=group_name, + group_desc=desc, + group_parent_id=parent_id) gr = ReposGroupModel().update(id_, form_data) return gr -def _make_repo(name, **kwargs): - form_data = _get_repo_create_params(repo_name=name, **kwargs) - cur_user = User.get_by_username(TEST_USER_ADMIN_LOGIN) - r = RepoModel().create(form_data, cur_user) - return r - - def _update_repo(name, **kwargs): - form_data = _get_repo_create_params(**kwargs) + form_data = fixture._get_repo_create_params(**kwargs) if not 'repo_name' in kwargs: form_data['repo_name'] = name if not 'perms_new' in kwargs: @@ -51,12 +37,9 @@ class TestReposGroups(unittest.TestCase): def setUp(self): - self.g1 = _make_group('test1', skip_if_exists=True) - Session().commit() - self.g2 = _make_group('test2', skip_if_exists=True) - Session().commit() - self.g3 = _make_group('test3', skip_if_exists=True) - Session().commit() + self.g1 = fixture.create_group('test1', skip_if_exists=True) + self.g2 = fixture.create_group('test2', skip_if_exists=True) + self.g3 = fixture.create_group('test3', skip_if_exists=True) def tearDown(self): Session.remove() @@ -76,47 +59,42 @@ ReposGroupModel().delete(id_) def test_create_group(self): - g = _make_group('newGroup') + g = fixture.create_group('newGroup') Session().commit() self.assertEqual(g.full_path, 'newGroup') self.assertTrue(self.__check_path('newGroup')) def test_create_same_name_group(self): - self.assertRaises(IntegrityError, lambda: _make_group('newGroup')) + self.assertRaises(IntegrityError, lambda: fixture.create_group('newGroup')) Session().rollback() def test_same_subgroup(self): - sg1 = _make_group('sub1', parent_id=self.g1.group_id) - Session().commit() + sg1 = fixture.create_group('sub1', group_parent_id=self.g1.group_id) self.assertEqual(sg1.parent_group, self.g1) self.assertEqual(sg1.full_path, 'test1/sub1') self.assertTrue(self.__check_path('test1', 'sub1')) - ssg1 = _make_group('subsub1', parent_id=sg1.group_id) - Session().commit() + ssg1 = fixture.create_group('subsub1', group_parent_id=sg1.group_id) self.assertEqual(ssg1.parent_group, sg1) self.assertEqual(ssg1.full_path, 'test1/sub1/subsub1') self.assertTrue(self.__check_path('test1', 'sub1', 'subsub1')) def test_remove_group(self): - sg1 = _make_group('deleteme') - Session().commit() + sg1 = fixture.create_group('deleteme') self.__delete_group(sg1.group_id) self.assertEqual(RepoGroup.get(sg1.group_id), None) self.assertFalse(self.__check_path('deteteme')) - sg1 = _make_group('deleteme', parent_id=self.g1.group_id) - Session().commit() + sg1 = fixture.create_group('deleteme', group_parent_id=self.g1.group_id) self.__delete_group(sg1.group_id) self.assertEqual(RepoGroup.get(sg1.group_id), None) self.assertFalse(self.__check_path('test1', 'deteteme')) def test_rename_single_group(self): - sg1 = _make_group('initial') - Session().commit() + sg1 = fixture.create_group('initial') new_sg1 = _update_group(sg1.group_id, 'after') self.assertTrue(self.__check_path('after')) @@ -124,8 +102,7 @@ def test_update_group_parent(self): - sg1 = _make_group('initial', parent_id=self.g1.group_id) - Session().commit() + sg1 = fixture.create_group('initial', group_parent_id=self.g1.group_id) new_sg1 = _update_group(sg1.group_id, 'after', parent_id=self.g1.group_id) self.assertTrue(self.__check_path('test1', 'after')) @@ -142,12 +119,11 @@ def test_subgrouping_with_repo(self): - g1 = _make_group('g1') - g2 = _make_group('g2') - Session().commit() + g1 = fixture.create_group('g1') + g2 = fixture.create_group('g2') # create new repo - r = _make_repo('john') - Session().commit() + r = fixture.create_repo('john') + self.assertEqual(r.repo_name, 'john') # put repo into group r = _update_repo('john', repo_group=g1.group_id) @@ -162,10 +138,8 @@ r.just_name])) def test_move_to_root(self): - g1 = _make_group('t11') - Session().commit() - g2 = _make_group('t22', parent_id=g1.group_id) - Session().commit() + g1 = fixture.create_group('t11') + g2 = fixture.create_group('t22', group_parent_id=g1.group_id) self.assertEqual(g2.full_path, 't11/t22') self.assertTrue(self.__check_path('t11', 't22')) @@ -180,15 +154,11 @@ self.assertTrue(self.__check_path('g22')) def test_rename_top_level_group_in_nested_setup(self): - g1 = _make_group('L1') - Session().commit() - g2 = _make_group('L2', parent_id=g1.group_id) - Session().commit() - g3 = _make_group('L3', parent_id=g2.group_id) - Session().commit() + g1 = fixture.create_group('L1') + g2 = fixture.create_group('L2', group_parent_id=g1.group_id) + g3 = fixture.create_group('L3', group_parent_id=g2.group_id) - r = _make_repo('L1/L2/L3/L3_REPO', repo_group=g3.group_id) - Session().commit() + r = fixture.create_repo('L1/L2/L3/L3_REPO', repo_group=g3.group_id) ##rename L1 all groups should be now changed _update_group(g1.group_id, 'L1_NEW') @@ -199,18 +169,12 @@ self.assertEqual(r.repo_name, 'L1_NEW/L2/L3/L3_REPO') def test_change_parent_of_top_level_group_in_nested_setup(self): - g1 = _make_group('R1') - Session().commit() - g2 = _make_group('R2', parent_id=g1.group_id) - Session().commit() - g3 = _make_group('R3', parent_id=g2.group_id) - Session().commit() + g1 = fixture.create_group('R1') + g2 = fixture.create_group('R2', group_parent_id=g1.group_id) + g3 = fixture.create_group('R3', group_parent_id=g2.group_id) + g4 = fixture.create_group('R1_NEW') - g4 = _make_group('R1_NEW') - Session().commit() - - r = _make_repo('R1/R2/R3/R3_REPO', repo_group=g3.group_id) - Session().commit() + r = fixture.create_repo('R1/R2/R3/R3_REPO', repo_group=g3.group_id) ##rename L1 all groups should be now changed _update_group(g1.group_id, 'R1', parent_id=g4.group_id) Session().commit() @@ -220,18 +184,12 @@ self.assertEqual(r.repo_name, 'R1_NEW/R1/R2/R3/R3_REPO') def test_change_parent_of_top_level_group_in_nested_setup_with_rename(self): - g1 = _make_group('X1') - Session().commit() - g2 = _make_group('X2', parent_id=g1.group_id) - Session().commit() - g3 = _make_group('X3', parent_id=g2.group_id) - Session().commit() + g1 = fixture.create_group('X1') + g2 = fixture.create_group('X2', group_parent_id=g1.group_id) + g3 = fixture.create_group('X3', group_parent_id=g2.group_id) + g4 = fixture.create_group('X1_NEW') - g4 = _make_group('X1_NEW') - Session().commit() - - r = _make_repo('X1/X2/X3/X3_REPO', repo_group=g3.group_id) - Session().commit() + r = fixture.create_repo('X1/X2/X3/X3_REPO', repo_group=g3.group_id) ##rename L1 all groups should be now changed _update_group(g1.group_id, 'X1_PRIM', parent_id=g4.group_id)