/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: Marius Kruger
  • Date: 2010-07-10 21:28:56 UTC
  • mto: (5384.1.1 integration)
  • mto: This revision was merged to the branch mainline in revision 5385.
  • Revision ID: marius.kruger@enerweb.co.za-20100710212856-uq4ji3go0u5se7hx
* Update documentation
* add NEWS

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
21
 
22
 
from breezy import (
 
22
from bzrlib 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=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)
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")
75
45
    def test_log_C(self):
76
46
        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"""\
 
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
------------------------------------------------------------
88
54
revno: 1
89
55
committer: ???? Meinel <juju@info.com>
93
59
  Unicode ? commit
94
60
""", out)
95
61
 
96
 
    @unittest.skipIf(
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(
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"""\
 
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
------------------------------------------------------------
108
70
revno: 1
109
71
committer: ???? Meinel <juju@info.com>
112
74
message:
113
75
  Unicode ? commit
114
76
""", 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)