Commit 35625c7e authored by maruel@chromium.org's avatar maruel@chromium.org

Fix locale.getlocale() exception.

Reapply r79006 with fixes for ubuntu 10.4.

The only change is in fix_default_encoding() to trap an exception
locale.getlocale() may throw.

R=dpranke@chromium.org
BUG=none
TEST=unit test

Review URL: http://codereview.chromium.org/6721029

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@79144 0039d316-1c4b-4281-b951-d872f2087c98
parent 529e97b7
...@@ -9,6 +9,7 @@ details on the presubmit API built into gcl. ...@@ -9,6 +9,7 @@ details on the presubmit API built into gcl.
""" """
UNIT_TESTS = [ UNIT_TESTS = [
'tests.fix_encoding_test',
'tests.gcl_unittest', 'tests.gcl_unittest',
'tests.gclient_scm_test', 'tests.gclient_scm_test',
'tests.gclient_smoketest', 'tests.gclient_smoketest',
......
This diff is collapsed.
...@@ -40,6 +40,7 @@ import breakpad # pylint: disable=W0611 ...@@ -40,6 +40,7 @@ import breakpad # pylint: disable=W0611
# gcl now depends on gclient. # gcl now depends on gclient.
from scm import SVN from scm import SVN
import fix_encoding
import gclient_utils import gclient_utils
import owners import owners
import presubmit_support import presubmit_support
...@@ -1473,4 +1474,5 @@ def main(argv): ...@@ -1473,4 +1474,5 @@ def main(argv):
if __name__ == "__main__": if __name__ == "__main__":
fix_encoding.fix_encoding()
sys.exit(main(sys.argv[1:])) sys.exit(main(sys.argv[1:]))
...@@ -64,6 +64,7 @@ import urllib ...@@ -64,6 +64,7 @@ import urllib
import breakpad # pylint: disable=W0611 import breakpad # pylint: disable=W0611
import fix_encoding
import gclient_scm import gclient_scm
import gclient_utils import gclient_utils
from third_party.repo.progress import Progress from third_party.repo.progress import Progress
...@@ -1266,6 +1267,7 @@ def Main(argv): ...@@ -1266,6 +1267,7 @@ def Main(argv):
if '__main__' == __name__: if '__main__' == __name__:
fix_encoding.fix_encoding()
sys.exit(Main(sys.argv[1:])) sys.exit(Main(sys.argv[1:]))
# vim: ts=2:sw=2:tw=80:et: # vim: ts=2:sw=2:tw=80:et:
...@@ -50,6 +50,7 @@ except ImportError: ...@@ -50,6 +50,7 @@ except ImportError:
import simplejson as json # pylint: disable=F0401 import simplejson as json # pylint: disable=F0401
# Local imports. # Local imports.
import fix_encoding
import gclient_utils import gclient_utils
import owners import owners
import presubmit_canned_checks import presubmit_canned_checks
...@@ -142,18 +143,18 @@ class OutputApi(object): ...@@ -142,18 +143,18 @@ class OutputApi(object):
def handle(self, output): def handle(self, output):
output.write(self._message) output.write(self._message)
output.write('\n') output.write('\n')
if len(self._items) > 0: for index, item in enumerate(self._items):
output.write(' ' + ' \\\n '.join(map(str, self._items)) + '\n') output.write(' ')
# Write separately in case it's unicode.
output.write(item)
if index < len(self._items) - 1:
output.write(' \\')
output.write('\n')
if self._long_text: if self._long_text:
# Sometimes self._long_text is a ascii string, a codepage string output.write('\n***************\n')
# (on windows), or a unicode object. # Write separately in case it's unicode.
try: output.write(self._long_text)
long_text = self._long_text.decode() output.write('\n***************\n')
except UnicodeDecodeError:
long_text = self._long_text.decode('ascii', 'replace')
output.write('\n***************\n%s\n***************\n' %
long_text)
if self.fatal: if self.fatal:
output.fail() output.fail()
...@@ -1192,4 +1193,5 @@ def Main(argv): ...@@ -1192,4 +1193,5 @@ def Main(argv):
if __name__ == '__main__': if __name__ == '__main__':
fix_encoding.fix_encoding()
sys.exit(Main(None)) sys.exit(Main(None))
#!/usr/bin/python
# coding=utf8
# Copyright (c) 2011 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Unit tests for fix_encoding.py."""
import os
import sys
import unittest
ROOT_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.insert(0, ROOT_DIR)
import fix_encoding
class FixEncodingTest(unittest.TestCase):
# Nice mix of latin, hebrew, arabic and chinese. Doesn't mean anything.
text = u'Héllô 偉大 سيد'
def test_code_page(self):
# Make sure printing garbage won't throw.
print self.text.encode() + '\xff'
print >> sys.stderr, self.text.encode() + '\xff'
def test_utf8(self):
# Make sure printing utf-8 works.
print self.text.encode('utf-8')
print >> sys.stderr, self.text.encode('utf-8')
def test_unicode(self):
# Make sure printing unicode works.
print self.text
print >> sys.stderr, self.text
def test_default_encoding(self):
self.assertEquals('utf-8', sys.getdefaultencoding())
def test_win_console(self):
if sys.platform != 'win32':
return
# This should fail if redirected. Can be checked with:
# python fix_encoding_test.py > a
self.assertEquals(
sys.stdout.__class__, fix_encoding.WinUnicodeConsoleOutput)
self.assertEquals(
sys.stderr.__class__, fix_encoding.WinUnicodeConsoleOutput)
self.assertEquals(sys.stdout.encoding, sys.getdefaultencoding())
self.assertEquals(sys.stderr.encoding, sys.getdefaultencoding())
def test_multiple_calls(self):
# Shouldn't do anything.
self.assertEquals(False, fix_encoding.fix_encoding())
if __name__ == '__main__':
assert fix_encoding.fix_encoding()
unittest.main()
...@@ -90,7 +90,8 @@ class GclUnittest(GclTestsBase): ...@@ -90,7 +90,8 @@ class GclUnittest(GclTestsBase):
'OptionallyDoPresubmitChecks', 'REPOSITORY_ROOT', 'REVIEWERS_REGEX', 'OptionallyDoPresubmitChecks', 'REPOSITORY_ROOT', 'REVIEWERS_REGEX',
'RunShell', 'RunShellWithReturnCode', 'SVN', 'RunShell', 'RunShellWithReturnCode', 'SVN',
'TryChange', 'UnknownFiles', 'Warn', 'TryChange', 'UnknownFiles', 'Warn',
'attrs', 'breakpad', 'defer_attributes', 'gclient_utils', 'getpass', 'attrs', 'breakpad', 'defer_attributes', 'fix_encoding',
'gclient_utils', 'getpass',
'json', 'main', 'need_change', 'need_change_and_args', 'no_args', 'json', 'main', 'need_change', 'need_change_and_args', 'no_args',
'optparse', 'os', 'owners', 'presubmit_support', 'random', 're', 'optparse', 'os', 'owners', 'presubmit_support', 'random', 're',
'string', 'subprocess', 'suggest_reviewers', 'sys', 'tempfile', 'string', 'subprocess', 'suggest_reviewers', 'sys', 'tempfile',
......
...@@ -141,7 +141,8 @@ class PresubmitUnittest(PresubmitTestsBase): ...@@ -141,7 +141,8 @@ class PresubmitUnittest(PresubmitTestsBase):
'NotImplementedException', 'OutputApi', 'ParseFiles', 'NotImplementedException', 'OutputApi', 'ParseFiles',
'PresubmitExecuter', 'PresubmitOutput', 'ScanSubDirs', 'PresubmitExecuter', 'PresubmitOutput', 'ScanSubDirs',
'SvnAffectedFile', 'SvnChange', 'cPickle', 'cStringIO', 'SvnAffectedFile', 'SvnChange', 'cPickle', 'cStringIO',
'exceptions', 'fnmatch', 'gclient_utils', 'glob', 'json', 'load_files', 'exceptions', 'fix_encoding', 'fnmatch', 'gclient_utils', 'glob', 'json',
'load_files',
'logging', 'marshal', 'normpath', 'optparse', 'os', 'owners', 'pickle', 'logging', 'marshal', 'normpath', 'optparse', 'os', 'owners', 'pickle',
'presubmit_canned_checks', 'random', 're', 'scm', 'subprocess', 'presubmit_canned_checks', 'random', 're', 'scm', 'subprocess',
'sys', 'tempfile', 'time', 'traceback', 'types', 'unittest', 'urllib2', 'sys', 'tempfile', 'time', 'traceback', 'types', 'unittest', 'urllib2',
......
...@@ -45,7 +45,8 @@ class TryChangeUnittest(TryChangeTestsBase): ...@@ -45,7 +45,8 @@ class TryChangeUnittest(TryChangeTestsBase):
'EPILOG', 'Escape', 'GIT', 'GuessVCS', 'GetMungedDiff', 'HELP_STRING', 'EPILOG', 'Escape', 'GIT', 'GuessVCS', 'GetMungedDiff', 'HELP_STRING',
'InvalidScript', 'NoTryServerAccess', 'PrintSuccess', 'SCM', 'SVN', 'InvalidScript', 'NoTryServerAccess', 'PrintSuccess', 'SCM', 'SVN',
'TryChange', 'USAGE', 'TryChange', 'USAGE',
'breakpad', 'datetime', 'errno', 'gcl', 'gclient_utils', 'getpass', 'breakpad', 'datetime', 'errno', 'fix_encoding', 'gcl', 'gclient_utils',
'getpass',
'json', 'logging', 'optparse', 'os', 'posixpath', 're', 'scm', 'shutil', 'json', 'logging', 'optparse', 'os', 'posixpath', 're', 'scm', 'shutil',
'sys', 'tempfile', 'urllib', 'sys', 'tempfile', 'urllib',
] ]
......
...@@ -39,6 +39,7 @@ try: ...@@ -39,6 +39,7 @@ try:
except ImportError: except ImportError:
gcl = None gcl = None
import fix_encoding
import gclient_utils import gclient_utils
import scm import scm
...@@ -769,4 +770,5 @@ def TryChange(argv, ...@@ -769,4 +770,5 @@ def TryChange(argv,
if __name__ == "__main__": if __name__ == "__main__":
fix_encoding.fix_encoding()
sys.exit(TryChange(None, [], False)) sys.exit(TryChange(None, [], False))
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment