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

More work on roundtrip push support.

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
 
17
17
"""Tests for GitShaMap."""
18
18
 
 
19
from dulwich.objects import (
 
20
    Blob,
 
21
    Commit,
 
22
    Tree,
 
23
    )
 
24
 
19
25
import os
 
26
import stat
 
27
 
 
28
from bzrlib.inventory import (
 
29
    InventoryFile,
 
30
    InventoryDirectory,
 
31
    ROOT_ID,
 
32
    )
 
33
 
 
34
from bzrlib.revision import (
 
35
    Revision,
 
36
    )
20
37
 
21
38
from bzrlib.tests import (
22
39
    TestCase,
23
40
    TestCaseInTempDir,
24
41
    UnavailableFeature,
25
42
    )
 
43
from bzrlib.transport import (
 
44
    get_transport,
 
45
    )
26
46
 
27
 
from bzrlib.plugins.git.shamap import (
28
 
    DictGitShaMap,
29
 
    SqliteGitShaMap,
30
 
    TdbGitShaMap,
 
47
from bzrlib.plugins.git.cache import (
 
48
    DictBzrGitCache,
 
49
    IndexBzrGitCache,
 
50
    IndexGitCacheFormat,
 
51
    SqliteBzrGitCache,
 
52
    TdbBzrGitCache,
31
53
    )
32
54
 
33
55
class TestGitShaMap:
34
56
 
 
57
    def _get_test_commit(self):
 
58
        c = Commit()
 
59
        c.committer = "Jelmer <jelmer@samba.org>"
 
60
        c.commit_time = 0
 
61
        c.commit_timezone = 0
 
62
        c.author = "Jelmer <jelmer@samba.org>"
 
63
        c.author_time = 0
 
64
        c.author_timezone = 0
 
65
        c.message = "Teh foo bar"
 
66
        c.tree = "cc9462f7f8263ef5adfbeff2fb936bb36b504cba"
 
67
        return c
 
68
 
35
69
    def test_commit(self):
36
70
        self.map.start_write_group()
37
 
        self.map.add_entry("5686645d49063c73d35436192dfc9a160c672301",
38
 
            "commit", ("myrevid", "cc9462f7f8263ef5adfbeff2fb936bb36b504cba"))
 
71
        updater = self.cache.get_updater(Revision("myrevid"))
 
72
        c = self._get_test_commit()
 
73
        updater.add_object(c, {
 
74
            "testament3-sha1": "cc9462f7f8263ef5adf8eff2fb936bb36b504cba"},
 
75
            None)
 
76
        updater.finish()
39
77
        self.map.commit_write_group()
40
78
        self.assertEquals(
41
 
            ("commit", ("myrevid", "cc9462f7f8263ef5adfbeff2fb936bb36b504cba")),
42
 
            self.map.lookup_git_sha("5686645d49063c73d35436192dfc9a160c672301"))
 
79
            ("commit", ("myrevid",
 
80
                "cc9462f7f8263ef5adfbeff2fb936bb36b504cba",
 
81
                {"testament3-sha1": "cc9462f7f8263ef5adf8eff2fb936bb36b504cba"},
 
82
                )),
 
83
            self.map.lookup_git_sha(c.id))
 
84
        self.assertEquals(c.id, self.map.lookup_commit("myrevid"))
43
85
 
44
86
    def test_lookup_notfound(self):
45
87
        self.assertRaises(KeyError,
46
88
            self.map.lookup_git_sha, "5686645d49063c73d35436192dfc9a160c672301")
47
89
 
48
90
    def test_blob(self):
49
 
        thesha = "5686645d49063c73d35436192dfc9a160c672301"
50
91
        self.map.start_write_group()
51
 
        self.map.add_entry(thesha, "blob", ("myfileid", "myrevid"))
 
92
        updater = self.cache.get_updater(Revision("myrevid"))
 
93
        updater.add_object(self._get_test_commit(), { "testament3-sha1": "Test" }, None)
 
94
        b = Blob()
 
95
        b.data = "TEH BLOB"
 
96
        ie = InventoryFile("myfileid", "somename", ROOT_ID)
 
97
        ie.revision = "myrevid"
 
98
        updater.add_object(b, ie, None)
 
99
        updater.finish()
52
100
        self.map.commit_write_group()
53
101
        self.assertEquals(
54
102
            ("blob", ("myfileid", "myrevid")),
55
 
            self.map.lookup_git_sha(thesha))
56
 
        self.assertEquals(thesha, self.map.lookup_blob("myfileid", "myrevid"))
 
103
            self.map.lookup_git_sha(b.id))
 
104
        self.assertEquals(b.id,
 
105
            self.map.lookup_blob_id("myfileid", "myrevid"))
57
106
 
58
107
    def test_tree(self):
59
 
        thesha = "5686645d49063c73d35436192dfc9a160c672301"
60
108
        self.map.start_write_group()
61
 
        self.map.add_entry(thesha,
62
 
            "tree", ("somepath", "myrevid"))
 
109
        updater = self.cache.get_updater(Revision("myrevid"))
 
110
        updater.add_object(self._get_test_commit(), {
 
111
            "testament3-sha1": "mytestamentsha" }, None)
 
112
        t = Tree()
 
113
        t.add(stat.S_IFREG, "somename", Blob().id)
 
114
        ie = InventoryDirectory("fileid", "myname", ROOT_ID)
 
115
        ie.revision = "irrelevant"
 
116
        updater.add_object(t, ie, "")
 
117
        updater.finish()
63
118
        self.map.commit_write_group()
64
 
        self.assertEquals(
65
 
            ("tree", ("somepath", "myrevid")),
66
 
            self.map.lookup_git_sha(thesha))
67
 
        self.assertEquals(thesha, self.map.lookup_tree("somepath", "myrevid"))
 
119
        self.assertEquals(("tree", ("fileid", "myrevid")),
 
120
            self.map.lookup_git_sha(t.id))
 
121
        # It's possible for a backend to not implement lookup_tree
 
122
        try:
 
123
            self.assertEquals(t.id,
 
124
                self.map.lookup_tree_id("fileid", "myrevid"))
 
125
        except NotImplementedError:
 
126
            pass
68
127
 
69
128
    def test_revids(self):
70
129
        self.map.start_write_group()
71
 
        self.map.add_entry("5686645d49063c73d35436192dfc9a160c672301",
72
 
            "commit", ("myrevid", "cc9462f7f8263ef5adfbeff2fb936bb36b504cba"))
 
130
        updater = self.cache.get_updater(Revision("myrevid"))
 
131
        c = self._get_test_commit()
 
132
        updater.add_object(c, {"testament3-sha1": "mtestament"}, None)
 
133
        updater.finish()
73
134
        self.map.commit_write_group()
74
135
        self.assertEquals(["myrevid"], list(self.map.revids()))
75
136
 
 
137
    def test_missing_revisions(self):
 
138
        self.map.start_write_group()
 
139
        updater = self.cache.get_updater(Revision("myrevid"))
 
140
        c = self._get_test_commit()
 
141
        updater.add_object(c, {"testament3-sha1": "testament"}, None)
 
142
        updater.finish()
 
143
        self.map.commit_write_group()
 
144
        self.assertEquals(set(["lala", "bla"]),
 
145
            set(self.map.missing_revisions(["myrevid", "lala", "bla"])))
 
146
 
76
147
 
77
148
class DictGitShaMapTests(TestCase,TestGitShaMap):
78
149
 
79
150
    def setUp(self):
80
151
        TestCase.setUp(self)
81
 
        self.map = DictGitShaMap()
82
 
 
83
 
 
84
 
class SqliteGitShaMapTests(TestCase,TestGitShaMap):
 
152
        self.cache = DictBzrGitCache()
 
153
        self.map = self.cache.idmap
 
154
 
 
155
 
 
156
class SqliteGitShaMapTests(TestCaseInTempDir,TestGitShaMap):
85
157
 
86
158
    def setUp(self):
87
 
        TestCase.setUp(self)
88
 
        self.map = SqliteGitShaMap()
 
159
        TestCaseInTempDir.setUp(self)
 
160
        self.cache = SqliteBzrGitCache(os.path.join(self.test_dir, 'foo.db'))
 
161
        self.map = self.cache.idmap
89
162
 
90
163
 
91
164
class TdbGitShaMapTests(TestCaseInTempDir,TestGitShaMap):
93
166
    def setUp(self):
94
167
        TestCaseInTempDir.setUp(self)
95
168
        try:
96
 
            self.map = TdbGitShaMap(os.path.join(self.test_dir, 'foo.tdb'))
 
169
            self.cache = TdbBzrGitCache(os.path.join(self.test_dir, 'foo.tdb'))
97
170
        except ImportError:
98
171
            raise UnavailableFeature("Missing tdb")
 
172
        self.map = self.cache.idmap
 
173
 
 
174
 
 
175
class IndexGitShaMapTests(TestCaseInTempDir,TestGitShaMap):
 
176
 
 
177
    def setUp(self):
 
178
        TestCaseInTempDir.setUp(self)
 
179
        transport = get_transport(self.test_dir)
 
180
        IndexGitCacheFormat().initialize(transport)
 
181
        self.cache = IndexBzrGitCache(transport)
 
182
        self.map = self.cache.idmap