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([".bzr"]), set(os.listdir("b")))
190
self.assertEquals(set(["abranch", "bbranch"]),
191
set(BzrDir.open("b").get_branches().keys()))
193
def test_git_import_incremental(self):
194
r = GitRepo.init("a", mkdir=True)
195
self.build_tree(["a/file"])
197
r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
198
self.run_bzr(["git-import", "a", "b"])
199
self.run_bzr(["git-import", "a", "b"])
200
self.assertEquals(set([".bzr"]), set(os.listdir("b")))
202
self.assertEquals(["abranch"], b.get_branches().keys())
204
def test_git_import_tags(self):
205
r = GitRepo.init("a", mkdir=True)
206
self.build_tree(["a/file"])
208
cid = r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
209
r["refs/tags/atag"] = cid
210
self.run_bzr(["git-import", "a", "b"])
211
self.assertEquals(set([".bzr"]), set(os.listdir("b")))
213
self.assertEquals(["abranch"], b.get_branches().keys())
214
self.assertEquals(["atag"],
215
b.open_branch("abranch").tags.get_tag_dict().keys())
217
def test_git_import_colo(self):
218
if bzrlib_version < (2, 5, 0):
219
raise TestSkipped("colocated branches not supported with bzr < 2.5")
220
r = GitRepo.init("a", mkdir=True)
221
self.build_tree(["a/file"])
223
r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
224
r.do_commit(ref="refs/heads/bbranch", committer="Joe <joe@example.com>", message="Dummy")
225
self.make_bzrdir("b", format="development-colo")
226
self.run_bzr(["git-import", "a", "b"])
228
set([b.name for b in BzrDir.open("b").list_branches()]),
229
set(["abranch", "bbranch"]))
231
def test_git_refs_from_git(self):
232
r = GitRepo.init("a", mkdir=True)
233
self.build_tree(["a/file"])
235
cid = r.do_commit(ref="refs/heads/abranch", committer="Joe <joe@example.com>", message="Dummy")
236
r["refs/tags/atag"] = cid
237
(stdout, stderr) = self.run_bzr(["git-refs", "a"])
238
self.assertEquals(stderr, "")
239
self.assertEquals(stdout,
240
'refs/tags/atag -> ' + cid + '\n'
241
'refs/heads/abranch -> ' + cid + '\n')
243
def test_git_refs_from_bzr(self):
244
tree = self.make_branch_and_tree('a')
245
self.build_tree(["a/file"])
247
revid = tree.commit(committer="Joe <joe@example.com>", message="Dummy")
248
tree.branch.tags.set_tag("atag", revid)
249
(stdout, stderr) = self.run_bzr(["git-refs", "a"])
250
self.assertEquals(stderr, "")
251
self.assertTrue("refs/tags/atag -> " in stdout)
252
self.assertTrue("HEAD -> " in stdout)