/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to tests/test_blackbox.py

Implement GitRepository.revision_graph_can_have_wrong_parents().

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
 
17
17
"""Black-box tests for bzr-git."""
18
18
 
 
19
from dulwich.repo import (
 
20
    Repo as GitRepo,
 
21
    )
 
22
 
 
23
import os
 
24
 
 
25
from bzrlib.tests import KnownFailure
19
26
from bzrlib.tests.blackbox import ExternalBase
20
27
 
21
28
from bzrlib.plugins.git import (
22
 
    ids,
23
29
    tests,
24
30
    )
25
31
 
26
32
 
27
33
class TestGitBlackBox(ExternalBase):
28
34
 
 
35
    def simple_commit(self):
 
36
        # Create a git repository with a revision.
 
37
        repo = GitRepo.init(self.test_dir)
 
38
        builder = tests.GitBranchBuilder()
 
39
        builder.set_file('a', 'text for a\n', False)
 
40
        r1 = builder.commit('Joe Foo <joe@foo.com>', u'<The commit message>')
 
41
        return repo, builder.finish()[r1]
 
42
 
 
43
    def test_nick(self):
 
44
        GitRepo.init(self.test_dir)
 
45
        output, error = self.run_bzr(['nick'])
 
46
        self.assertEquals("HEAD\n", output)
 
47
 
29
48
    def test_info(self):
30
 
        # Create a git repository with a revision.
31
 
        tests.run_git('init')
32
 
        builder = tests.GitBranchBuilder()
33
 
        builder.set_file('a', 'text for a\n', False)
34
 
        builder.commit('Joe Foo <joe@foo.com>', u'<The commit message>')
35
 
        builder.finish()
36
 
 
 
49
        self.simple_commit()
37
50
        output, error = self.run_bzr(['info'])
38
51
        self.assertEqual(error, '')
39
52
        self.assertTrue("Repository branch (format: git)" in output)
40
53
 
 
54
    def test_branch(self):
 
55
        os.mkdir("gitbranch")
 
56
        GitRepo.init(os.path.join(self.test_dir, "gitbranch"))
 
57
        os.chdir('gitbranch')
 
58
        builder = tests.GitBranchBuilder()
 
59
        builder.set_file('a', 'text for a\n', False)
 
60
        builder.commit('Joe Foo <joe@foo.com>', u'<The commit message>')
 
61
        builder.finish()
 
62
        os.chdir('..')
 
63
 
 
64
        output, error = self.run_bzr(['branch', 'gitbranch', 'bzrbranch'])
 
65
        self.assertEqual(error, 'Branched 1 revision(s).\n')
 
66
 
 
67
    def test_branch_ls(self):
 
68
        self.simple_commit()
 
69
        output, error = self.run_bzr(['ls', '-r-1'])
 
70
        self.assertEqual(error, '')
 
71
        self.assertEqual(output, "a\n")
 
72
 
 
73
    def test_init(self):
 
74
        self.run_bzr("init-repo --git repo") 
 
75
 
 
76
    def test_info_verbose(self):
 
77
        self.simple_commit()
 
78
 
 
79
        output, error = self.run_bzr(['info', '-v'])
 
80
        self.assertEqual(error, '')
 
81
        self.assertTrue("Repository branch (format: git)" in output)
 
82
        self.assertTrue("control: Local Git Repository" in output)
 
83
        self.assertTrue("branch: Git Branch" in output)
 
84
        self.assertTrue("repository: Git Repository" in output)
 
85
 
 
86
    def test_push(self):
 
87
        os.mkdir("bla")
 
88
        GitRepo.init(os.path.join(self.test_dir, "bla"))
 
89
        self.run_bzr(['init', 'foo'])
 
90
        self.run_bzr(['commit', '--unchanged', '-m', 'bla', 'foo'])
 
91
        output, error = self.run_bzr(['push', '-d', 'foo', 'bla'], retcode=3)
 
92
        self.assertEquals('bzr: ERROR: Push is not yet supported for bzr-git. Try dpush instead.\n', error)
 
93
        self.assertEquals("", output)
 
94
 
41
95
    def test_log(self):
42
96
        # Smoke test for "bzr log" in a git repository.
43
 
 
44
 
        # Create a git repository with a revision.
45
 
        tests.run_git('init')
46
 
        builder = tests.GitBranchBuilder()
47
 
        builder.set_file('a', 'text for a\n', False)
48
 
        builder.commit('Joe Foo <joe@foo.com>', u'<The commit message>')
49
 
        builder.finish()
 
97
        self.simple_commit()
50
98
 
51
99
        # Check that bzr log does not fail and includes the revision.
52
100
        output, error = self.run_bzr(['log'])
54
102
        self.assertTrue(
55
103
            '<The commit message>' in output,
56
104
            "Commit message was not found in output:\n%s" % (output,))
 
105
 
 
106
    def test_log_verbose(self):
 
107
        # Smoke test for "bzr log -v" in a git repository.
 
108
        self.simple_commit()
 
109
 
 
110
        # Check that bzr log does not fail and includes the revision.
 
111
        output, error = self.run_bzr(['log', '-v'])
 
112
 
 
113
    def test_tags(self):
 
114
        git_repo, commit_sha1 = self.simple_commit()
 
115
        git_repo.refs["refs/tags/foo"] = commit_sha1
 
116
 
 
117
        output, error = self.run_bzr(['tags'])
 
118
        self.assertEquals(error, '')
 
119
        self.assertEquals(output, "foo                  1\n")
 
120
 
 
121
    def test_tag(self):
 
122
        self.simple_commit()
 
123
 
 
124
        output, error = self.run_bzr(["tag", "bar"])
 
125
 
 
126
        self.assertEquals(error, '')
 
127
        self.assertEquals(output, 'Created tag bar.\n')
 
128
 
 
129
    def test_init_repo(self):
 
130
        output, error = self.run_bzr(["init-repo", "--git", "bla.git"])
 
131
        self.assertEquals(error, '')
 
132
        self.assertEquals(output, 'Repository branch (format: git)\nLocation:\n  shared repository: bla.git\n  repository branch: bla.git\n')
 
133