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=b'r1',
39
tree.commit(u'Unicode \xb5 commit', rev_id='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
73
sys.version_info[:2] >= (3, 8),
74
"python > 3.8 doesn't allow changing filesystem default encoding")
75
45
def test_log_C(self):
76
46
self.disable_missing_extensions_warning()
77
out, err = self.run_log_quiet_long(
79
# C is not necessarily the default locale, so set both LANG and
80
# LC_ALL explicitly because LC_ALL is preferred on (some?) Linux
81
# systems but only LANG is respected on Windows.
83
'LANG': 'C', 'LC_ALL': 'C', 'LC_CTYPE': None,
84
'LANGUAGE': None, 'PYTHONCOERCECLOCALE': '0', 'PYTHONUTF8': '0'})
85
self.assertEqual(b'', err)
86
self.assertEqualDiff(b"""\
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("""\
87
53
------------------------------------------------------------
89
55
committer: ???? Meinel <juju@info.com>
97
sys.version_info[:2] >= (3, 8),
98
"python > 3.8 doesn't allow changing filesystem default encoding")
99
62
def test_log_BOGUS(self):
100
out, err = self.run_log_quiet_long(
102
env_changes={'LANG': 'BOGUS', 'LC_ALL': None, 'LC_CTYPE': None,
103
'LANGUAGE': None, 'PYTHONCOERCECLOCALE': '0',
105
self.assertStartsWith(err, b'brz: warning: unsupported locale setting')
106
self.assertEqualDiff(b"""\
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("""\
107
69
------------------------------------------------------------
109
71
committer: ???? Meinel <juju@info.com>
117
class TestMultibyteCodecs(tests.TestCaseWithTransport):
118
"""Tests for quirks of multibyte encodings and their python codecs"""
120
def test_plugins_mbcs(self):
121
"""Ensure the plugins command works with cjkcodecs, see lp:754082"""
122
self.disable_missing_extensions_warning()
123
out, err = self.run_bzr(["plugins"], encoding="EUC-JP")
124
# The output is tested in bt.test_plugins rather than here
125
self.assertEqual("", err)