/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to breezy/tests/blackbox/test_locale.py

  • Committer: Jelmer Vernooij
  • Date: 2020-01-24 00:06:05 UTC
  • mto: This revision was merged to the branch mainline in revision 7459.
  • Revision ID: jelmer@jelmer.uk-20200124000605-qw2v9i7pjfrcy12m
Support importing Git submodules as tree references.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 Canonical Ltd
 
1
# Copyright (C) 2006, 2011 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
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
16
16
 
17
 
"""Test that bzr handles locales in a reasonable way"""
 
17
"""Test that brz handles locales in a reasonable way"""
18
18
 
19
 
import os
20
19
import sys
 
20
import unittest
21
21
 
22
 
from bzrlib import (
 
22
from breezy import (
23
23
    tests,
24
24
    )
25
25
 
36
36
        tree = self.make_branch_and_tree('tree')
37
37
        self.build_tree(['tree/a'])
38
38
        tree.add('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)
43
43
        self.tree = tree
44
44
 
 
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']
 
48
        cmd.extend(args)
 
49
        return self.run_bzr_subprocess(cmd, env_changes=env_changes)
 
50
 
 
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(
 
55
            ['tree'],
 
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.
 
59
            env_changes={
 
60
                'LANG': 'C', 'LC_ALL': 'C', 'LC_CTYPE': None, 'LANGUAGE': None})
 
61
        self.assertEqual(b'', err)
 
62
        self.assertEqualDiff(b"""\
 
63
------------------------------------------------------------
 
64
revno: 1
 
65
committer: \xd8\xac\xd9\x88\xd8\xac\xd9\x88 Meinel <juju@info.com>
 
66
branch nick: tree
 
67
timestamp: Thu 2006-08-24 20:28:17 +0000
 
68
message:
 
69
  Unicode \xc2\xb5 commit
 
70
""", out)
 
71
 
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(
 
75
            ['tree'],
 
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.
 
79
            env_changes={
 
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
------------------------------------------------------------
54
85
revno: 1
55
86
committer: ???? Meinel <juju@info.com>
60
91
""", out)
61
92
 
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(
 
95
            ['tree'],
 
96
            env_changes={'LANG': 'BOGUS', 'LC_ALL': None, 'LC_CTYPE': None,
 
97
                         'LANGUAGE': None, 'PYTHONCOERCECLOCALE': '0',
 
98
                         'PYTHONUTF8': '0'})
 
99
        self.assertStartsWith(err, b'brz: warning: unsupported locale setting')
 
100
        self.assertEqualDiff(b"""\
69
101
------------------------------------------------------------
70
102
revno: 1
71
103
committer: ???? Meinel <juju@info.com>
74
106
message:
75
107
  Unicode ? commit
76
108
""", out)
 
109
 
 
110
 
 
111
class TestMultibyteCodecs(tests.TestCaseWithTransport):
 
112
    """Tests for quirks of multibyte encodings and their python codecs"""
 
113
 
 
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)