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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
17
"""Test testaments for gpg signing."""
19
19
# TODO: Testaments with x-bits
24
from bzrlib.tests import TestCaseWithTransport
25
from bzrlib.testament import Testament, StrictTestament
23
from bzrlib import osutils
24
from bzrlib.tests import SymlinkFeature, TestCaseWithTransport
25
from bzrlib.testament import (
26
30
from bzrlib.transform import TreeTransform
27
from bzrlib.osutils import has_symlinks
30
33
class TestamentSetup(TestCaseWithTransport):
33
36
super(TestamentSetup, self).setUp()
34
self.wt = self.make_branch_and_tree('.')
37
self.wt = self.make_branch_and_tree('.', format='dirstate-with-subtree')
38
self.wt.set_root_id('TREE_ROT')
35
39
b = self.b = self.wt.branch
36
40
b.nick = "test branch"
37
41
self.wt.commit(message='initial null commit',
58
62
class TestamentTests(TestamentSetup):
64
def testament_class(self):
67
def expected(self, key):
68
return texts[self.testament_class()][key]
70
def from_revision(self, repository, revision_id):
71
return self.testament_class().from_revision(repository, revision_id)
60
73
def test_null_testament(self):
61
74
"""Testament for a revision with no contents."""
62
t = Testament.from_revision(self.b.repository, 'test@user-1')
75
t = self.from_revision(self.b.repository, 'test@user-1')
63
76
ass = self.assertTrue
64
77
eq = self.assertEqual
65
78
ass(isinstance(t, Testament))
71
84
def test_testment_text_form(self):
72
85
"""Conversion of testament to canonical text form."""
73
t = Testament.from_revision(self.b.repository, 'test@user-1')
74
text_form = t.as_text()
75
self.log('testament text form:\n' + text_form)
76
self.assertEqual(text_form, REV_1_TESTAMENT)
78
def test_strict_testment_text_form(self):
79
"""Conversion of testament to canonical text form."""
80
t = StrictTestament.from_revision(self.b.repository, 'test@user-1')
81
text_form = t.as_text()
82
self.log('testament text form:\n' + text_form)
83
self.assertEqualDiff(text_form, REV_1_STRICT_TESTAMENT)
86
t = self.from_revision(self.b.repository, 'test@user-1')
87
text_form = t.as_text()
88
self.log('testament text form:\n' + text_form)
89
self.assertEqualDiff(text_form, self.expected('rev_1'))
90
short_text_form = t.as_short_text()
91
self.assertEqualDiff(short_text_form, self.expected('rev_1_short'))
85
93
def test_testament_with_contents(self):
86
94
"""Testament containing a file and a directory."""
87
t = Testament.from_revision(self.b.repository, 'test@user-2')
88
text_form = t.as_text()
89
self.log('testament text form:\n' + text_form)
90
self.assertEqualDiff(text_form, REV_2_TESTAMENT)
91
actual_short = t.as_short_text()
92
self.assertEqualDiff(actual_short, REV_2_SHORT)
94
def test_strict_testament_with_contents(self):
95
"""Testament containing a file and a directory."""
96
t = StrictTestament.from_revision(self.b.repository, 'test@user-2')
97
text_form = t.as_text()
98
self.log('testament text form:\n' + text_form)
99
self.assertEqualDiff(text_form, REV_2_STRICT_TESTAMENT)
100
actual_short = t.as_short_text()
101
self.assertEqualDiff(actual_short, REV_2_SHORT_STRICT)
95
t = self.from_revision(self.b.repository, 'test@user-2')
96
text_form = t.as_text()
97
self.log('testament text form:\n' + text_form)
98
self.assertEqualDiff(text_form, self.expected('rev_2'))
99
actual_short = t.as_short_text()
100
self.assertEqualDiff(actual_short, self.expected('rev_2_short'))
103
102
def test_testament_symlinks(self):
104
103
"""Testament containing symlink (where possible)"""
105
if not has_symlinks():
104
self.requireFeature(SymlinkFeature)
107
105
os.symlink('wibble/linktarget', 'link')
108
106
self.wt.add(['link'], ['link-id'])
109
107
self.wt.commit(message='add symlink',
112
110
rev_id='test@user-3',
113
111
committer='test@user')
114
t = Testament.from_revision(self.b.repository, 'test@user-3')
115
self.assertEqualDiff(t.as_text(), REV_3_TESTAMENT)
112
t = self.from_revision(self.b.repository, 'test@user-3')
113
self.assertEqualDiff(t.as_text(), self.expected('rev_3'))
117
115
def test_testament_revprops(self):
118
116
"""Testament to revision with extra properties"""
126
124
rev_id='test@user-3',
127
125
committer='test@user',
129
t = Testament.from_revision(self.b.repository, 'test@user-3')
130
self.assertEqualDiff(t.as_text(), REV_PROPS_TESTAMENT)
127
t = self.from_revision(self.b.repository, 'test@user-3')
128
self.assertEqualDiff(t.as_text(), self.expected('rev_props'))
132
130
def test_testament_unicode_commit_message(self):
135
133
timestamp=1129025493,
137
135
rev_id='test@user-3',
138
committer='Erik B\xe5gfors <test@user>',
136
committer=u'Erik B\xe5gfors <test@user>',
139
137
revprops={'uni':u'\xb5'}
141
t = Testament.from_revision(self.b.repository, 'test@user-3')
139
t = self.from_revision(self.b.repository, 'test@user-3')
142
140
self.assertEqualDiff(
143
SAMPLE_UNICODE_TESTAMENT.encode('utf-8'), t.as_text())
141
self.expected('sample_unicode').encode('utf-8'), t.as_text())
143
def test_from_tree(self):
144
tree = self.b.repository.revision_tree('test@user-2')
145
testament = self.testament_class().from_revision_tree(tree)
146
text_1 = testament.as_short_text()
147
text_2 = self.from_revision(self.b.repository,
148
'test@user-2').as_short_text()
149
self.assertEqual(text_1, text_2)
145
151
def test___init__(self):
146
152
revision = self.b.repository.get_revision('test@user-2')
147
inventory = self.b.repository.get_inventory('test@user-2')
148
testament_1 = Testament(revision, inventory).as_short_text()
149
testament_2 = Testament.from_revision(self.b.repository,
150
'test@user-2').as_short_text()
151
self.assertEqual(testament_1, testament_2)
153
tree = self.b.repository.revision_tree('test@user-2')
154
testament_1 = self.testament_class()(revision, tree)
155
text_1 = testament_1.as_short_text()
156
text_2 = self.from_revision(self.b.repository,
157
'test@user-2').as_short_text()
158
self.assertEqual(text_1, text_2)
161
class TestamentTestsStrict(TestamentTests):
163
def testament_class(self):
164
return StrictTestament
167
class TestamentTestsStrict2(TestamentTests):
169
def testament_class(self):
170
return StrictTestament3
154
173
REV_1_TESTAMENT = """\
155
174
bazaar-ng testament version 1
205
REV_1_STRICT_TESTAMENT3 = """\
206
bazaar testament version 3 strict
207
revision-id: test@user-1
209
timestamp: 1129025423
215
directory . TREE_ROT test@user-1 no
185
222
REV_1_SHORT = """\
186
223
bazaar-ng testament short form 1
187
224
revision-id: test@user-1
189
""" % sha(REV_1_TESTAMENT).hexdigest()
226
""" % osutils.sha(REV_1_TESTAMENT).hexdigest()
192
229
REV_1_SHORT_STRICT = """\
193
230
bazaar-ng testament short form 2.1
194
231
revision-id: test@user-1
196
""" % sha(REV_1_STRICT_TESTAMENT).hexdigest()
233
""" % osutils.sha(REV_1_STRICT_TESTAMENT).hexdigest()
236
REV_1_SHORT_STRICT3 = """\
237
bazaar testament short form 3 strict
238
revision-id: test@user-1
240
""" % osutils.sha(REV_1_STRICT_TESTAMENT3).hexdigest()
199
243
REV_2_TESTAMENT = """\
283
REV_2_STRICT_TESTAMENT3 = """\
284
bazaar testament version 3 strict
285
revision-id: test@user-2
287
timestamp: 1129025483
292
add files and directories
294
directory . TREE_ROT test@user-1 no
295
file hello hello-id 34dd0ac19a24bf80c4d33b5c8960196e8d8d1f73 test@user-2 yes
296
directory src src-id test@user-2 no
297
file src/foo.c foo.c-id a2a049c20f908ae31b231d98779eb63c66448f24 test@user-2 no
239
304
REV_2_SHORT = """\
240
305
bazaar-ng testament short form 1
241
306
revision-id: test@user-2
243
""" % sha(REV_2_TESTAMENT).hexdigest()
308
""" % osutils.sha(REV_2_TESTAMENT).hexdigest()
246
311
REV_2_SHORT_STRICT = """\
247
312
bazaar-ng testament short form 2.1
248
313
revision-id: test@user-2
250
""" % sha(REV_2_STRICT_TESTAMENT).hexdigest()
315
""" % osutils.sha(REV_2_STRICT_TESTAMENT).hexdigest()
318
REV_2_SHORT_STRICT3 = """\
319
bazaar testament short form 3 strict
320
revision-id: test@user-2
322
""" % osutils.sha(REV_2_STRICT_TESTAMENT3).hexdigest()
253
325
REV_PROPS_TESTAMENT = """\
351
REV_PROPS_TESTAMENT_STRICT = """\
352
bazaar-ng testament version 2.1
353
revision-id: test@user-3
355
timestamp: 1129025493
360
revision with properties
362
file hello hello-id 34dd0ac19a24bf80c4d33b5c8960196e8d8d1f73 test@user-2 yes
363
directory src src-id test@user-2 no
364
file src/foo.c foo.c-id a2a049c20f908ae31b231d98779eb63c66448f24 test@user-2 no
377
REV_PROPS_TESTAMENT_STRICT3 = """\
378
bazaar testament version 3 strict
379
revision-id: test@user-3
381
timestamp: 1129025493
386
revision with properties
388
directory . TREE_ROT test@user-1 no
389
file hello hello-id 34dd0ac19a24bf80c4d33b5c8960196e8d8d1f73 test@user-2 yes
390
directory src src-id test@user-2 no
391
file src/foo.c foo.c-id a2a049c20f908ae31b231d98779eb63c66448f24 test@user-2 no
279
404
REV_3_TESTAMENT = """\
280
405
bazaar-ng testament version 1
281
406
revision-id: test@user-3
425
REV_3_TESTAMENT_STRICT = """\
426
bazaar-ng testament version 2.1
427
revision-id: test@user-3
429
timestamp: 1129025493
436
file hello hello-id 34dd0ac19a24bf80c4d33b5c8960196e8d8d1f73 test@user-2 yes
437
symlink link link-id wibble/linktarget test@user-3 no
438
directory src src-id test@user-2 no
439
file src/foo.c foo.c-id a2a049c20f908ae31b231d98779eb63c66448f24 test@user-2 no
446
REV_3_TESTAMENT_STRICT3 = """\
447
bazaar testament version 3 strict
448
revision-id: test@user-3
450
timestamp: 1129025493
457
directory . TREE_ROT test@user-1 no
458
file hello hello-id 34dd0ac19a24bf80c4d33b5c8960196e8d8d1f73 test@user-2 yes
459
symlink link link-id wibble/linktarget test@user-3 no
460
directory src src-id test@user-2 no
461
file src/foo.c foo.c-id a2a049c20f908ae31b231d98779eb63c66448f24 test@user-2 no
300
468
SAMPLE_UNICODE_TESTAMENT = u"""\
301
469
bazaar-ng testament version 1
302
470
revision-id: test@user-3
490
SAMPLE_UNICODE_TESTAMENT_STRICT = u"""\
491
bazaar-ng testament version 2.1
492
revision-id: test@user-3
493
committer: Erik B\xe5gfors <test@user>
494
timestamp: 1129025493
499
non-ascii commit \N{COPYRIGHT SIGN} me
501
file hello hello-id 34dd0ac19a24bf80c4d33b5c8960196e8d8d1f73 test@user-2 yes
502
directory src src-id test@user-2 no
503
file src/foo.c foo.c-id a2a049c20f908ae31b231d98779eb63c66448f24 test@user-2 no
512
SAMPLE_UNICODE_TESTAMENT_STRICT3 = u"""\
513
bazaar testament version 3 strict
514
revision-id: test@user-3
515
committer: Erik B\xe5gfors <test@user>
516
timestamp: 1129025493
521
non-ascii commit \N{COPYRIGHT SIGN} me
523
directory . TREE_ROT test@user-1 no
524
file hello hello-id 34dd0ac19a24bf80c4d33b5c8960196e8d8d1f73 test@user-2 yes
525
directory src src-id test@user-2 no
526
file src/foo.c foo.c-id a2a049c20f908ae31b231d98779eb63c66448f24 test@user-2 no
536
Testament: { 'rev_1': REV_1_TESTAMENT,
537
'rev_1_short': REV_1_SHORT,
538
'rev_2': REV_2_TESTAMENT,
539
'rev_2_short': REV_2_SHORT,
540
'rev_3': REV_3_TESTAMENT,
541
'rev_props': REV_PROPS_TESTAMENT,
542
'sample_unicode': SAMPLE_UNICODE_TESTAMENT,
544
StrictTestament: {'rev_1': REV_1_STRICT_TESTAMENT,
545
'rev_1_short': REV_1_SHORT_STRICT,
546
'rev_2': REV_2_STRICT_TESTAMENT,
547
'rev_2_short': REV_2_SHORT_STRICT,
548
'rev_3': REV_3_TESTAMENT_STRICT,
549
'rev_props': REV_PROPS_TESTAMENT_STRICT,
550
'sample_unicode': SAMPLE_UNICODE_TESTAMENT_STRICT,
552
StrictTestament3: {'rev_1': REV_1_STRICT_TESTAMENT3,
553
'rev_1_short': REV_1_SHORT_STRICT3,
554
'rev_2': REV_2_STRICT_TESTAMENT3,
555
'rev_2_short': REV_2_SHORT_STRICT3,
556
'rev_3': REV_3_TESTAMENT_STRICT3,
557
'rev_props': REV_PROPS_TESTAMENT_STRICT3,
558
'sample_unicode': SAMPLE_UNICODE_TESTAMENT_STRICT3,