/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
1
# Copyright (C) 2007 Canonical Ltd
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
"""Test the model for interacting with the git process, etc."""
18
19
from bzrlib.plugins.git import tests
20
from bzrlib.plugins.git.gitlib import (
21
    errors,
22
    model,
23
    )
24
25
26
class TestModel(tests.TestCaseInTempDir):
27
28
    def test_no_head(self):
29
        tests.run_git('init')
30
        themodel = model.GitModel('.git')
31
        self.assertIs(None, themodel.get_head())
32
33
    def test_no_repository(self):
34
        themodel = model.GitModel('.git')
35
        self.assertRaises(errors.GitCommandError, themodel.get_head)
36
37
    def test_ancestors(self):
38
        tests.run_git('init')
0.200.24 by John Arbash Meinel
Use the builder in test_model as well to shave off a few more seconds.
39
        builder = tests.GitBranchBuilder()
40
        file_handle = builder.set_file('a', 'text for a\n', False)
41
        commit1_handle = builder.commit('Joe Foo <joe@foo.com>', u'message')
42
        file2_handle = builder.set_file('a', 'new a\n', False)
43
        commit2_handle = builder.commit('Joe Foo <joe@foo.com>', u'new a')
44
        file3_handle = builder.set_file('b', 'text for b\n', False)
45
        commit3_handle = builder.commit('Jerry Bar <jerry@foo.com>', u'b',
46
                                        base=commit1_handle)
47
        commit4_handle = builder.commit('Jerry Bar <jerry@foo.com>', u'merge',
48
                                        base=commit3_handle,
49
                                        merge=[commit2_handle],)
50
51
        mapping = builder.finish()
52
        commit1_id = mapping[commit1_handle]
53
        commit2_id = mapping[commit2_handle]
54
        commit3_id = mapping[commit3_handle]
55
        commit4_id = mapping[commit4_handle]
56
57
        revisions = tests.run_git('rev-list', '--topo-order',
58
                                  commit4_id)
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
59
        revisions = revisions.splitlines()
0.200.24 by John Arbash Meinel
Use the builder in test_model as well to shave off a few more seconds.
60
        self.assertEqual([commit4_id, commit2_id, commit3_id, commit1_id],
61
                         revisions)
62
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
63
        graph = {revisions[0]:[revisions[2], revisions[1]],
64
                 revisions[1]:[revisions[3]],
65
                 revisions[2]:[revisions[3]],
66
                 revisions[3]:[],
67
                }
68
69
        themodel = model.GitModel('.git')
0.200.24 by John Arbash Meinel
Use the builder in test_model as well to shave off a few more seconds.
70
        tests.run_git('reset', '--hard', commit4_id)
0.200.20 by John Arbash Meinel
All tests are passing again
71
        self.assertEqual(revisions[0], themodel.get_head())
0.200.19 by John Arbash Meinel
More refactoring. Add some direct tests for GitModel.
72
        self.assertEqual(graph, themodel.ancestry([revisions[0]]))