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

Ignore .plugins dir.

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
 
17
17
"""Tests for interfacing with a Git Repository"""
18
18
 
19
 
import dulwich
20
 
from dulwich.repo import (
21
 
    Repo as GitRepo,
22
 
    )
23
 
import os
 
19
import git
24
20
 
25
21
from bzrlib import (
26
22
    errors,
27
23
    inventory,
 
24
    repository,
28
25
    revision,
29
26
    )
30
 
from bzrlib.repository import (
31
 
    InterRepository,
32
 
    Repository,
33
 
    )
34
27
 
 
28
from bzrlib.plugins.git import tests
35
29
from bzrlib.plugins.git import (
36
 
    dir,
37
 
    repository,
38
 
    tests,
39
 
    )
40
 
from bzrlib.plugins.git.mapping import (
41
 
    default_mapping,
42
 
    )
43
 
from bzrlib.plugins.git.object_store import (
44
 
    BazaarObjectStore,
45
 
    )
46
 
from bzrlib.plugins.git.push import (
47
 
    MissingObjectsIterator,
48
 
    )
 
30
    git_dir,
 
31
    git_repository,
 
32
    ids,
 
33
    )
 
34
 
49
35
 
50
36
class TestGitRepositoryFeatures(tests.TestCaseInTempDir):
51
37
    """Feature tests for GitRepository."""
53
39
    _test_needs_features = [tests.GitCommandFeature]
54
40
 
55
41
    def test_open_existing(self):
56
 
        GitRepo.init(self.test_dir)
 
42
        tests.run_git('init')
57
43
 
58
 
        repo = Repository.open('.')
59
 
        self.assertIsInstance(repo, repository.GitRepository)
 
44
        repo = repository.Repository.open('.')
 
45
        self.assertIsInstance(repo, git_repository.GitRepository)
60
46
 
61
47
    def test_has_git_repo(self):
62
 
        GitRepo.init(self.test_dir)
 
48
        tests.run_git('init')
63
49
 
64
 
        repo = Repository.open('.')
65
 
        self.assertIsInstance(repo._git, dulwich.repo.Repo)
 
50
        repo = repository.Repository.open('.')
 
51
        self.assertIsInstance(repo._git, git.repo.Repo)
66
52
 
67
53
    def test_get_revision(self):
68
54
        # GitRepository.get_revision gives a Revision object.
69
55
 
70
56
        # Create a git repository with a revision.
71
 
        GitRepo.init(self.test_dir)
 
57
        tests.run_git('init')
72
58
        builder = tests.GitBranchBuilder()
73
59
        builder.set_file('a', 'text for a\n', False)
74
60
        commit_handle = builder.commit('Joe Foo <joe@foo.com>', u'message')
76
62
        commit_id = mapping[commit_handle]
77
63
 
78
64
        # Get the corresponding Revision object.
79
 
        revid = default_mapping.revision_id_foreign_to_bzr(commit_id)
80
 
        repo = Repository.open('.')
 
65
        revid = ids.convert_revision_id_git_to_bzr(commit_id)
 
66
        repo = repository.Repository.open('.')
81
67
        rev = repo.get_revision(revid)
82
68
        self.assertIsInstance(rev, revision.Revision)
83
69
 
84
 
    def test_get_revision_unknown(self):
85
 
        GitRepo.init(self.test_dir)
86
 
 
87
 
        repo = Repository.open('.')
88
 
        self.assertRaises(errors.NoSuchRevision, repo.get_revision, "bla")
89
 
 
90
70
    def simple_commit(self):
91
71
        # Create a git repository with some interesting files in a revision.
92
 
        GitRepo.init(self.test_dir)
 
72
        tests.run_git('init')
93
73
        builder = tests.GitBranchBuilder()
94
74
        builder.set_file('data', 'text\n', False)
95
75
        builder.set_file('executable', 'content', True)
102
82
 
103
83
    def test_revision_tree(self):
104
84
        commit_id = self.simple_commit()
105
 
        revid = default_mapping.revision_id_foreign_to_bzr(commit_id)
106
 
        repo = Repository.open('.')
 
85
        revid = ids.convert_revision_id_git_to_bzr(commit_id)
 
86
        repo = repository.Repository.open('.')
107
87
        tree = repo.revision_tree(revid)
108
88
        self.assertEquals(tree.get_revision_id(), revid)
109
89
        self.assertEquals("text\n", tree.get_file_text(tree.path2id("data")))
115
95
        commit_id = self.simple_commit()
116
96
 
117
97
        # Get the corresponding Inventory object.
118
 
        revid = default_mapping.revision_id_foreign_to_bzr(commit_id)
119
 
        repo = Repository.open('.')
 
98
        revid = ids.convert_revision_id_git_to_bzr(commit_id)
 
99
        repo = repository.Repository.open('.')
120
100
        inv = repo.get_inventory(revid)
121
101
        self.assertIsInstance(inv, inventory.Inventory)
122
102
        printed_inv = '\n'.join(
124
104
            for path, entry in inv.iter_entries())
125
105
        self.assertEqualDiff(
126
106
            printed_inv,
127
 
            "('', False, GitInventoryDirectory('TREE_ROOT', u'', parent_id=None,"
128
 
            " revision='"+default_mapping.revision_id_foreign_to_bzr("69c39cfa65962f3cf16b9b3eb08a15954e9d8590")+"'))\n"
129
 
            "(u'data', False, GitInventoryFile('data', u'data',"
130
 
            " parent_id='TREE_ROOT',"
131
 
            " sha1='aa785adca3fcdfe1884ae840e13c6d294a2414e8', len=5, revision=git-v1:69c39cfa65962f3cf16b9b3eb08a15954e9d8590))\n"
132
 
            "(u'executable', True, GitInventoryFile('executable', u'executable',"
133
 
            " parent_id='TREE_ROOT',"
134
 
            " sha1='040f06fd774092478d450774f5ba30c5da78acc8', len=7, revision=git-v1:69c39cfa65962f3cf16b9b3eb08a15954e9d8590))\n"
135
 
            "(u'link', False, GitInventoryLink('link', u'link',"
136
 
            " parent_id='TREE_ROOT', revision='"+default_mapping.revision_id_foreign_to_bzr("69c39cfa65962f3cf16b9b3eb08a15954e9d8590")+"'))\n"
137
 
            "(u'subdir', False, GitInventoryDirectory('subdir', u'subdir',"
138
 
            " parent_id='TREE_ROOT', revision='"+default_mapping.revision_id_foreign_to_bzr("69c39cfa65962f3cf16b9b3eb08a15954e9d8590")+"'))\n"
139
 
            "(u'subdir/subfile', False, GitInventoryFile('subdir/subfile',"
 
107
            "('', False, InventoryDirectory('TREE_ROOT', u'', parent_id=None,"
 
108
            " revision='git-experimental-r:69c39cfa65962f3cf16b9b3eb08a15954e9d8590'))\n"
 
109
            "(u'data', False, InventoryFile('data', u'data',"
 
110
            " parent_id='TREE_ROOT',"
 
111
            " sha1='aa785adca3fcdfe1884ae840e13c6d294a2414e8', len=5))\n"
 
112
            "(u'executable', True, InventoryFile('executable', u'executable',"
 
113
            " parent_id='TREE_ROOT',"
 
114
            " sha1='040f06fd774092478d450774f5ba30c5da78acc8', len=7))\n"
 
115
            "(u'link', False, InventoryLink('link', u'link',"
 
116
            " parent_id='TREE_ROOT', revision='git-experimental-r:69c39cfa65962f3cf16b9b3eb08a15954e9d8590'))\n"
 
117
            "(u'subdir', False, InventoryDirectory('subdir', u'subdir',"
 
118
            " parent_id='TREE_ROOT', revision='git-experimental-r:69c39cfa65962f3cf16b9b3eb08a15954e9d8590'))\n"
 
119
            "(u'subdir/subfile', False, InventoryFile('subdir/subfile',"
140
120
            " u'subfile', parent_id='subdir',"
141
 
            " sha1='67b75c3e49f31fcadddbf9df6a1d8be8c3e44290', len=12, revision=git-v1:69c39cfa65962f3cf16b9b3eb08a15954e9d8590))")
 
121
            " sha1='67b75c3e49f31fcadddbf9df6a1d8be8c3e44290', len=12))")
142
122
 
143
123
 
144
124
class TestGitRepository(tests.TestCaseWithTransport):
145
125
 
146
126
    def setUp(self):
147
127
        tests.TestCaseWithTransport.setUp(self)
148
 
        dulwich.repo.Repo.create(self.test_dir)
149
 
        self.git_repo = Repository.open(self.test_dir)
 
128
        git.repo.Repo.create(self.test_dir)
 
129
        self.git_repo = repository.Repository.open(self.test_dir)
150
130
 
151
131
    def test_supports_rich_root(self):
 
132
        # GitRepository.supports_rich_root is False, at least for now.
152
133
        repo = self.git_repo
153
 
        self.assertEqual(repo.supports_rich_root(), True)
 
134
        self.assertEqual(repo.supports_rich_root(), False)
154
135
 
155
136
    def test_get_signature_text(self):
156
137
        self.assertRaises(errors.NoSuchRevision, self.git_repo.get_signature_text, revision.NULL_REVISION)
159
140
        self.assertEquals(False, self.git_repo.has_signature_for_revision_id(revision.NULL_REVISION))
160
141
 
161
142
    def test_all_revision_ids_none(self):
162
 
        self.assertEquals(set([revision.NULL_REVISION]), self.git_repo.all_revision_ids())
 
143
        self.assertEquals(set(), self.git_repo.all_revision_ids())
163
144
 
164
145
    def test_get_ancestry_null(self):
165
 
        self.assertEquals([None, revision.NULL_REVISION], self.git_repo.get_ancestry(revision.NULL_REVISION))
 
146
        self.assertEquals([None], self.git_repo.get_ancestry(revision.NULL_REVISION))
166
147
 
167
148
    def assertIsNullInventory(self, inv):
168
149
        self.assertEqual(inv.root, None)
191
172
 
192
173
    def setUp(self):
193
174
        super(GitRepositoryFormat, self).setUp()
194
 
        self.format = repository.GitRepositoryFormat()
 
175
        self.format = git_repository.GitFormat()
195
176
 
196
177
    def test_get_format_description(self):
197
178
        self.assertEquals("Git Repository", self.format.get_format_description())
198
 
 
199
 
 
200
 
class RevisionGistImportTests(tests.TestCaseWithTransport):
201
 
 
202
 
    def setUp(self):
203
 
        tests.TestCaseWithTransport.setUp(self)
204
 
        self.git_path = os.path.join(self.test_dir, "git")
205
 
        os.mkdir(self.git_path)
206
 
        dulwich.repo.Repo.create(self.git_path)
207
 
        self.git_repo = Repository.open(self.git_path)
208
 
        self.bzr_tree = self.make_branch_and_tree("bzr")
209
 
 
210
 
    def get_inter(self):
211
 
        return InterRepository.get(self.bzr_tree.branch.repository, 
212
 
                                   self.git_repo)
213
 
 
214
 
    def object_iter(self):
215
 
        store = BazaarObjectStore(self.bzr_tree.branch.repository, default_mapping)
216
 
        return MissingObjectsIterator(store, self.bzr_tree.branch.repository)
217
 
 
218
 
    def import_rev(self, revid, parent_lookup=None):
219
 
        return self.object_iter().import_revision(revid)
220
 
 
221
 
    def test_pointless(self):
222
 
        revid = self.bzr_tree.commit("pointless", timestamp=1205433193,
223
 
                timezone=0,
224
 
                  committer="Jelmer Vernooij <jelmer@samba.org>")
225
 
        self.assertEquals("2caa8094a5b794961cd9bf582e3e2bb090db0b14", 
226
 
                self.import_rev(revid))
227
 
        self.assertEquals("2caa8094a5b794961cd9bf582e3e2bb090db0b14", 
228
 
                self.import_rev(revid))