36
36
tree = self.make_branch_and_tree('tree')
37
37
self.build_tree(['tree/a'])
39
tree.commit(u'Unicode \xb5 commit', rev_id='r1',
39
tree.commit(u'Unicode \xb5 commit', rev_id=b'r1',
40
40
committer=u'\u062c\u0648\u062c\u0648'
41
41
u' Meinel <juju@info.com>',
42
42
timestamp=1156451297.96, timezone=0)
45
def run_log_quiet_long(self, args, env_changes={}):
46
cmd = ['--no-aliases', '--no-plugins', '-Oprogress_bar=none',
47
'log', '-q', '--log-format=long']
49
return self.run_bzr_subprocess(cmd, env_changes=env_changes)
51
@unittest.skipIf(sys.version_info[:2] < (3, 7), "python < 3.7 doesn't coerce utf-8")
52
def test_log_coerced_utf8(self):
53
self.disable_missing_extensions_warning()
54
out, err = self.run_log_quiet_long(
56
# C is not necessarily the default locale, so set both LANG and
57
# LC_ALL explicitly because LC_ALL is preferred on (some?) Linux
58
# systems but only LANG is respected on Windows.
60
'LANG': 'C', 'LC_ALL': 'C', 'LC_CTYPE': None, 'LANGUAGE': None})
61
self.assertEqual(b'', err)
62
self.assertEqualDiff(b"""\
63
------------------------------------------------------------
65
committer: \xd8\xac\xd9\x88\xd8\xac\xd9\x88 Meinel <juju@info.com>
67
timestamp: Thu 2006-08-24 20:28:17 +0000
69
Unicode \xc2\xb5 commit
45
72
def test_log_C(self):
46
73
self.disable_missing_extensions_warning()
47
out, err = self.run_bzr_subprocess(
48
'--no-aliases --no-plugins log -q --log-format=long tree',
49
env_changes={'LANG':'C', 'BZR_PROGRESS_BAR':'none',
50
'LC_ALL':None, 'LC_CTYPE':None, 'LANGUAGE':None})
51
self.assertEqual('', err)
52
self.assertEqualDiff("""\
74
out, err = self.run_log_quiet_long(
76
# C is not necessarily the default locale, so set both LANG and
77
# LC_ALL explicitly because LC_ALL is preferred on (some?) Linux
78
# systems but only LANG is respected on Windows.
80
'LANG': 'C', 'LC_ALL': 'C', 'LC_CTYPE': None,
81
'LANGUAGE': None, 'PYTHONCOERCECLOCALE': '0', 'PYTHONUTF8': '0'})
82
self.assertEqual(b'', err)
83
self.assertEqualDiff(b"""\
53
84
------------------------------------------------------------
55
86
committer: ???? Meinel <juju@info.com>
62
93
def test_log_BOGUS(self):
63
out, err = self.run_bzr_subprocess(
64
'--no-aliases --no-plugins log -q --log-format=long tree',
65
env_changes={'LANG':'BOGUS', 'BZR_PROGRESS_BAR':'none',
66
'LC_ALL':None, 'LC_CTYPE':None, 'LANGUAGE':None})
67
self.assertStartsWith(err, 'bzr: warning: unsupported locale setting')
68
self.assertEqualDiff("""\
94
out, err = self.run_log_quiet_long(
96
env_changes={'LANG': 'BOGUS', 'LC_ALL': None, 'LC_CTYPE': None,
97
'LANGUAGE': None, 'PYTHONCOERCECLOCALE': '0',
99
self.assertStartsWith(err, b'brz: warning: unsupported locale setting')
100
self.assertEqualDiff(b"""\
69
101
------------------------------------------------------------
71
103
committer: ???? Meinel <juju@info.com>
111
class TestMultibyteCodecs(tests.TestCaseWithTransport):
112
"""Tests for quirks of multibyte encodings and their python codecs"""
114
def test_plugins_mbcs(self):
115
"""Ensure the plugins command works with cjkcodecs, see lp:754082"""
116
self.disable_missing_extensions_warning()
117
out, err = self.run_bzr(["plugins"], encoding="EUC-JP")
118
# The output is tested in bt.test_plugins rather than here
119
self.assertEqual("", err)