1
# Copyright (C) 2006, 2007, 2009, 2010 Canonical Ltd
1
# Copyright (C) 2006, 2007, 2009-2012, 2016 Canonical Ltd
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
17
17
"""Tests for display of exceptions."""
19
from cStringIO import StringIO
33
from bzrlib.tests import TestCaseInTempDir, TestCase
34
from bzrlib.errors import NotBranchError
37
class TestExceptionReporting(TestCase):
31
from breezy.bzr.groupcompress_repo import RepositoryFormat2a
34
class TestExceptionReporting(tests.TestCaseInTempDir):
39
36
def test_exception_exitcode(self):
40
37
# we must use a subprocess, because the normal in-memory mechanism
43
40
universal_newlines=True,
44
41
retcode=errors.EXIT_INTERNAL_ERROR)
45
42
self.assertEqual(4, errors.EXIT_INTERNAL_ERROR)
46
self.assertContainsRe(err,
47
r'exceptions\.AssertionError: always fails\n')
48
self.assertContainsRe(err, r'Bazaar has encountered an internal error')
43
self.assertContainsRe(err, br'\nAssertionError: always fails\n')
44
self.assertContainsRe(err, br'Bazaar has encountered an internal error')
46
def test_undecodable_argv(self):
47
"""A user error must be reported if argv is not in the locale encoding
49
A subprocess with an environment ascii-only setting is used so the test
50
can run without worrying about the locale the test suite is using.
52
if os.name != "posix":
53
raise tests.TestNotApplicable("Needs system beholden to C locales")
54
out, err = self.run_bzr_subprocess(["\xa0"],
55
env_changes={"LANG": "C", "LC_ALL": "C"},
56
universal_newlines=True,
57
retcode=errors.EXIT_ERROR)
58
self.assertContainsRe(err, br"^brz: ERROR: .*'\\xa0'.* unsupported",
60
self.assertEqual(out, "")
62
def test_utf8_default_fs_enc(self):
63
"""In the C locale brz treats a posix filesystem as UTF-8 encoded"""
64
if os.name != "posix":
65
raise tests.TestNotApplicable("Needs system beholden to C locales")
66
out, err = self.run_bzr_subprocess(["init", "file:%C2%A7"],
67
env_changes={"LANG": "C", "LC_ALL": "C"})
68
self.assertContainsRe(out, "^Created a standalone tree .*$")
71
class TestOptParseBugHandling(tests.TestCase):
72
"Test that we handle http://bugs.python.org/issue2931"
74
def test_nonascii_optparse(self):
75
"""Reasonable error raised when non-ascii in option name"""
76
error_re = 'Only ASCII permitted in option names'
77
out = self.run_bzr_error([error_re], ['st', u'-\xe4'])
80
class TestObsoleteRepoFormat(RepositoryFormat2a):
83
def get_format_string(cls):
84
return b"Test Obsolete Repository Format"
86
def is_deprecated(self):
51
90
class TestDeprecationWarning(tests.TestCaseWithTransport):
52
91
"""The deprecation warning is controlled via a global variable:
53
92
repository._deprecation_warning_done. As such, it can be emitted only once
54
during a bzr invocation, no matter how many repositories are involved.
93
during a brz invocation, no matter how many repositories are involved.
56
95
It would be better if it was a repo attribute instead but that's far more
57
96
work than I want to do right now -- vila 20091215.
61
100
super(TestDeprecationWarning, self).setUp()
101
self.addCleanup(repository.format_registry.remove,
102
TestObsoleteRepoFormat)
103
repository.format_registry.register(TestObsoleteRepoFormat)
104
self.addCleanup(controldir.format_registry.remove, "testobsolete")
105
bzr.register_metadir(controldir.format_registry, "testobsolete",
106
"breezy.tests.blackbox.test_exceptions.TestObsoleteRepoFormat",
107
branch_format='breezy.bzr.branch.BzrBranchFormat7',
108
tree_format='breezy.bzr.workingtree_4.WorkingTreeFormat6',
110
help='Same as 2a, but with an obsolete repo format.')
62
111
self.disable_deprecation_warning()
64
113
def enable_deprecation_warning(self, repo=None):
72
121
def make_obsolete_repo(self, path):
73
122
# We don't want the deprecation raising during the repo creation
74
tree = self.make_branch_and_tree(path, format=bzrdir.BzrDirFormat5())
123
format = controldir.format_registry.make_controldir("testobsolete")
124
tree = self.make_branch_and_tree(path, format=format)
77
127
def check_warning(self, present):
79
129
check = self.assertContainsRe
81
131
check = self.assertNotContainsRe
82
check(self._get_log(keep_log_file=True), 'WARNING.*bzr upgrade')
132
check(self.get_log(), 'WARNING.*brz upgrade')
84
134
def test_repository_deprecation_warning(self):
85
135
"""Old formats give a warning"""
91
141
def test_repository_deprecation_warning_suppressed_global(self):
92
142
"""Old formats give a warning"""
93
conf = config.GlobalConfig()
94
conf.set_user_option('suppress_warnings', 'format_deprecation')
143
conf = config.GlobalStack()
144
conf.set('suppress_warnings', 'format_deprecation')
95
145
self.make_obsolete_repo('foo')
96
146
self.enable_deprecation_warning()
97
147
out, err = self.run_bzr('status', working_dir='foo')
100
150
def test_repository_deprecation_warning_suppressed_locations(self):
101
151
"""Old formats give a warning"""
102
152
self.make_obsolete_repo('foo')
103
conf = config.LocationConfig(osutils.pathjoin(self.test_dir, 'foo'))
104
conf.set_user_option('suppress_warnings', 'format_deprecation')
153
conf = config.LocationStack(osutils.pathjoin(self.test_dir, 'foo'))
154
conf.set('suppress_warnings', 'format_deprecation')
105
155
self.enable_deprecation_warning()
106
156
out, err = self.run_bzr('status', working_dir='foo')
107
157
self.check_warning(False)
109
159
def test_repository_deprecation_warning_suppressed_branch(self):
110
160
"""Old formats give a warning"""
111
161
tree = self.make_obsolete_repo('foo')
112
conf = tree.branch.get_config()
113
conf.set_user_option('suppress_warnings', 'format_deprecation')
162
conf = tree.branch.get_config_stack()
163
conf.set('suppress_warnings', 'format_deprecation')
114
164
self.enable_deprecation_warning()
115
165
out, err = self.run_bzr('status', working_dir='foo')
116
166
self.check_warning(False)