69
75
output, error = self.run_bzr(['branch', 'gitbranch', 'bzrbranch'])
70
self.assertEqual(error, 'Branched 1 revision(s).\n')
77
(error == 'Branched 1 revision(s).\n') or
78
(error == 'Branched 1 revision.\n'),
81
def test_checkout(self):
83
GitRepo.init(os.path.join(self.test_dir, "gitbranch"))
85
builder = tests.GitBranchBuilder()
86
builder.set_file('a', 'text for a\n', False)
87
builder.commit('Joe Foo <joe@foo.com>', u'<The commit message>')
91
output, error = self.run_bzr(['checkout', 'gitbranch', 'bzrbranch'])
92
self.assertEqual(error, '')
93
self.assertEqual(output, '')
72
95
def test_branch_ls(self):
73
96
self.simple_commit()
129
155
output, error = self.run_bzr(["tag", "bar"])
131
self.assertEquals(error, '')
132
self.assertEquals(output, 'Created tag bar.\n')
157
# bzr <= 2.2 emits this message in the output stream
158
# bzr => 2.3 emits this message in the error stream
159
self.assertEquals(error + output, 'Created tag bar.\n')
134
161
def test_init_repo(self):
135
output, error = self.run_bzr(["init-repo", "--git", "bla.git"])
162
output, error = self.run_bzr(["init", "--git", "bla.git"])
136
163
self.assertEquals(error, '')
137
self.assertEquals(output, 'Unshared repository with trees (format: git)\nLocation:\n repository: bla.git\n')
164
self.assertEquals(output, 'Created a standalone tree (format: git)\n')
166
def test_diff_format(self):
167
tree = self.make_branch_and_tree('.')
168
self.build_tree(['a'])
170
output, error = self.run_bzr(['diff', '--format=git'], retcode=1)
171
self.assertEqual(error, '')
172
self.assertEqual(output,
173
'diff --git /dev/null b/a\n'
176
'index 0000000..c197bd8 100644\n'
182
def test_git_import(self):
183
r = GitRepo.init("a", mkdir=True)
184
self.build_tree(["a/file"])
186
r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
187
r.do_commit(ref="refs/heads/bbranch", committer="Joe <joe@example.com>", message="Dummy")
188
self.run_bzr(["git-import", "a", "b"])
189
self.assertEquals(set(["abranch", "bbranch", ".bzr"]),
190
set(os.listdir("b")))
192
def test_git_import_incremental(self):
193
r = GitRepo.init("a", mkdir=True)
194
self.build_tree(["a/file"])
196
r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
197
self.run_bzr(["git-import", "a", "b"])
198
self.run_bzr(["git-import", "a", "b"])
199
self.assertEquals(set(["abranch", ".bzr"]), set(os.listdir("b")))
201
def test_git_import_tags(self):
202
r = GitRepo.init("a", mkdir=True)
203
self.build_tree(["a/file"])
205
cid = r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
206
r["refs/tags/atag"] = cid
207
self.run_bzr(["git-import", "a", "b"])
208
self.assertEquals(set(["abranch", ".bzr"]), set(os.listdir("b")))
209
b = Branch.open("b/abranch")
210
self.assertEquals(["atag"], b.tags.get_tag_dict().keys())
212
def test_git_import_colo(self):
213
if bzrlib_version < (2, 5, 0):
214
raise TestSkipped("colocated branches not supported with bzr < 2.5")
215
r = GitRepo.init("a", mkdir=True)
216
self.build_tree(["a/file"])
218
r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
219
r.do_commit(ref="refs/heads/bbranch", committer="Joe <joe@example.com>", message="Dummy")
220
self.make_bzrdir("b", format="development-colo")
221
self.run_bzr(["git-import", "a", "b"])
223
set([b.name for b in BzrDir.open("b").list_branches()]),
224
set(["abranch", "bbranch"]))
226
def test_git_refs_from_git(self):
227
r = GitRepo.init("a", mkdir=True)
228
self.build_tree(["a/file"])
230
cid = r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
231
r["refs/tags/atag"] = cid
232
(stdout, stderr) = self.run_bzr(["git-refs", "a"])
233
self.assertEquals(stderr, "")
234
self.assertEquals(stdout,
235
'refs/tags/atag -> ' + cid + '\n'
236
'refs/heads/abranch -> ' + cid + '\n')
238
def test_git_refs_from_bzr(self):
239
tree = self.make_branch_and_tree('a')
240
self.build_tree(["a/file"])
242
revid = tree.commit(committer="Joe <joe@example.com>", message="Dummy")
243
tree.branch.tags.set_tag("atag", revid)
244
(stdout, stderr) = self.run_bzr(["git-refs", "a"])
245
self.assertEquals(stderr, "")
246
self.assertTrue("refs/tags/atag -> " in stdout)
247
self.assertTrue("HEAD -> " in stdout)