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

  • Committer: Jelmer Vernooij
  • Date: 2018-11-16 16:20:27 UTC
  • mto: This revision was merged to the branch mainline in revision 7174.
  • Revision ID: jelmer@jelmer.uk-20181116162027-6v6i0kpyfi54blso
Use addCleanup.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006 Canonical Ltd
 
1
# Copyright (C) 2005-2012, 2016 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
16
16
 
17
17
"""Tests for version_info"""
18
18
 
19
 
from cStringIO import StringIO
20
 
import imp
21
19
import os
22
20
import sys
23
21
 
24
 
from bzrlib import (
25
 
    errors,
 
22
from .. import (
26
23
    registry,
27
 
    symbol_versioning,
28
24
    tests,
29
25
    version_info_formats,
30
26
    )
31
 
from bzrlib.tests import TestCaseWithTransport
32
 
from bzrlib.rio import read_stanzas
33
 
 
34
 
from bzrlib.version_info_formats.format_custom import CustomVersionInfoBuilder
35
 
from bzrlib.version_info_formats.format_rio import RioVersionInfoBuilder
36
 
from bzrlib.version_info_formats.format_python import PythonVersionInfoBuilder
37
 
 
38
 
 
39
 
class TestVersionInfo(TestCaseWithTransport):
 
27
from ..sixish import (
 
28
    BytesIO,
 
29
    StringIO,
 
30
    )
 
31
from . import TestCaseWithTransport
 
32
from ..rio import read_stanzas, read_stanzas_unicode
 
33
 
 
34
from ..version_info_formats.format_custom import (
 
35
    CustomVersionInfoBuilder,
 
36
    MissingTemplateVariable,
 
37
    NoTemplate,
 
38
    )
 
39
from ..version_info_formats.format_rio import RioVersionInfoBuilder
 
40
from ..version_info_formats.format_python import PythonVersionInfoBuilder
 
41
 
 
42
 
 
43
class VersionInfoTestCase(TestCaseWithTransport):
40
44
 
41
45
    def create_branch(self):
42
46
        wt = self.make_branch_and_tree('branch')
43
47
 
44
48
        self.build_tree(['branch/a'])
45
49
        wt.add('a')
46
 
        wt.commit('a', rev_id='r1')
 
50
        wt.commit('a', rev_id=b'r1')
47
51
 
48
52
        self.build_tree(['branch/b'])
49
53
        wt.add('b')
50
 
        wt.commit('b', rev_id='r2')
51
 
 
52
 
        self.build_tree_contents([('branch/a', 'new contents\n')])
53
 
        wt.commit(u'\xe52', rev_id='r3')
54
 
 
55
 
        return wt
 
54
        wt.commit('b', rev_id=b'r2')
 
55
 
 
56
        self.build_tree_contents([('branch/a', b'new contents\n')])
 
57
        wt.commit(u'\xe52', rev_id=b'r3')
 
58
 
 
59
        return wt
 
60
 
 
61
    def create_tree_with_dotted_revno(self):
 
62
        wt = self.make_branch_and_tree('branch')
 
63
        self.build_tree(['branch/a'])
 
64
        wt.add('a')
 
65
        wt.commit('a', rev_id=b'r1')
 
66
 
 
67
        other = wt.controldir.sprout('other').open_workingtree()
 
68
        self.build_tree(['other/b.a'])
 
69
        other.add(['b.a'])
 
70
        other.commit('b.a', rev_id=b'o2')
 
71
 
 
72
        os.chdir('branch')
 
73
        self.run_bzr('merge ../other')
 
74
        wt.commit('merge', rev_id=b'merge')
 
75
 
 
76
        wt.update(revision=b'o2')
 
77
 
 
78
        return wt
 
79
 
 
80
 
 
81
class TestVersionInfoRio(VersionInfoTestCase):
56
82
 
57
83
    def test_rio_null(self):
58
84
        wt = self.make_branch_and_tree('branch')
64
90
        self.assertContainsRe(val, 'build-date:')
65
91
        self.assertContainsRe(val, 'revno: 0')
66
92
 
67
 
    def test_rio_version_text(self):
 
93
    def test_rio_dotted_revno(self):
 
94
        wt = self.create_tree_with_dotted_revno()
 
95
 
 
96
        sio = StringIO()
 
97
        builder = RioVersionInfoBuilder(wt.branch, working_tree=wt)
 
98
        builder.generate(sio)
 
99
        val = sio.getvalue()
 
100
        self.assertContainsRe(val, 'revno: 1.1.1')
 
101
 
 
102
    def regen_text(self, wt, **kwargs):
 
103
        sio = StringIO()
 
104
        builder = RioVersionInfoBuilder(wt.branch, working_tree=wt, **kwargs)
 
105
        builder.generate(sio)
 
106
        val = sio.getvalue()
 
107
        return val
 
108
 
 
109
    def test_simple(self):
68
110
        wt = self.create_branch()
69
111
 
70
 
        def regen(**kwargs):
71
 
            sio = StringIO()
72
 
            builder = RioVersionInfoBuilder(wt.branch, working_tree=wt,
73
 
                                            **kwargs)
74
 
            builder.generate(sio)
75
 
            val = sio.getvalue()
76
 
            return val
77
 
 
78
 
        val = regen()
 
112
        val = self.regen_text(wt)
79
113
        self.assertContainsRe(val, 'build-date:')
80
114
        self.assertContainsRe(val, 'date:')
81
115
        self.assertContainsRe(val, 'revno: 3')
82
116
        self.assertContainsRe(val, 'revision-id: r3')
83
117
 
84
 
        val = regen(check_for_clean=True)
 
118
    def test_clean(self):
 
119
        wt = self.create_branch()
 
120
        val = self.regen_text(wt, check_for_clean=True)
85
121
        self.assertContainsRe(val, 'clean: True')
86
122
 
 
123
    def test_no_clean(self):
 
124
        wt = self.create_branch()
87
125
        self.build_tree(['branch/c'])
88
 
        val = regen(check_for_clean=True)
 
126
        val = self.regen_text(wt, check_for_clean=True)
89
127
        self.assertContainsRe(val, 'clean: False')
90
 
        os.remove('branch/c')
91
 
 
92
 
        val = regen(include_revision_history=True)
 
128
 
 
129
    def test_history(self):
 
130
        wt = self.create_branch()
 
131
 
 
132
        val = self.regen_text(wt, include_revision_history=True)
93
133
        self.assertContainsRe(val, 'id: r1')
94
134
        self.assertContainsRe(val, 'message: a')
95
135
        self.assertContainsRe(val, 'id: r2')
96
136
        self.assertContainsRe(val, 'message: b')
97
137
        self.assertContainsRe(val, 'id: r3')
98
 
        self.assertContainsRe(val, 'message: \xc3\xa52') # utf8 encoding '\xe5'
 
138
        self.assertContainsRe(val, 'message: \xe5')
 
139
 
 
140
    def regen(self, wt, **kwargs):
 
141
        sio = StringIO()
 
142
        builder = RioVersionInfoBuilder(wt.branch, working_tree=wt, **kwargs)
 
143
        builder.generate(sio)
 
144
        sio.seek(0)
 
145
        stanzas = list(read_stanzas_unicode(sio))
 
146
        self.assertEqual(1, len(stanzas))
 
147
        return stanzas[0]
99
148
 
100
149
    def test_rio_version_hook(self):
101
150
        def update_stanza(rev, stanza):
104
153
            'revision', update_stanza, None)
105
154
        wt = self.create_branch()
106
155
 
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()
 
156
        stanza = self.regen(wt)
118
157
        self.assertEqual(['bloe'], stanza.get_all('bla'))
119
158
 
120
 
    def test_rio_version(self):
 
159
    def get_one_stanza(self, stanza, key):
 
160
        new_stanzas = list(read_stanzas(BytesIO(stanza[key].encode('utf8'))))
 
161
        self.assertEqual(1, len(new_stanzas))
 
162
        return new_stanzas[0]
 
163
 
 
164
    def test_build_date(self):
121
165
        wt = self.create_branch()
122
 
 
123
 
        def regen(**kwargs):
124
 
            sio = StringIO()
125
 
            builder = RioVersionInfoBuilder(wt.branch, working_tree=wt,
126
 
                                            **kwargs)
127
 
            builder.generate(sio)
128
 
            sio.seek(0)
129
 
            stanzas = list(read_stanzas(sio))
130
 
            self.assertEqual(1, len(stanzas))
131
 
            return stanzas[0]
132
 
 
133
 
        def get_one_stanza(stanza, key):
134
 
            new_stanzas = list(read_stanzas(
135
 
                                StringIO(stanza[key].encode('utf8'))))
136
 
            self.assertEqual(1, len(new_stanzas))
137
 
            return new_stanzas[0]
138
 
 
139
 
        stanza = regen()
140
 
        self.failUnless('date' in stanza)
141
 
        self.failUnless('build-date' in stanza)
 
166
        stanza = self.regen(wt)
 
167
        self.assertTrue('date' in stanza)
 
168
        self.assertTrue('build-date' in stanza)
142
169
        self.assertEqual(['3'], stanza.get_all('revno'))
143
170
        self.assertEqual(['r3'], stanza.get_all('revision-id'))
144
171
 
145
 
        stanza = regen(check_for_clean=True)
146
 
        self.assertEqual(['True'], stanza.get_all('clean'))
147
 
 
 
172
    def test_not_clean(self):
 
173
        wt = self.create_branch()
148
174
        self.build_tree(['branch/c'])
149
 
        stanza = regen(check_for_clean=True, include_file_revisions=True)
 
175
        stanza = self.regen(wt, check_for_clean=True, include_file_revisions=True)
150
176
        self.assertEqual(['False'], stanza.get_all('clean'))
151
177
 
 
178
    def test_file_revisions(self):
 
179
        wt = self.create_branch()
 
180
        self.build_tree(['branch/c'])
 
181
        stanza = self.regen(wt, check_for_clean=True, include_file_revisions=True)
152
182
        # This assumes it's being run against a tree that does not update the
153
183
        # root revision on every commit.
154
 
        file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
 
184
        file_rev_stanza = self.get_one_stanza(stanza, 'file-revisions')
155
185
        self.assertEqual(['', 'a', 'b', 'c'], file_rev_stanza.get_all('path'))
156
186
        self.assertEqual(['r1', 'r3', 'r2', 'unversioned'],
157
187
            file_rev_stanza.get_all('revision'))
158
 
        os.remove('branch/c')
159
188
 
160
 
        stanza = regen(include_revision_history=True)
161
 
        revision_stanza = get_one_stanza(stanza, 'revisions')
 
189
    def test_revision_history(self):
 
190
        wt = self.create_branch()
 
191
        stanza = self.regen(wt, include_revision_history=True)
 
192
        revision_stanza = self.get_one_stanza(stanza, 'revisions')
162
193
        self.assertEqual(['r1', 'r2', 'r3'], revision_stanza.get_all('id'))
163
194
        self.assertEqual(['a', 'b', u'\xe52'], revision_stanza.get_all('message'))
164
195
        self.assertEqual(3, len(revision_stanza.get_all('date')))
165
196
 
 
197
    def test_file_revisions_with_rename(self):
166
198
        # a was modified, so it should show up modified again
 
199
        wt = self.create_branch()
167
200
        self.build_tree(['branch/a', 'branch/c'])
168
201
        wt.add('c')
169
202
        wt.rename_one('b', 'd')
170
 
        stanza = regen(check_for_clean=True, include_file_revisions=True)
171
 
        file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
 
203
        stanza = self.regen(wt, check_for_clean=True, include_file_revisions=True)
 
204
        file_rev_stanza = self.get_one_stanza(stanza, 'file-revisions')
172
205
        self.assertEqual(['', 'a', 'b', 'c', 'd'],
173
206
                          file_rev_stanza.get_all('path'))
174
207
        self.assertEqual(['r1', 'modified', 'renamed to d', 'new',
175
208
                          'renamed from b'],
176
209
                         file_rev_stanza.get_all('revision'))
177
210
 
178
 
        wt.commit('modified', rev_id='r4')
 
211
    def test_file_revisions_with_removal(self):
 
212
        wt = self.create_branch()
 
213
        self.build_tree(['branch/a', 'branch/c'])
 
214
        wt.add('c')
 
215
        wt.rename_one('b', 'd')
 
216
 
 
217
        wt.commit('modified', rev_id=b'r4')
 
218
 
179
219
        wt.remove(['c', 'd'])
180
220
        os.remove('branch/d')
181
 
        stanza = regen(check_for_clean=True, include_file_revisions=True)
182
 
        file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
 
221
        stanza = self.regen(wt, check_for_clean=True, include_file_revisions=True)
 
222
        file_rev_stanza = self.get_one_stanza(stanza, 'file-revisions')
183
223
        self.assertEqual(['', 'a', 'c', 'd'], file_rev_stanza.get_all('path'))
184
224
        self.assertEqual(['r1', 'r4', 'unversioned', 'removed'],
185
225
                         file_rev_stanza.get_all('revision'))
186
226
 
 
227
    def test_revision(self):
 
228
        wt = self.create_branch()
 
229
        self.build_tree(['branch/a', 'branch/c'])
 
230
        wt.add('c')
 
231
        wt.rename_one('b', 'd')
 
232
 
 
233
        stanza = self.regen(wt, check_for_clean=True,
 
234
            include_file_revisions=True, revision_id=wt.last_revision())
 
235
        file_rev_stanza = self.get_one_stanza(stanza, 'file-revisions')
 
236
        self.assertEqual(['', 'a', 'b'], file_rev_stanza.get_all('path'))
 
237
        self.assertEqual(['r1', 'r3', 'r2'],
 
238
                         file_rev_stanza.get_all('revision'))
 
239
 
 
240
 
 
241
class PythonVersionInfoTests(VersionInfoTestCase):
 
242
 
187
243
    def test_python_null(self):
188
244
        wt = self.make_branch_and_tree('branch')
189
245
 
192
248
        builder.generate(sio)
193
249
        val = sio.getvalue()
194
250
        self.assertContainsRe(val, "'revision_id': None")
195
 
        self.assertContainsRe(val, "'revno': 0")
 
251
        self.assertContainsRe(val, "'revno': '0'")
 
252
        self.assertNotContainsString(val, '\n\n\n\n')
 
253
 
 
254
    def test_python_dotted_revno(self):
 
255
        wt = self.create_tree_with_dotted_revno()
 
256
 
 
257
        sio = StringIO()
 
258
        builder = PythonVersionInfoBuilder(wt.branch, working_tree=wt)
 
259
        builder.generate(sio)
 
260
        val = sio.getvalue()
 
261
        self.assertContainsRe(val, "'revno': '1.1.1'")
 
262
 
 
263
    def regen(self, wt, **kwargs):
 
264
        """Create a test module, import and return it"""
 
265
        builder = PythonVersionInfoBuilder(wt.branch, working_tree=wt,
 
266
                                           **kwargs)
 
267
        outf = StringIO()
 
268
        builder.generate(outf)
 
269
        local_vars = {}
 
270
        exec(outf.getvalue(), {}, local_vars)
 
271
        return local_vars
196
272
 
197
273
    def test_python_version(self):
198
274
        wt = self.create_branch()
199
275
 
200
 
        def regen(**kwargs):
201
 
            """Create a test module, import and return it"""
202
 
            outf = open('test_version_information.py', 'wb')
203
 
            try:
204
 
                builder = PythonVersionInfoBuilder(wt.branch, working_tree=wt,
205
 
                                                   **kwargs)
206
 
                builder.generate(outf)
207
 
            finally:
208
 
                outf.close()
209
 
            module_info = imp.find_module('test_version_information',
210
 
                                          [os.getcwdu()])
211
 
            tvi = imp.load_module('tvi', *module_info)
212
 
            # Make sure the module isn't cached
213
 
            sys.modules.pop('tvi', None)
214
 
            sys.modules.pop('test_version_information', None)
215
 
            # Delete the compiled versions, because we are generating
216
 
            # a new file fast enough that python doesn't detect it
217
 
            # needs to recompile, and using sleep() just makes the
218
 
            # test slow
219
 
            if os.path.exists('test_version_information.pyc'):
220
 
                os.remove('test_version_information.pyc')
221
 
            if os.path.exists('test_version_information.pyo'):
222
 
                os.remove('test_version_information.pyo')
223
 
            return tvi
224
 
 
225
 
        tvi = regen()
226
 
        self.assertEqual(3, tvi.version_info['revno'])
227
 
        self.assertEqual('r3', tvi.version_info['revision_id'])
228
 
        self.failUnless(tvi.version_info.has_key('date'))
229
 
        self.assertEqual(None, tvi.version_info['clean'])
230
 
 
231
 
        tvi = regen(check_for_clean=True)
232
 
        self.assertEqual(True, tvi.version_info['clean'])
 
276
        tvi = self.regen(wt)
 
277
        self.assertEqual('3', tvi['version_info']['revno'])
 
278
        self.assertEqual(b'r3', tvi['version_info']['revision_id'])
 
279
        self.assertTrue('date' in tvi['version_info'])
 
280
        self.assertEqual(None, tvi['version_info']['clean'])
 
281
 
 
282
        tvi = self.regen(wt, check_for_clean=True)
 
283
        self.assertTrue(tvi['version_info']['clean'])
233
284
 
234
285
        self.build_tree(['branch/c'])
235
 
        tvi = regen(check_for_clean=True, include_file_revisions=True)
236
 
        self.assertEqual(False, tvi.version_info['clean'])
 
286
        tvi = self.regen(wt, check_for_clean=True, include_file_revisions=True)
 
287
        self.assertFalse(tvi['version_info']['clean'])
237
288
        self.assertEqual(['', 'a', 'b', 'c'],
238
 
                         sorted(tvi.file_revisions.keys()))
239
 
        self.assertEqual('r3', tvi.file_revisions['a'])
240
 
        self.assertEqual('r2', tvi.file_revisions['b'])
241
 
        self.assertEqual('unversioned', tvi.file_revisions['c'])
 
289
                         sorted(tvi['file_revisions'].keys()))
 
290
        self.assertEqual(b'r3', tvi['file_revisions']['a'])
 
291
        self.assertEqual(b'r2', tvi['file_revisions']['b'])
 
292
        self.assertEqual('unversioned', tvi['file_revisions']['c'])
242
293
        os.remove('branch/c')
243
294
 
244
 
        tvi = regen(include_revision_history=True)
 
295
        tvi = self.regen(wt, include_revision_history=True)
245
296
 
246
297
        rev_info = [(rev, message) for rev, message, timestamp, timezone
247
 
                                   in tvi.revisions]
248
 
        self.assertEqual([('r1', 'a'), ('r2', 'b'), ('r3', u'\xe52')], rev_info)
 
298
                                   in tvi['revisions']]
 
299
        self.assertEqual([(b'r1', 'a'), (b'r2', 'b'), (b'r3', u'\xe52')], rev_info)
249
300
 
250
301
        # a was modified, so it should show up modified again
251
302
        self.build_tree(['branch/a', 'branch/c'])
252
303
        wt.add('c')
253
304
        wt.rename_one('b', 'd')
254
 
        tvi = regen(check_for_clean=True, include_file_revisions=True)
 
305
        tvi = self.regen(wt, check_for_clean=True, include_file_revisions=True)
255
306
        self.assertEqual(['', 'a', 'b', 'c', 'd'],
256
 
                          sorted(tvi.file_revisions.keys()))
257
 
        self.assertEqual('modified', tvi.file_revisions['a'])
258
 
        self.assertEqual('renamed to d', tvi.file_revisions['b'])
259
 
        self.assertEqual('new', tvi.file_revisions['c'])
260
 
        self.assertEqual('renamed from b', tvi.file_revisions['d'])
 
307
                          sorted(tvi['file_revisions'].keys()))
 
308
        self.assertEqual('modified', tvi['file_revisions']['a'])
 
309
        self.assertEqual('renamed to d', tvi['file_revisions']['b'])
 
310
        self.assertEqual('new', tvi['file_revisions']['c'])
 
311
        self.assertEqual('renamed from b', tvi['file_revisions']['d'])
261
312
 
262
 
        wt.commit('modified', rev_id='r4')
 
313
        wt.commit('modified', rev_id=b'r4')
263
314
        wt.remove(['c', 'd'])
264
315
        os.remove('branch/d')
265
 
        tvi = regen(check_for_clean=True, include_file_revisions=True)
 
316
        tvi = self.regen(wt, check_for_clean=True, include_file_revisions=True)
266
317
        self.assertEqual(['', 'a', 'c', 'd'],
267
 
                          sorted(tvi.file_revisions.keys()))
268
 
        self.assertEqual('r4', tvi.file_revisions['a'])
269
 
        self.assertEqual('unversioned', tvi.file_revisions['c'])
270
 
        self.assertEqual('removed', tvi.file_revisions['d'])
 
318
                          sorted(tvi['file_revisions'].keys()))
 
319
        self.assertEqual(b'r4', tvi['file_revisions']['a'])
 
320
        self.assertEqual('unversioned', tvi['file_revisions']['c'])
 
321
        self.assertEqual('removed', tvi['file_revisions']['d'])
 
322
 
 
323
 
 
324
class CustomVersionInfoTests(VersionInfoTestCase):
271
325
 
272
326
    def test_custom_null(self):
273
327
        sio = StringIO()
275
329
        builder = CustomVersionInfoBuilder(wt.branch, working_tree=wt,
276
330
            template='revno: {revno}')
277
331
        builder.generate(sio)
278
 
        self.assertEquals("revno: 0", sio.getvalue())
 
332
        self.assertEqual("revno: 0", sio.getvalue())
279
333
 
280
334
        builder = CustomVersionInfoBuilder(wt.branch, working_tree=wt, 
281
335
            template='{revno} revid: {revision_id}')
282
336
        # revision_id is not available yet
283
 
        self.assertRaises(errors.MissingTemplateVariable, 
284
 
            builder.generate, sio)
285
 
 
286
 
    def test_custom_version_text(self):
 
337
        self.assertRaises(MissingTemplateVariable, builder.generate, sio)
 
338
 
 
339
    def test_custom_dotted_revno(self):
 
340
        sio = StringIO()
 
341
        wt = self.create_tree_with_dotted_revno()
 
342
        builder = CustomVersionInfoBuilder(wt.branch, working_tree=wt, 
 
343
            template='{revno} revid: {revision_id}')
 
344
        builder.generate(sio)
 
345
        self.assertEqual("1.1.1 revid: o2", sio.getvalue())
 
346
 
 
347
    def regen(self, wt, tpl, **kwargs):
 
348
        sio = StringIO()
 
349
        builder = CustomVersionInfoBuilder(wt.branch, working_tree=wt,
 
350
                                           template=tpl, **kwargs)
 
351
        builder.generate(sio)
 
352
        val = sio.getvalue()
 
353
        return val
 
354
 
 
355
    def test_build_date(self):
287
356
        wt = self.create_branch()
288
357
 
289
 
        def regen(tpl, **kwargs):
290
 
            sio = StringIO()
291
 
            builder = CustomVersionInfoBuilder(wt.branch, working_tree=wt,
292
 
                                               template=tpl, **kwargs)
293
 
            builder.generate(sio)
294
 
            val = sio.getvalue()
295
 
            return val
296
 
 
297
 
        val = regen('build-date: "{build_date}"\ndate: "{date}"')
 
358
        val = self.regen(wt, 'build-date: "{build_date}"\ndate: "{date}"')
298
359
        self.assertContainsRe(val, 'build-date: "[0-9-+: ]+"')
299
360
        self.assertContainsRe(val, 'date: "[0-9-+: ]+"')
300
361
 
301
 
        val = regen('revno: {revno}')
 
362
    def test_revno(self):
 
363
        wt = self.create_branch()
 
364
        val = self.regen(wt, 'revno: {revno}')
302
365
        self.assertEqual(val, 'revno: 3')
303
366
 
304
 
        val = regen('revision-id: {revision_id}')
 
367
    def test_revision_id(self):
 
368
        wt = self.create_branch()
 
369
        val = self.regen(wt, 'revision-id: {revision_id}')
305
370
        self.assertEqual(val, 'revision-id: r3')
306
371
 
307
 
        val = regen('clean: {clean}', check_for_clean=True)
 
372
    def test_clean(self):
 
373
        wt = self.create_branch()
 
374
        val = self.regen(wt, 'clean: {clean}', check_for_clean=True)
308
375
        self.assertEqual(val, 'clean: 1')
309
376
 
 
377
    def test_not_clean(self):
 
378
        wt = self.create_branch()
 
379
 
310
380
        self.build_tree(['branch/c'])
311
 
        val = regen('clean: {clean}', check_for_clean=True)
 
381
        val = self.regen(wt, 'clean: {clean}', check_for_clean=True)
312
382
        self.assertEqual(val, 'clean: 0')
313
383
        os.remove('branch/c')
314
384
 
315
385
    def test_custom_without_template(self):
316
386
        builder = CustomVersionInfoBuilder(None)
317
387
        sio = StringIO()
318
 
        self.assertRaises(errors.NoTemplate, builder.generate, sio)
 
388
        self.assertRaises(NoTemplate, builder.generate, sio)
319
389
 
320
390
 
321
391
class TestBuilder(version_info_formats.VersionInfoBuilder):