/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_git_branch.py

Ultra-experimental support for "bzr pull". No test. No sanity.

Show diffs side-by-side

added added

removed removed

Lines of Context:
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
16
16
 
17
 
 
18
17
"""Tests for interfacing with a Git Branch"""
19
18
 
20
 
 
21
 
import dulwich
22
 
from dulwich.repo import (
23
 
    Repo as GitRepo,
24
 
    )
25
 
 
26
 
import os
27
 
 
28
 
from bzrlib import (
29
 
    revision,
30
 
    )
31
 
from bzrlib.branch import (
32
 
    Branch,
33
 
    )
34
 
from bzrlib.bzrdir import (
35
 
    BzrDir,
36
 
    )
37
 
from bzrlib.repository import (
38
 
    Repository,
39
 
    )
40
 
 
 
19
import subprocess
 
20
 
 
21
from bzrlib import branch, revision
 
22
 
 
23
from bzrlib.plugins.git import tests
41
24
from bzrlib.plugins.git import (
42
 
    branch,
43
 
    tests,
 
25
    git_branch,
 
26
    ids,
44
27
    )
45
 
from bzrlib.plugins.git.mapping import default_mapping
46
28
 
47
29
 
48
30
class TestGitBranch(tests.TestCaseInTempDir):
50
32
    _test_needs_features = [tests.GitCommandFeature]
51
33
 
52
34
    def test_open_existing(self):
53
 
        GitRepo.init('.')
54
 
 
55
 
        thebranch = Branch.open('.')
56
 
        self.assertIsInstance(thebranch, branch.GitBranch)
57
 
 
58
 
    def test_repr(self):
59
 
        GitRepo.init('.')
60
 
        thebranch = Branch.open('.')
61
 
        self.assertEquals("LocalGitBranch('file://%s/', 'HEAD')" % self.test_dir, repr(thebranch))
 
35
        tests.run_git('init')
 
36
 
 
37
        thebranch = branch.Branch.open('.')
 
38
        self.assertIsInstance(thebranch, git_branch.GitBranch)
62
39
 
63
40
    def test_last_revision_is_null(self):
64
 
        GitRepo.init('.')
 
41
        tests.run_git('init')
65
42
 
66
 
        thebranch = Branch.open('.')
 
43
        thebranch = branch.Branch.open('.')
67
44
        self.assertEqual(revision.NULL_REVISION, thebranch.last_revision())
68
45
        self.assertEqual((0, revision.NULL_REVISION),
69
46
                         thebranch.last_revision_info())
70
47
 
71
 
    def simple_commit_a(self):
72
 
        GitRepo.init('.')
 
48
    def test_last_revision_is_valid(self):
 
49
        tests.run_git('init')
73
50
        self.build_tree(['a'])
74
51
        tests.run_git('add', 'a')
75
52
        tests.run_git('commit', '-m', 'a')
76
 
 
77
 
    def test_last_revision_is_valid(self):
78
 
        self.simple_commit_a()
79
53
        head = tests.run_git('rev-parse', 'HEAD').strip()
80
54
 
81
 
        thebranch = Branch.open('.')
82
 
        self.assertEqual(default_mapping.revision_id_foreign_to_bzr(head),
 
55
        thebranch = branch.Branch.open('.')
 
56
        self.assertEqual(ids.convert_revision_id_git_to_bzr(head),
83
57
                         thebranch.last_revision())
84
 
 
85
 
    def test_revision_history(self):
86
 
        self.simple_commit_a()
87
 
        reva = tests.run_git('rev-parse', 'HEAD').strip()
88
 
        self.build_tree(['b'])
89
 
        tests.run_git('add', 'b')
90
 
        tests.run_git('commit', '-m', 'b')
91
 
        revb = tests.run_git('rev-parse', 'HEAD').strip()
92
 
 
93
 
        thebranch = Branch.open('.')
94
 
        self.assertEqual([default_mapping.revision_id_foreign_to_bzr(r) for r in (reva, revb)],
95
 
                         thebranch.revision_history())
96
 
 
97
 
    def test_tag_annotated(self):
98
 
        self.simple_commit_a()
99
 
        reva = tests.run_git('rev-parse', 'HEAD').strip()
100
 
        tests.run_git('tag', '-a', '-m', 'add tag', 'foo')
101
 
        thebranch = Branch.open('.')
102
 
        self.assertEquals({"foo": default_mapping.revision_id_foreign_to_bzr(reva)},
103
 
                          thebranch.tags.get_tag_dict())
104
 
 
105
 
    def test_tag(self):
106
 
        self.simple_commit_a()
107
 
        reva = tests.run_git('rev-parse', 'HEAD').strip()
108
 
        tests.run_git('tag', '-m', 'add tag', 'foo')
109
 
        thebranch = Branch.open('.')
110
 
        self.assertEquals({"foo": default_mapping.revision_id_foreign_to_bzr(reva)},
111
 
                          thebranch.tags.get_tag_dict())
112
 
 
113
 
        
114
 
 
115
 
class TestWithGitBranch(tests.TestCaseWithTransport):
116
 
 
117
 
    def setUp(self):
118
 
        tests.TestCaseWithTransport.setUp(self)
119
 
        dulwich.repo.Repo.create(self.test_dir)
120
 
        self.git_branch = Branch.open(self.test_dir)
121
 
 
122
 
    def test_get_parent(self):
123
 
        self.assertIs(None, self.git_branch.get_parent())
124
 
 
125
 
    def test_get_stacked_on_url(self):
126
 
        self.assertIs(None, self.git_branch.get_stacked_on_url())
127
 
 
128
 
    def test_get_physical_lock_status(self):
129
 
        self.assertFalse(self.git_branch.get_physical_lock_status())
130
 
 
131
 
 
132
 
class TestGitBranchFormat(tests.TestCase):
133
 
 
134
 
    def setUp(self):
135
 
        super(TestGitBranchFormat, self).setUp()
136
 
        self.format = branch.GitBranchFormat()
137
 
 
138
 
    def test_get_format_description(self):
139
 
        self.assertEquals("Git Branch", self.format.get_format_description())
140
 
 
141
 
 
142
 
 
143
 
class BranchTests(tests.TestCaseInTempDir):
144
 
 
145
 
    def make_onerev_branch(self):
146
 
        os.mkdir("d")
147
 
        os.chdir("d")
148
 
        GitRepo.init('.')
149
 
        bb = tests.GitBranchBuilder()
150
 
        bb.set_file("foobar", "foo\nbar\n", False)
151
 
        mark = bb.commit("Somebody <somebody@someorg.org>", "mymsg")
152
 
        gitsha = bb.finish()[mark]
153
 
        os.chdir("..")
154
 
        return "d", gitsha
155
 
 
156
 
    def clone_git_branch(self, from_url, to_url):
157
 
        from_dir = BzrDir.open(from_url)
158
 
        to_dir = from_dir.sprout(to_url)
159
 
        return to_dir.open_branch()
160
 
 
161
 
    def test_single_rev(self):
162
 
        path, gitsha = self.make_onerev_branch()
163
 
        oldrepo = Repository.open(path)
164
 
        revid = oldrepo.get_mapping().revision_id_foreign_to_bzr(gitsha)
165
 
        newbranch = self.clone_git_branch(path, "f")
166
 
        self.assertEquals([revid], newbranch.repository.all_revision_ids())
167
 
 
168
 
    def test_sprouted_tags(self):
169
 
        path, gitsha = self.make_onerev_branch()
170
 
        os.chdir(path)
171
 
        tests.run_git("tag", "lala")
172
 
        os.chdir(self.test_dir)
173
 
        oldrepo = Repository.open(path)
174
 
        revid = oldrepo.get_mapping().revision_id_foreign_to_bzr(gitsha)
175
 
        newbranch = self.clone_git_branch(path, "f")
176
 
        self.assertEquals({"lala": revid}, newbranch.tags.get_tag_dict())
177
 
        self.assertEquals([revid], newbranch.repository.all_revision_ids())