69
74
output, error = self.run_bzr(['branch', 'gitbranch', 'bzrbranch'])
70
self.assertEqual(error, 'Branched 1 revision(s).\n')
76
(error == 'Branched 1 revision(s).\n') or
77
(error == 'Branched 1 revision.\n'),
80
def test_checkout(self):
82
GitRepo.init(os.path.join(self.test_dir, "gitbranch"))
84
builder = tests.GitBranchBuilder()
85
builder.set_file('a', 'text for a\n', False)
86
builder.commit('Joe Foo <joe@foo.com>', u'<The commit message>')
90
output, error = self.run_bzr(['checkout', 'gitbranch', 'bzrbranch'])
91
self.assertEqual(error, '')
92
self.assertEqual(output, '')
72
94
def test_branch_ls(self):
73
95
self.simple_commit()
129
157
output, error = self.run_bzr(["tag", "bar"])
131
self.assertEquals(error, '')
132
self.assertEquals(output, 'Created tag bar.\n')
159
# bzr <= 2.2 emits this message in the output stream
160
# bzr => 2.3 emits this message in the error stream
161
self.assertEquals(error + output, 'Created tag bar.\n')
134
163
def test_init_repo(self):
135
output, error = self.run_bzr(["init-repo", "--git", "bla.git"])
164
output, error = self.run_bzr(["init", "--git", "bla.git"])
136
165
self.assertEquals(error, '')
137
self.assertEquals(output, 'Unshared repository with trees (format: git)\nLocation:\n repository: bla.git\n')
166
self.assertEquals(output, 'Created a standalone tree (format: git)\n')
168
def test_diff_format(self):
169
tree = self.make_branch_and_tree('.')
170
self.build_tree(['a'])
172
output, error = self.run_bzr(['diff', '--format=git'], retcode=1)
173
self.assertEqual(error, '')
174
self.assertEqual(output,
175
'diff --git /dev/null b/a\n'
178
'index 0000000..c197bd8 100644\n'
184
def test_git_import(self):
185
r = GitRepo.init("a", mkdir=True)
186
self.build_tree(["a/file"])
188
r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
189
r.do_commit(ref="refs/heads/bbranch", committer="Joe <joe@example.com>", message="Dummy")
190
self.run_bzr(["git-import", "a", "b"])
191
self.assertEquals(set(["abranch", "bbranch", ".bzr"]),
192
set(os.listdir("b")))
194
def test_git_import_incremental(self):
195
r = GitRepo.init("a", mkdir=True)
196
self.build_tree(["a/file"])
198
r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
199
self.run_bzr(["git-import", "a", "b"])
200
self.run_bzr(["git-import", "a", "b"])
201
self.assertEquals(set(["abranch", ".bzr"]), set(os.listdir("b")))
203
def test_git_import_tags(self):
204
r = GitRepo.init("a", mkdir=True)
205
self.build_tree(["a/file"])
207
cid = r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
208
r["refs/tags/atag"] = cid
209
self.run_bzr(["git-import", "a", "b"])
210
self.assertEquals(set(["abranch", ".bzr"]), set(os.listdir("b")))
211
b = Branch.open("b/abranch")
212
self.assertEquals(["atag"], b.tags.get_tag_dict().keys())
214
def test_git_import_colo(self):
215
if bzrlib_version < (2, 5, 0):
216
raise TestSkipped("colocated branches not supported with bzr < 2.5")
217
r = GitRepo.init("a", mkdir=True)
218
self.build_tree(["a/file"])
220
r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
221
r.do_commit(ref="refs/heads/bbranch", committer="Joe <joe@example.com>", message="Dummy")
222
self.make_bzrdir("b", format="development-colo")
223
self.run_bzr(["git-import", "a", "b"])
225
set([b.name for b in BzrDir.open("b").list_branches()]),
226
set(["abranch", "bbranch"]))
228
def test_git_refs_from_git(self):
229
r = GitRepo.init("a", mkdir=True)
230
self.build_tree(["a/file"])
232
cid = r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
233
r["refs/tags/atag"] = cid
234
(stdout, stderr) = self.run_bzr(["git-refs", "a"])
235
self.assertEquals(stderr, "")
236
self.assertEquals(stdout,
237
'refs/tags/atag -> ' + cid + '\n'
238
'refs/heads/abranch -> ' + cid + '\n')
240
def test_git_refs_from_bzr(self):
241
tree = self.make_branch_and_tree('a')
242
self.build_tree(["a/file"])
244
revid = tree.commit(committer="Joe <joe@example.com>", message="Dummy")
245
tree.branch.tags.set_tag("atag", revid)
246
(stdout, stderr) = self.run_bzr(["git-refs", "a"])
247
self.assertEquals(stderr, "")
248
self.assertTrue("refs/tags/atag -> " in stdout)
249
self.assertTrue("refs/heads/master -> " in stdout)
250
self.assertTrue("HEAD -> " in stdout)