/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 bzrlib/tests/test_version_info.py

  • Committer: Robert Collins
  • Date: 2008-01-25 10:46:10 UTC
  • mto: This revision was merged to the branch mainline in revision 3211.
  • Revision ID: robertc@robertcollins.net-20080125104610-4qweeqqch2feyxdv
 * The ``register-branch`` command will now use the public url of the branch
   containing the current directory, if one has been set and no explicit branch is provided.
   (Robert Collins)

 * New error ``NoPublicBranch`` for commands that need a public branch to
   operate. (Robert Collins)

Show diffs side-by-side

added added

removed removed

Lines of Context:
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
17
"""Tests for version_info"""
18
18
 
22
22
import sys
23
23
 
24
24
from bzrlib import (
25
 
    errors,
26
 
    registry,
27
25
    symbol_versioning,
28
26
    tests,
29
27
    version_info_formats,
54
52
 
55
53
        return wt
56
54
 
57
 
    def test_rio_null(self):
58
 
        wt = self.make_branch_and_tree('branch')
59
 
 
60
 
        sio = StringIO()
61
 
        builder = RioVersionInfoBuilder(wt.branch, working_tree=wt)
62
 
        builder.generate(sio)
63
 
        val = sio.getvalue()
64
 
        self.assertContainsRe(val, 'build-date:')
65
 
        self.assertContainsRe(val, 'revno: 0')
66
 
 
67
55
    def test_rio_version_text(self):
68
56
        wt = self.create_branch()
69
57
 
97
85
        self.assertContainsRe(val, 'id: r3')
98
86
        self.assertContainsRe(val, 'message: \xc3\xa52') # utf8 encoding '\xe5'
99
87
 
100
 
    def test_rio_version_hook(self):
101
 
        def update_stanza(rev, stanza):
102
 
            stanza.add('bla', 'bloe')
103
 
        RioVersionInfoBuilder.hooks.install_named_hook(
104
 
            'revision', update_stanza, None)
105
 
        wt = self.create_branch()
106
 
 
107
 
        def regen(**kwargs):
108
 
            sio = StringIO()
109
 
            builder = RioVersionInfoBuilder(wt.branch, working_tree=wt,
110
 
                                            **kwargs)
111
 
            builder.generate(sio)
112
 
            sio.seek(0)
113
 
            stanzas = list(read_stanzas(sio))
114
 
            self.assertEqual(1, len(stanzas))
115
 
            return stanzas[0]
116
 
 
117
 
        stanza = regen()
118
 
        self.assertEqual(['bloe'], stanza.get_all('bla'))
119
 
 
120
88
    def test_rio_version(self):
121
89
        wt = self.create_branch()
122
90
 
149
117
        stanza = regen(check_for_clean=True, include_file_revisions=True)
150
118
        self.assertEqual(['False'], stanza.get_all('clean'))
151
119
 
152
 
        # This assumes it's being run against a tree that does not update the
153
 
        # root revision on every commit.
 
120
        # XXX: This assumes it's being run against a repository that updates
 
121
        # the root revision on every commit.  Newer ones that use
 
122
        # RootCommitBuilder won't update it on each commit.
154
123
        file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
155
124
        self.assertEqual(['', 'a', 'b', 'c'], file_rev_stanza.get_all('path'))
156
 
        self.assertEqual(['r1', 'r3', 'r2', 'unversioned'],
 
125
        self.assertEqual(['r3', 'r3', 'r2', 'unversioned'],
157
126
            file_rev_stanza.get_all('revision'))
158
127
        os.remove('branch/c')
159
128
 
169
138
        wt.rename_one('b', 'd')
170
139
        stanza = regen(check_for_clean=True, include_file_revisions=True)
171
140
        file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
172
 
        self.assertEqual(['', 'a', 'b', 'c', 'd'],
 
141
        self.assertEqual(['', 'a', 'b', 'c', 'd'], 
173
142
                          file_rev_stanza.get_all('path'))
174
 
        self.assertEqual(['r1', 'modified', 'renamed to d', 'new',
 
143
        self.assertEqual(['r3', 'modified', 'renamed to d', 'new', 
175
144
                          'renamed from b'],
176
145
                         file_rev_stanza.get_all('revision'))
177
146
 
181
150
        stanza = regen(check_for_clean=True, include_file_revisions=True)
182
151
        file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
183
152
        self.assertEqual(['', 'a', 'c', 'd'], file_rev_stanza.get_all('path'))
184
 
        self.assertEqual(['r1', 'r4', 'unversioned', 'removed'],
 
153
        self.assertEqual(['r4', 'r4', 'unversioned', 'removed'],
185
154
                         file_rev_stanza.get_all('revision'))
186
155
 
187
 
    def test_python_null(self):
188
 
        wt = self.make_branch_and_tree('branch')
189
 
 
190
 
        sio = StringIO()
191
 
        builder = PythonVersionInfoBuilder(wt.branch, working_tree=wt)
192
 
        builder.generate(sio)
193
 
        val = sio.getvalue()
194
 
        self.assertContainsRe(val, "'revision_id': None")
195
 
        self.assertContainsRe(val, "'revno': 0")
196
 
 
197
156
    def test_python_version(self):
198
157
        wt = self.create_branch()
199
158
 
234
193
        self.build_tree(['branch/c'])
235
194
        tvi = regen(check_for_clean=True, include_file_revisions=True)
236
195
        self.assertEqual(False, tvi.version_info['clean'])
237
 
        self.assertEqual(['', 'a', 'b', 'c'],
 
196
        self.assertEqual(['', 'a', 'b', 'c'], 
238
197
                         sorted(tvi.file_revisions.keys()))
239
198
        self.assertEqual('r3', tvi.file_revisions['a'])
240
199
        self.assertEqual('r2', tvi.file_revisions['b'])
252
211
        wt.add('c')
253
212
        wt.rename_one('b', 'd')
254
213
        tvi = regen(check_for_clean=True, include_file_revisions=True)
255
 
        self.assertEqual(['', 'a', 'b', 'c', 'd'],
 
214
        self.assertEqual(['', 'a', 'b', 'c', 'd'], 
256
215
                          sorted(tvi.file_revisions.keys()))
257
216
        self.assertEqual('modified', tvi.file_revisions['a'])
258
217
        self.assertEqual('renamed to d', tvi.file_revisions['b'])
263
222
        wt.remove(['c', 'd'])
264
223
        os.remove('branch/d')
265
224
        tvi = regen(check_for_clean=True, include_file_revisions=True)
266
 
        self.assertEqual(['', 'a', 'c', 'd'],
 
225
        self.assertEqual(['', 'a', 'c', 'd'], 
267
226
                          sorted(tvi.file_revisions.keys()))
268
227
        self.assertEqual('r4', tvi.file_revisions['a'])
269
228
        self.assertEqual('unversioned', tvi.file_revisions['c'])
270
229
        self.assertEqual('removed', tvi.file_revisions['d'])
271
230
 
272
 
    def test_custom_null(self):
273
 
        sio = StringIO()
274
 
        wt = self.make_branch_and_tree('branch')
275
 
        builder = CustomVersionInfoBuilder(wt.branch, working_tree=wt,
276
 
            template='revno: {revno}')
277
 
        builder.generate(sio)
278
 
        self.assertEquals("revno: 0", sio.getvalue())
279
 
 
280
 
        builder = CustomVersionInfoBuilder(wt.branch, working_tree=wt, 
281
 
            template='{revno} revid: {revision_id}')
282
 
        # revision_id is not available yet
283
 
        self.assertRaises(errors.MissingTemplateVariable, 
284
 
            builder.generate, sio)
285
 
 
286
231
    def test_custom_version_text(self):
287
232
        wt = self.create_branch()
288
233
 
312
257
        self.assertEqual(val, 'clean: 0')
313
258
        os.remove('branch/c')
314
259
 
315
 
    def test_custom_without_template(self):
316
 
        builder = CustomVersionInfoBuilder(None)
317
 
        sio = StringIO()
318
 
        self.assertRaises(errors.NoTemplate, builder.generate, sio)
319
 
 
320
260
 
321
261
class TestBuilder(version_info_formats.VersionInfoBuilder):
322
262
    pass
326
266
 
327
267
    def setUp(self):
328
268
        super(TestVersionInfoFormatRegistry, self).setUp()
329
 
        self.overrideAttr(version_info_formats,
330
 
                          'format_registry', registry.Registry())
 
269
        registry = version_info_formats.format_registry
 
270
        self._default_key = registry._default_key
 
271
        self._dict = registry._dict.copy()
 
272
        self._help_dict = registry._help_dict.copy()
 
273
        self._info_dict = registry._info_dict.copy()
 
274
        self.addCleanup(self._cleanup)
 
275
 
 
276
    def _cleanup(self):
 
277
        # Restore the registry to pristine state after the test runs
 
278
        registry = version_info_formats.format_registry
 
279
        registry._default_key = self._default_key
 
280
        registry._dict = self._dict
 
281
        registry._help_dict = self._help_dict
 
282
        registry._info_dict = self._info_dict
331
283
 
332
284
    def test_register_remove(self):
333
285
        registry = version_info_formats.format_registry
338
290
                         registry.get_help('testbuilder'))
339
291
        registry.remove('testbuilder')
340
292
        self.assertRaises(KeyError, registry.get, 'testbuilder')
 
293
 
 
294
    def test_old_functions(self):
 
295
        self.applyDeprecated(symbol_versioning.one_zero,
 
296
            version_info_formats.register_builder,
 
297
            'test-builder', __name__, 'TestBuilder')
 
298
        formats = self.applyDeprecated(symbol_versioning.one_zero,
 
299
            version_info_formats.get_builder_formats)
 
300
        self.failUnless('test-builder' in formats)
 
301
        self.assertIs(TestBuilder,
 
302
            self.applyDeprecated(symbol_versioning.one_zero,
 
303
                version_info_formats.get_builder, 'test-builder'))
 
304
        version_info_formats.format_registry.remove('test-builder')