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

  • Committer: Jelmer Vernooij
  • Date: 2009-03-28 22:27:07 UTC
  • mto: (0.200.305 trunk)
  • mto: This revision was merged to the branch mainline in revision 6960.
  • Revision ID: jelmer@samba.org-20090328222707-n0y980ntev40xqd2
Fix blob lookup.

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
 
    )
 
19
import dulwich as git
23
20
import os
24
21
 
25
22
from bzrlib import (
28
25
    revision,
29
26
    )
30
27
from bzrlib.repository import (
31
 
    InterRepository,
32
28
    Repository,
33
29
    )
34
30
 
40
36
from bzrlib.plugins.git.mapping import (
41
37
    default_mapping,
42
38
    )
43
 
from bzrlib.plugins.git.object_store import (
44
 
    BazaarObjectStore,
45
 
    )
46
 
from bzrlib.plugins.git.push import (
47
 
    MissingObjectsIterator,
48
 
    )
49
39
 
50
40
class TestGitRepositoryFeatures(tests.TestCaseInTempDir):
51
41
    """Feature tests for GitRepository."""
52
42
 
53
 
    def _do_commit(self):
54
 
        builder = tests.GitBranchBuilder()
55
 
        builder.set_file('a', 'text for a\n', False)
56
 
        commit_handle = builder.commit('Joe Foo <joe@foo.com>', u'message')
57
 
        mapping = builder.finish()
58
 
        return mapping[commit_handle]
 
43
    _test_needs_features = [tests.GitCommandFeature]
59
44
 
60
45
    def test_open_existing(self):
61
 
        GitRepo.init(self.test_dir)
 
46
        tests.run_git('init')
62
47
 
63
48
        repo = Repository.open('.')
64
49
        self.assertIsInstance(repo, repository.GitRepository)
65
50
 
66
51
    def test_has_git_repo(self):
67
 
        GitRepo.init(self.test_dir)
68
 
 
69
 
        repo = Repository.open('.')
70
 
        self.assertIsInstance(repo._git, dulwich.repo.BaseRepo)
71
 
 
72
 
    def test_has_revision(self):
73
 
        GitRepo.init(self.test_dir)
74
 
        commit_id = self._do_commit()
75
 
        repo = Repository.open('.')
76
 
        self.assertFalse(repo.has_revision('foobar'))
77
 
        revid = default_mapping.revision_id_foreign_to_bzr(commit_id)
78
 
        self.assertTrue(repo.has_revision(revid))
79
 
 
80
 
    def test_has_revisions(self):
81
 
        GitRepo.init(self.test_dir)
82
 
        commit_id = self._do_commit()
83
 
        repo = Repository.open('.')
84
 
        self.assertEquals(set(), repo.has_revisions(['foobar']))
85
 
        revid = default_mapping.revision_id_foreign_to_bzr(commit_id)
86
 
        self.assertEquals(set([revid]), repo.has_revisions(['foobar', revid]))
 
52
        tests.run_git('init')
 
53
 
 
54
        repo = Repository.open('.')
 
55
        self.assertIsInstance(repo._git, git.repo.Repo)
87
56
 
88
57
    def test_get_revision(self):
89
58
        # GitRepository.get_revision gives a Revision object.
90
59
 
91
60
        # Create a git repository with a revision.
92
 
        GitRepo.init(self.test_dir)
93
 
        commit_id = self._do_commit()
 
61
        tests.run_git('init')
 
62
        builder = tests.GitBranchBuilder()
 
63
        builder.set_file('a', 'text for a\n', False)
 
64
        commit_handle = builder.commit('Joe Foo <joe@foo.com>', u'message')
 
65
        mapping = builder.finish()
 
66
        commit_id = mapping[commit_handle]
94
67
 
95
68
        # Get the corresponding Revision object.
96
69
        revid = default_mapping.revision_id_foreign_to_bzr(commit_id)
99
72
        self.assertIsInstance(rev, revision.Revision)
100
73
 
101
74
    def test_get_revision_unknown(self):
102
 
        GitRepo.init(self.test_dir)
 
75
        tests.run_git('init')
103
76
 
104
77
        repo = Repository.open('.')
105
78
        self.assertRaises(errors.NoSuchRevision, repo.get_revision, "bla")
106
79
 
107
80
    def simple_commit(self):
108
81
        # Create a git repository with some interesting files in a revision.
109
 
        GitRepo.init(self.test_dir)
 
82
        tests.run_git('init')
110
83
        builder = tests.GitBranchBuilder()
111
84
        builder.set_file('data', 'text\n', False)
112
85
        builder.set_file('executable', 'content', True)
117
90
        mapping = builder.finish()
118
91
        return mapping[commit_handle]
119
92
 
120
 
    def test_pack(self):
121
 
        commit_id = self.simple_commit()
122
 
        repo = Repository.open('.')
123
 
        repo.pack()
124
 
 
125
93
    def test_revision_tree(self):
126
94
        commit_id = self.simple_commit()
127
95
        revid = default_mapping.revision_id_foreign_to_bzr(commit_id)
146
114
            for path, entry in inv.iter_entries())
147
115
        self.assertEqualDiff(
148
116
            printed_inv,
149
 
            "('', False, GitInventoryDirectory('TREE_ROOT', u'', parent_id=None,"
 
117
            "('', False, InventoryDirectory('TREE_ROOT', u'', parent_id=None,"
150
118
            " revision='"+default_mapping.revision_id_foreign_to_bzr("69c39cfa65962f3cf16b9b3eb08a15954e9d8590")+"'))\n"
151
 
            "(u'data', False, GitInventoryFile('data', u'data',"
152
 
            " parent_id='TREE_ROOT',"
153
 
            " sha1='aa785adca3fcdfe1884ae840e13c6d294a2414e8', len=5, revision="+default_mapping.revid_prefix+":69c39cfa65962f3cf16b9b3eb08a15954e9d8590))\n"
154
 
            "(u'executable', True, GitInventoryFile('executable', u'executable',"
155
 
            " parent_id='TREE_ROOT',"
156
 
            " sha1='040f06fd774092478d450774f5ba30c5da78acc8', len=7, revision="+default_mapping.revid_prefix+":69c39cfa65962f3cf16b9b3eb08a15954e9d8590))\n"
157
 
            "(u'link', False, GitInventoryLink('link', u'link',"
158
 
            " parent_id='TREE_ROOT', revision='"+default_mapping.revision_id_foreign_to_bzr("69c39cfa65962f3cf16b9b3eb08a15954e9d8590")+"'))\n"
159
 
            "(u'subdir', False, GitInventoryDirectory('subdir', u'subdir',"
160
 
            " parent_id='TREE_ROOT', revision='"+default_mapping.revision_id_foreign_to_bzr("69c39cfa65962f3cf16b9b3eb08a15954e9d8590")+"'))\n"
161
 
            "(u'subdir/subfile', False, GitInventoryFile('subdir/subfile',"
 
119
            "(u'data', False, InventoryFile('data', u'data',"
 
120
            " parent_id='TREE_ROOT',"
 
121
            " sha1='aa785adca3fcdfe1884ae840e13c6d294a2414e8', len=5))\n"
 
122
            "(u'executable', True, InventoryFile('executable', u'executable',"
 
123
            " parent_id='TREE_ROOT',"
 
124
            " sha1='040f06fd774092478d450774f5ba30c5da78acc8', len=7))\n"
 
125
            "(u'link', False, InventoryLink('link', u'link',"
 
126
            " parent_id='TREE_ROOT', revision='"+default_mapping.revision_id_foreign_to_bzr("69c39cfa65962f3cf16b9b3eb08a15954e9d8590")+"'))\n"
 
127
            "(u'subdir', False, InventoryDirectory('subdir', u'subdir',"
 
128
            " parent_id='TREE_ROOT', revision='"+default_mapping.revision_id_foreign_to_bzr("69c39cfa65962f3cf16b9b3eb08a15954e9d8590")+"'))\n"
 
129
            "(u'subdir/subfile', False, InventoryFile('subdir/subfile',"
162
130
            " u'subfile', parent_id='subdir',"
163
 
            " sha1='67b75c3e49f31fcadddbf9df6a1d8be8c3e44290', len=12, revision="+default_mapping.revid_prefix+":69c39cfa65962f3cf16b9b3eb08a15954e9d8590))")
 
131
            " sha1='67b75c3e49f31fcadddbf9df6a1d8be8c3e44290', len=12))")
164
132
 
165
133
 
166
134
class TestGitRepository(tests.TestCaseWithTransport):
167
135
 
168
 
    def _do_commit(self):
169
 
        builder = tests.GitBranchBuilder()
170
 
        builder.set_file('a', 'text for a\n', False)
171
 
        commit_handle = builder.commit('Joe Foo <joe@foo.com>', u'message')
172
 
        mapping = builder.finish()
173
 
        return mapping[commit_handle]
174
 
 
175
136
    def setUp(self):
176
137
        tests.TestCaseWithTransport.setUp(self)
177
 
        dulwich.repo.Repo.create(self.test_dir)
 
138
        git.repo.Repo.create(self.test_dir)
178
139
        self.git_repo = Repository.open(self.test_dir)
179
140
 
180
141
    def test_supports_rich_root(self):
188
149
        self.assertEquals(False, self.git_repo.has_signature_for_revision_id(revision.NULL_REVISION))
189
150
 
190
151
    def test_all_revision_ids_none(self):
191
 
        self.assertEquals(set([]), self.git_repo.all_revision_ids())
192
 
 
193
 
    def test_all_revision_ids(self):
194
 
        commit_id = self._do_commit()
195
 
        self.assertEquals(
196
 
                set([default_mapping.revision_id_foreign_to_bzr(commit_id)]),
197
 
                self.git_repo.all_revision_ids())
 
152
        self.assertEquals(set([revision.NULL_REVISION]), self.git_repo.all_revision_ids())
198
153
 
199
154
    def test_get_ancestry_null(self):
200
155
        self.assertEquals([None, revision.NULL_REVISION], self.git_repo.get_ancestry(revision.NULL_REVISION))
238
193
        tests.TestCaseWithTransport.setUp(self)
239
194
        self.git_path = os.path.join(self.test_dir, "git")
240
195
        os.mkdir(self.git_path)
241
 
        dulwich.repo.Repo.create(self.git_path)
 
196
        git.repo.Repo.create(self.git_path)
242
197
        self.git_repo = Repository.open(self.git_path)
243
198
        self.bzr_tree = self.make_branch_and_tree("bzr")
244
199
 
245
 
    def get_inter(self):
246
 
        return InterRepository.get(self.bzr_tree.branch.repository, 
247
 
                                   self.git_repo)
248
 
 
249
 
    def object_iter(self):
250
 
        store = BazaarObjectStore(self.bzr_tree.branch.repository, default_mapping)
251
 
        store_iterator = MissingObjectsIterator(store, self.bzr_tree.branch.repository)
252
 
        return store, store_iterator
253
 
 
254
200
    def import_rev(self, revid, parent_lookup=None):
255
 
        store, store_iter = self.object_iter()
256
 
        store._cache.idmap.start_write_group()
257
 
        try:
258
 
            return store_iter.import_revision(revid, roundtrip=False)
259
 
        except:
260
 
            store._cache.idmap.abort_write_group()
261
 
            raise
262
 
        else:
263
 
            store._cache.idmap.commit_write_group()
 
201
        return self.git_repo.import_revision_gist(
 
202
            self.bzr_tree.branch.repository, revid, parent_lookup)
264
203
 
265
204
    def test_pointless(self):
266
205
        revid = self.bzr_tree.commit("pointless", timestamp=1205433193,
267
 
                timezone=0,
268
206
                  committer="Jelmer Vernooij <jelmer@samba.org>")
269
207
        self.assertEquals("2caa8094a5b794961cd9bf582e3e2bb090db0b14", 
270
208
                self.import_rev(revid))
271
209
        self.assertEquals("2caa8094a5b794961cd9bf582e3e2bb090db0b14", 
272
210
                self.import_rev(revid))
273
 
 
274
 
 
275
 
class ForeignTestsRepositoryFactory(object):
276
 
 
277
 
    def make_repository(self, transport):
278
 
        return dir.LocalGitControlDirFormat().initialize_on_transport(transport).open_repository()