/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 bzrlib/tests/blackbox/test_locale.py

  • Committer: Martin Pool
  • Date: 2009-07-27 06:28:35 UTC
  • mto: This revision was merged to the branch mainline in revision 4587.
  • Revision ID: mbp@sourcefrog.net-20090727062835-o66p8it658tq1sma
Add CountedLock.get_physical_lock_status

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006, 2011 Canonical Ltd
 
1
# Copyright (C) 2006 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 brz handles locales in a reasonable way"""
 
17
"""Test that bzr handles locales in a reasonable way"""
18
18
 
 
19
import os
19
20
import sys
20
 
import unittest
21
 
 
22
 
from breezy import (
23
 
    tests,
24
 
    )
25
 
 
26
 
 
27
 
class TestLocale(tests.TestCaseWithTransport):
 
21
 
 
22
from bzrlib.tests import TestCaseWithTransport, TestSkipped
 
23
 
 
24
 
 
25
class TestLocale(TestCaseWithTransport):
28
26
 
29
27
    def setUp(self):
30
28
        super(TestLocale, self).setUp()
31
29
 
32
30
        if sys.platform in ('win32',):
33
 
            raise tests.TestSkipped('Windows does not respond to the LANG'
34
 
                                    ' env variable')
 
31
            raise TestSkipped('Windows does not respond to the LANG'
 
32
                              ' env variable')
35
33
 
36
34
        tree = self.make_branch_and_tree('tree')
37
35
        self.build_tree(['tree/a'])
38
36
        tree.add('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)
43
41
        self.tree = tree
44
42
 
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")
75
43
    def test_log_C(self):
76
 
        self.disable_missing_extensions_warning()
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"""\
 
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
------------------------------------------------------------
88
51
revno: 1
89
52
committer: ???? Meinel <juju@info.com>
93
56
  Unicode ? commit
94
57
""", out)
95
58
 
96
 
    @unittest.skipIf(
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(
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"""\
 
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.
 
78
""", err)
 
79
        self.assertEqualDiff("""\
107
80
------------------------------------------------------------
108
81
revno: 1
109
82
committer: ???? Meinel <juju@info.com>
112
85
message:
113
86
  Unicode ? commit
114
87
""", 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)