17
17
"""Tests for interfacing with a Git Branch"""
21
from bzrlib import branch, revision
23
from bzrlib.plugins.git import tests
25
from bzrlib.branch import (
28
from bzrlib.bzrdir import (
31
from bzrlib.repository import (
24
35
from bzrlib.plugins.git import (
39
from bzrlib.plugins.git.mapping import default_mapping
30
42
class TestGitBranch(tests.TestCaseInTempDir):
34
46
def test_open_existing(self):
35
47
tests.run_git('init')
37
thebranch = branch.Branch.open('.')
38
self.assertIsInstance(thebranch, git_branch.GitBranch)
49
thebranch = Branch.open('.')
50
self.assertIsInstance(thebranch, branch.GitBranch)
40
52
def test_last_revision_is_null(self):
41
53
tests.run_git('init')
43
thebranch = branch.Branch.open('.')
55
thebranch = Branch.open('.')
44
56
self.assertEqual(revision.NULL_REVISION, thebranch.last_revision())
45
57
self.assertEqual((0, revision.NULL_REVISION),
46
58
thebranch.last_revision_info())
60
def simple_commit_a(self):
62
self.build_tree(['a'])
63
tests.run_git('add', 'a')
64
tests.run_git('commit', '-m', 'a')
48
66
def test_last_revision_is_valid(self):
50
self.build_tree(['a'])
51
tests.run_git('add', 'a')
52
tests.run_git('commit', '-m', 'a')
67
self.simple_commit_a()
53
68
head = tests.run_git('rev-parse', 'HEAD').strip()
55
thebranch = branch.Branch.open('.')
56
self.assertEqual(ids.convert_revision_id_git_to_bzr(head),
70
thebranch = Branch.open('.')
71
self.assertEqual(default_mapping.revision_id_foreign_to_bzr(head),
57
72
thebranch.last_revision())
59
74
def test_revision_history(self):
61
self.build_tree(['a'])
62
tests.run_git('add', 'a')
63
tests.run_git('commit', '-m', 'a')
75
self.simple_commit_a()
64
76
reva = tests.run_git('rev-parse', 'HEAD').strip()
65
77
self.build_tree(['b'])
66
78
tests.run_git('add', 'b')
67
79
tests.run_git('commit', '-m', 'b')
68
80
revb = tests.run_git('rev-parse', 'HEAD').strip()
70
thebranch = branch.Branch.open('.')
71
self.assertEqual([ids.convert_revision_id_git_to_bzr(r) for r in (reva, revb)],
82
thebranch = Branch.open('.')
83
self.assertEqual([default_mapping.revision_id_foreign_to_bzr(r) for r in (reva, revb)],
72
84
thebranch.revision_history())
86
def test_tag_annotated(self):
87
self.simple_commit_a()
88
reva = tests.run_git('rev-parse', 'HEAD').strip()
89
tests.run_git('tag', '-a', '-m', 'add tag', 'foo')
90
thebranch = Branch.open('.')
91
self.assertEquals({"foo": default_mapping.revision_id_foreign_to_bzr(reva)},
92
thebranch.tags.get_tag_dict())
95
self.simple_commit_a()
96
reva = tests.run_git('rev-parse', 'HEAD').strip()
97
tests.run_git('tag', '-m', 'add tag', 'foo')
98
thebranch = Branch.open('.')
99
self.assertEquals({"foo": default_mapping.revision_id_foreign_to_bzr(reva)},
100
thebranch.tags.get_tag_dict())
75
104
class TestWithGitBranch(tests.TestCaseWithTransport):
95
124
super(TestGitBranchFormat, self).setUp()
96
self.format = git_branch.GitBranchFormat()
125
self.format = branch.GitBranchFormat()
98
127
def test_get_format_description(self):
99
128
self.assertEquals("Git Branch", self.format.get_format_description())
132
class BranchTests(tests.TestCaseInTempDir):
134
def make_onerev_branch(self):
137
tests.run_git("init")
138
bb = tests.GitBranchBuilder()
139
bb.set_file("foobar", "foo\nbar\n", False)
140
mark = bb.commit("Somebody <somebody@someorg.org>", "mymsg")
141
gitsha = bb.finish()[mark]
145
def clone_git_branch(self, from_url, to_url):
146
from_dir = BzrDir.open(from_url)
147
to_dir = from_dir.sprout(to_url)
148
return to_dir.open_branch()
150
def test_single_rev(self):
151
path, gitsha = self.make_onerev_branch()
152
oldrepo = Repository.open(path)
153
revid = oldrepo.get_mapping().revision_id_foreign_to_bzr(gitsha)
154
newbranch = self.clone_git_branch(path, "f")
155
self.assertEquals([revid], newbranch.repository.all_revision_ids())
157
def test_sprouted_tags(self):
158
path, gitsha = self.make_onerev_branch()
160
tests.run_git("tag", "lala")
161
os.chdir(self.test_dir)
162
oldrepo = Repository.open(path)
163
revid = oldrepo.get_mapping().revision_id_foreign_to_bzr(gitsha)
164
newbranch = self.clone_git_branch(path, "f")
165
self.assertEquals({"lala": revid}, newbranch.tags.get_tag_dict())
166
self.assertEquals([revid], newbranch.repository.all_revision_ids())