1
# Copyright (C) 2005, 2006 Canonical Ltd
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
# GNU General Public License for more details.
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17
"""Tests for version_info"""
19
from cStringIO import StringIO
24
from bzrlib.tests import TestCaseWithTransport
25
from bzrlib.rio import read_stanzas
27
# TODO: jam 20051228 When part of bzrlib, this should become
28
# from bzrlib.generate_version_info import foo
30
from bzrlib.version_info_formats.format_rio import RioVersionInfoBuilder
31
from bzrlib.version_info_formats.format_python import PythonVersionInfoBuilder
34
class TestVersionInfo(TestCaseWithTransport):
36
def create_branch(self):
37
wt = self.make_branch_and_tree('branch')
39
self.build_tree(['branch/a'])
41
wt.commit('a', rev_id='r1')
43
self.build_tree(['branch/b'])
45
wt.commit('b', rev_id='r2')
47
open('branch/a', 'wb').write('new contents\n')
48
wt.commit('a2', rev_id='r3')
52
def test_rio_version_text(self):
53
wt = self.create_branch()
57
builder = RioVersionInfoBuilder(wt.branch, working_tree=wt,
64
self.assertContainsRe(val, 'build-date:')
65
self.assertContainsRe(val, 'date:')
66
self.assertContainsRe(val, 'revno: 3')
67
self.assertContainsRe(val, 'revision-id: r3')
69
val = regen(check_for_clean=True)
70
self.assertContainsRe(val, 'clean: True')
72
self.build_tree(['branch/c'])
73
val = regen(check_for_clean=True)
74
self.assertContainsRe(val, 'clean: False')
77
val = regen(include_revision_history=True)
78
self.assertContainsRe(val, 'id: r1')
79
self.assertContainsRe(val, 'message: a')
80
self.assertContainsRe(val, 'id: r2')
81
self.assertContainsRe(val, 'message: b')
82
self.assertContainsRe(val, 'id: r3')
83
self.assertContainsRe(val, 'message: a2')
85
def test_rio_version(self):
86
wt = self.create_branch()
90
builder = RioVersionInfoBuilder(wt.branch, working_tree=wt,
94
stanzas = list(read_stanzas(sio))
95
self.assertEqual(1, len(stanzas))
98
def get_one_stanza(stanza, key):
99
new_stanzas = list(read_stanzas(
100
StringIO(stanza[key].encode('utf8'))))
101
self.assertEqual(1, len(new_stanzas))
102
return new_stanzas[0]
105
self.failUnless('date' in stanza)
106
self.failUnless('build-date' in stanza)
107
self.assertEqual(['3'], stanza.get_all('revno'))
108
self.assertEqual(['r3'], stanza.get_all('revision-id'))
110
stanza = regen(check_for_clean=True)
111
self.assertEqual(['True'], stanza.get_all('clean'))
113
self.build_tree(['branch/c'])
114
stanza = regen(check_for_clean=True, include_file_revisions=True)
115
self.assertEqual(['False'], stanza.get_all('clean'))
117
file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
118
self.assertEqual(['a', 'b', 'c'], file_rev_stanza.get_all('path'))
119
self.assertEqual(['r3', 'r2', 'unversioned'],
120
file_rev_stanza.get_all('revision'))
121
os.remove('branch/c')
123
stanza = regen(include_revision_history=True)
124
revision_stanza = get_one_stanza(stanza, 'revisions')
125
self.assertEqual(['r1', 'r2', 'r3'], revision_stanza.get_all('id'))
126
self.assertEqual(['a', 'b', 'a2'], revision_stanza.get_all('message'))
127
self.assertEqual(3, len(revision_stanza.get_all('date')))
129
# a was modified, so it should show up modified again
130
self.build_tree(['branch/a', 'branch/c'])
132
wt.rename_one('b', 'd')
133
stanza = regen(check_for_clean=True, include_file_revisions=True)
134
file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
135
self.assertEqual(['a', 'b', 'c', 'd'], file_rev_stanza.get_all('path'))
136
self.assertEqual(['modified', 'renamed to d', 'new', 'renamed from b'],
137
file_rev_stanza.get_all('revision'))
139
wt.commit('modified', rev_id='r4')
140
wt.remove(['c', 'd'])
141
os.remove('branch/d')
142
stanza = regen(check_for_clean=True, include_file_revisions=True)
143
file_rev_stanza = get_one_stanza(stanza, 'file-revisions')
144
self.assertEqual(['a', 'c', 'd'], file_rev_stanza.get_all('path'))
145
self.assertEqual(['r4', 'unversioned', 'removed'],
146
file_rev_stanza.get_all('revision'))
148
def test_python_version(self):
149
wt = self.create_branch()
152
outf = open('test_version_information.py', 'wb')
153
builder = PythonVersionInfoBuilder(wt.branch, working_tree=wt,
155
builder.generate(outf)
157
module_info = imp.find_module('test_version_information',
159
tvi = imp.load_module('tvi', *module_info)
160
# Make sure the module isn't cached
161
sys.modules.pop('tvi', None)
162
sys.modules.pop('test_version_information', None)
163
# Delete the compiled versions, because we are generating
164
# a new file fast enough that python doesn't detect it
165
# needs to recompile, and using sleep() just makes the
167
if os.path.exists('test_version_information.pyc'):
168
os.remove('test_version_information.pyc')
169
if os.path.exists('test_version_information.pyo'):
170
os.remove('test_version_information.pyo')
174
self.assertEqual(3, tvi.version_info['revno'])
175
self.assertEqual('r3', tvi.version_info['revision_id'])
176
self.failUnless(tvi.version_info.has_key('date'))
177
self.assertEqual(None, tvi.version_info['clean'])
179
tvi = regen(check_for_clean=True)
180
self.assertEqual(True, tvi.version_info['clean'])
182
self.build_tree(['branch/c'])
183
tvi = regen(check_for_clean=True, include_file_revisions=True)
184
self.assertEqual(False, tvi.version_info['clean'])
185
self.assertEqual(['a', 'b', 'c'], sorted(tvi.file_revisions.keys()))
186
self.assertEqual('r3', tvi.file_revisions['a'])
187
self.assertEqual('r2', tvi.file_revisions['b'])
188
self.assertEqual('unversioned', tvi.file_revisions['c'])
189
os.remove('branch/c')
191
tvi = regen(include_revision_history=True)
193
rev_info = [(rev, message) for rev, message, timestamp, timezone
195
self.assertEqual([('r1', 'a'), ('r2', 'b'), ('r3', 'a2')], rev_info)
197
# a was modified, so it should show up modified again
198
self.build_tree(['branch/a', 'branch/c'])
200
wt.rename_one('b', 'd')
201
tvi = regen(check_for_clean=True, include_file_revisions=True)
202
self.assertEqual(['a', 'b', 'c', 'd'], sorted(tvi.file_revisions.keys()))
203
self.assertEqual('modified', tvi.file_revisions['a'])
204
self.assertEqual('renamed to d', tvi.file_revisions['b'])
205
self.assertEqual('new', tvi.file_revisions['c'])
206
self.assertEqual('renamed from b', tvi.file_revisions['d'])
208
wt.commit('modified', rev_id='r4')
209
wt.remove(['c', 'd'])
210
os.remove('branch/d')
211
tvi = regen(check_for_clean=True, include_file_revisions=True)
212
self.assertEqual(['a', 'c', 'd'], sorted(tvi.file_revisions.keys()))
213
self.assertEqual('r4', tvi.file_revisions['a'])
214
self.assertEqual('unversioned', tvi.file_revisions['c'])
215
self.assertEqual('removed', tvi.file_revisions['d'])