/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-04-05 19:11:34 UTC
  • mto: (7490.7.16 work)
  • mto: This revision was merged to the branch mainline in revision 7501.
  • Revision ID: jelmer@jelmer.uk-20200405191134-0aebh8ikiwygxma5
Populate the .gitignore file.

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
 
 
72
    @unittest.skipIf(
 
73
        sys.version_info[:2] >= (3, 8),
 
74
        "python > 3.8 doesn't allow changing filesystem default encoding")
45
75
    def test_log_C(self):
46
76
        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("""\
 
77
        out, err = self.run_log_quiet_long(
 
78
            ['tree'],
 
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.
 
82
            env_changes={
 
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"""\
53
87
------------------------------------------------------------
54
88
revno: 1
55
89
committer: ???? Meinel <juju@info.com>
59
93
  Unicode ? commit
60
94
""", out)
61
95
 
 
96
    @unittest.skipIf(
 
97
        sys.version_info[:2] >= (3, 8),
 
98
        "python > 3.8 doesn't allow changing filesystem default encoding")
62
99
    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("""\
 
100
        out, err = self.run_log_quiet_long(
 
101
            ['tree'],
 
102
            env_changes={'LANG': 'BOGUS', 'LC_ALL': None, 'LC_CTYPE': None,
 
103
                         'LANGUAGE': None, 'PYTHONCOERCECLOCALE': '0',
 
104
                         'PYTHONUTF8': '0'})
 
105
        self.assertStartsWith(err, b'brz: warning: unsupported locale setting')
 
106
        self.assertEqualDiff(b"""\
69
107
------------------------------------------------------------
70
108
revno: 1
71
109
committer: ???? Meinel <juju@info.com>
74
112
message:
75
113
  Unicode ? commit
76
114
""", out)
 
115
 
 
116
 
 
117
class TestMultibyteCodecs(tests.TestCaseWithTransport):
 
118
    """Tests for quirks of multibyte encodings and their python codecs"""
 
119
 
 
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)