1
# Copyright (C) 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
"""Blackbox tests for the 'brz testament' command"""
21
from breezy.sixish import PY3
22
from breezy.tests.test_testament import (
31
class TestTestament(TestamentSetup):
32
"""Run blackbox tests on 'brz testament'"""
34
def test_testament_command(self):
35
"""Testament containing a file and a directory."""
36
out, err = self.run_bzr('testament --long')
37
self.assertEqualDiff(err, '')
38
self.assertEqualDiff(out, REV_2_TESTAMENT.decode('ascii'))
40
def test_testament_command_2(self):
41
"""Command getting short testament of previous version."""
42
out, err = self.run_bzr('testament -r1')
43
self.assertEqualDiff(err, '')
44
self.assertEqualDiff(out, REV_1_SHORT.decode('ascii'))
46
def test_testament_command_3(self):
47
"""Command getting short testament of previous version."""
48
out, err = self.run_bzr('testament -r1 --strict')
49
self.assertEqualDiff(err, '')
50
self.assertEqualDiff(out, REV_1_SHORT_STRICT.decode('ascii'))
52
def test_testament_non_ascii(self):
53
self.wt.commit(u"Non \xe5ssci message")
54
long_out, err = self.run_bzr_raw('testament --long', encoding='utf-8')
55
self.assertEqualDiff(err, b'')
56
long_out, err = self.run_bzr_raw('testament --long', encoding='ascii')
57
short_out, err = self.run_bzr_raw('testament', encoding='ascii')
58
self.assertEqualDiff(err, b'')
59
sha1_re = re.compile(b'sha1: (?P<sha1>[a-f0-9]+)$', re.M)
60
sha1 = sha1_re.search(short_out).group('sha1')
61
self.assertEqual(sha1, osutils.sha_string(long_out))