14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
"""Test that brz handles locales in a reasonable way"""
17
"""Test that bzr handles locales in a reasonable way"""
27
class TestLocale(tests.TestCaseWithTransport):
22
from bzrlib.tests import TestCaseWithTransport, TestSkipped
25
class TestLocale(TestCaseWithTransport):
30
28
super(TestLocale, self).setUp()
32
30
if sys.platform in ('win32',):
33
raise tests.TestSkipped('Windows does not respond to the LANG'
31
raise TestSkipped('Windows does not respond to the LANG'
36
34
tree = self.make_branch_and_tree('tree')
37
35
self.build_tree(['tree/a'])
39
tree.commit(u'Unicode \xb5 commit', rev_id=b'r1',
37
tree.commit(u'Unicode \xb5 commit', rev_id='r1',
40
38
committer=u'\u062c\u0648\u062c\u0648'
41
39
u' Meinel <juju@info.com>',
42
40
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
43
def test_log_C(self):
76
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"""\
44
out, err = self.run_bzr_subprocess(
45
'--no-aliases --no-plugins log -q --log-format=long tree',
46
env_changes={'LANG':'C', 'BZR_PROGRESS_BAR':'none',
47
'LC_ALL':None, 'LC_CTYPE':None, 'LANGUAGE':None})
48
self.assertEqual('', err)
49
self.assertEqualDiff("""\
87
50
------------------------------------------------------------
89
52
committer: ???? Meinel <juju@info.com>
97
sys.version_info[:2] >= (3, 8),
98
"python > 3.8 doesn't allow changing filesystem default encoding")
99
59
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"""\
60
out, err = self.run_bzr_subprocess(
61
'--no-aliases --no-plugins log -q --log-format=long tree',
62
env_changes={'LANG':'BOGUS', 'BZR_PROGRESS_BAR':'none',
63
'LC_ALL':None, 'LC_CTYPE':None, 'LANGUAGE':None})
64
# XXX: This depends on the exact formatting of a locale.Error
65
# as the first part of the string. It may be a little tempermental
66
self.assertEqualDiff("""\
67
bzr: warning: unsupported locale setting
68
bzr could not set the application locale.
69
Although this should be no problem for bzr itself,
70
it might cause problems with some plugins.
71
To investigate the issue, look at the output
72
of the locale(1p) tool available on POSIX systems.
73
bzr: warning: unsupported locale setting
74
Could not determine what text encoding to use.
75
This error usually means your Python interpreter
76
doesn't support the locale set by $LANG (BOGUS)
77
Continuing with ascii encoding.
79
self.assertEqualDiff("""\
107
80
------------------------------------------------------------
109
82
committer: ???? Meinel <juju@info.com>