14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18
17
"""Tests for interfacing with a Git Branch"""
22
from dulwich.repo import (
32
from bzrlib.branch import (
35
from bzrlib.bzrdir import (
38
from bzrlib.repository import (
19
from bzrlib import revision
20
from bzrlib.branch import Branch
42
22
from bzrlib.plugins.git import (
47
from bzrlib.plugins.git.mapping import (
26
from bzrlib.plugins.git.mapping import default_mapping
52
31
class TestGitBranch(tests.TestCaseInTempDir):
54
33
_test_needs_features = [tests.GitCommandFeature]
56
35
def test_open_existing(self):
59
38
thebranch = Branch.open('.')
60
39
self.assertIsInstance(thebranch, branch.GitBranch)
64
thebranch = Branch.open('.')
65
self.assertEquals("LocalGitBranch('file://%s/', 'HEAD')" % self.test_dir, repr(thebranch))
67
41
def test_last_revision_is_null(self):
70
44
thebranch = Branch.open('.')
71
45
self.assertEqual(revision.NULL_REVISION, thebranch.last_revision())
73
47
thebranch.last_revision_info())
75
49
def simple_commit_a(self):
77
51
self.build_tree(['a'])
78
52
tests.run_git('add', 'a')
79
53
tests.run_git('commit', '-m', 'a')
98
72
self.assertEqual([default_mapping.revision_id_foreign_to_bzr(r) for r in (reva, revb)],
99
73
thebranch.revision_history())
101
def test_tag_annotated(self):
102
76
self.simple_commit_a()
103
77
reva = tests.run_git('rev-parse', 'HEAD').strip()
104
79
tests.run_git('tag', '-a', '-m', 'add tag', 'foo')
105
thebranch = Branch.open('.')
106
self.assertEquals({"foo": default_mapping.revision_id_foreign_to_bzr(reva)},
107
thebranch.tags.get_tag_dict())
110
self.simple_commit_a()
111
reva = tests.run_git('rev-parse', 'HEAD').strip()
112
tests.run_git('tag', '-m', 'add tag', 'foo')
113
thebranch = Branch.open('.')
114
self.assertEquals({"foo": default_mapping.revision_id_foreign_to_bzr(reva)},
115
thebranch.tags.get_tag_dict())
81
thebranch = Branch.open('.')
82
self.assertEquals({"foo": default_mapping.revision_id_foreign_to_bzr(reva)},
83
thebranch.tags.get_tag_dict())
119
86
class TestWithGitBranch(tests.TestCaseWithTransport):
122
89
tests.TestCaseWithTransport.setUp(self)
123
dulwich.repo.Repo.create(self.test_dir)
90
git.repo.Repo.create(self.test_dir)
124
91
self.git_branch = Branch.open(self.test_dir)
126
93
def test_get_parent(self):
127
94
self.assertIs(None, self.git_branch.get_parent())
129
96
def test_get_stacked_on_url(self):
130
self.assertRaises(errors.UnstackableBranchFormat,
131
self.git_branch.get_stacked_on_url)
97
self.assertIs(None, self.git_branch.get_stacked_on_url())
133
99
def test_get_physical_lock_status(self):
134
100
self.assertFalse(self.git_branch.get_physical_lock_status())
143
109
def test_get_format_description(self):
144
110
self.assertEquals("Git Branch", self.format.get_format_description())
148
class BranchTests(tests.TestCaseInTempDir):
150
def make_onerev_branch(self):
154
bb = tests.GitBranchBuilder()
155
bb.set_file("foobar", "foo\nbar\n", False)
156
mark = bb.commit("Somebody <somebody@someorg.org>", "mymsg")
157
gitsha = bb.finish()[mark]
161
def clone_git_branch(self, from_url, to_url):
162
from_dir = BzrDir.open(from_url)
163
to_dir = from_dir.sprout(to_url)
164
return to_dir.open_branch()
166
def test_single_rev(self):
167
path, gitsha = self.make_onerev_branch()
168
oldrepo = Repository.open(path)
169
revid = oldrepo.get_mapping().revision_id_foreign_to_bzr(gitsha)
170
newbranch = self.clone_git_branch(path, "f")
171
self.assertEquals([revid], newbranch.repository.all_revision_ids())
173
def test_sprouted_tags(self):
174
path, gitsha = self.make_onerev_branch()
176
tests.run_git("tag", "lala")
177
os.chdir(self.test_dir)
178
oldrepo = Repository.open(path)
179
revid = oldrepo.get_mapping().revision_id_foreign_to_bzr(gitsha)
180
newbranch = self.clone_git_branch(path, "f")
181
self.assertEquals({"lala": revid}, newbranch.tags.get_tag_dict())
182
self.assertEquals([revid], newbranch.repository.all_revision_ids())
185
class ForeignTestsBranchFactory(object):
187
def make_empty_branch(self, transport):
188
return LocalGitBzrDirFormat().initialize_on_transport(transport).open_branch()
190
make_branch = make_empty_branch