/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
6614.1.3 by Vincent Ladeuil
Fix assertEquals being deprecated by using assertEqual.
1
# Copyright (C) 2005-2011, 2016 Canonical Ltd
1185.33.9 by Martin Pool
Add new selftest module.
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
4183.7.1 by Sabin Iacob
update FSF mailing address
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
1185.33.9 by Martin Pool
Add new selftest module.
16
17
# "weren't nothing promised to you.  do i look like i got a promise face?"
18
19
"""Tests for trace library"""
20
1740.5.7 by Martin Pool
Add test for formatting of EPIPE
21
import errno
6015.52.1 by Martin Packman
Add tests for logging various problematic values
22
import logging
1185.33.9 by Martin Pool
Add new selftest module.
23
import os
3195.1.1 by Andrew Bennetts
Always include timestamps in the trace file (i.e. remove -Dtimes in favour of having it switched on permanently)
24
import re
1185.33.9 by Martin Pool
Add new selftest module.
25
import sys
3173.1.12 by Martin Pool
Add test_push_log_file
26
import tempfile
1185.33.9 by Martin Pool
Add new selftest module.
27
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
28
from .. import (
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
29
    debug,
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
30
    errors,
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
31
    trace,
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
32
    )
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
33
from ..sixish import (
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
34
    PY3,
35
    StringIO,
6621.22.2 by Martin
Use BytesIO or StringIO from bzrlib.sixish
36
    )
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
37
from . import features, TestCaseInTempDir, TestCase
38
from ..trace import (
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
39
    mutter, mutter_callsite, report_exception,
40
    set_verbosity_level, get_verbosity_level, is_quiet, is_verbose, be_quiet,
3173.1.12 by Martin Pool
Add test_push_log_file
41
    pop_log_file,
42
    push_log_file,
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
43
    _rollover_trace_maybe,
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
44
    show_error,
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
45
    )
1185.33.9 by Martin Pool
Add new selftest module.
46
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
47
48
def _format_exception():
49
    """Format an exception as it would normally be displayed to the user"""
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
50
    buf = StringIO()
5765.1.1 by John Arbash Meinel
Merge Federico Culloca's PointlessCommit message, and revert accidental changes.
51
    report_exception(sys.exc_info(), buf)
1551.9.3 by Aaron Bentley
Revert buggy apport changes
52
    return buf.getvalue()
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
53
54
1185.33.9 by Martin Pool
Add new selftest module.
55
class TestTrace(TestCase):
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
56
1551.9.3 by Aaron Bentley
Revert buggy apport changes
57
    def test_format_sys_exception(self):
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
58
        # Test handling of an internal/unexpected error that probably
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
59
        # indicates a bug in brz.  The details of the message may vary
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
60
        # depending on whether apport is available or not.  See test_crash for
61
        # more.
1185.33.9 by Martin Pool
Add new selftest module.
62
        try:
6619.3.11 by Jelmer Vernooij
Use modern exceptions.
63
            raise NotImplementedError("time travel")
1185.33.9 by Martin Pool
Add new selftest module.
64
        except NotImplementedError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
65
            err = _format_exception()
66
        self.assertContainsRe(err,
6973.14.8 by Jelmer Vernooij
Fix tests.
67
                '^brz: ERROR: NotImplementedError: time travel')
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
68
        self.assertContainsRe(err,
6973.14.8 by Jelmer Vernooij
Fix tests.
69
            'Bazaar has encountered an internal error.')
1185.33.9 by Martin Pool
Add new selftest module.
70
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
71
    def test_format_interrupt_exception(self):
72
        try:
73
            raise KeyboardInterrupt()
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
74
        except KeyboardInterrupt:
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
75
            # XXX: Some risk that a *real* keyboard interrupt won't be seen
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
76
            msg = _format_exception()
77
        self.assertEqual(msg, 'brz: interrupted\n')
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
78
4634.26.1 by Martin Pool
Cleaner message when out of memory
79
    def test_format_memory_error(self):
80
        try:
81
            raise MemoryError()
82
        except MemoryError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
83
            msg = _format_exception()
6614.1.3 by Vincent Ladeuil
Fix assertEquals being deprecated by using assertEqual.
84
        self.assertEqual(msg,
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
85
            "brz: out of memory\nUse -Dmem_dump to dump memory to a file.\n")
4634.26.1 by Martin Pool
Cleaner message when out of memory
86
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
87
    def test_format_mem_dump(self):
6091.2.2 by Max Bowsher
Per jam's review comments, get rid of features.meliae_feature, which is new in
88
        self.requireFeature(features.meliae)
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
89
        debug.debug_flags.add('mem_dump')
90
        try:
91
            raise MemoryError()
92
        except MemoryError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
93
            msg = _format_exception()
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
94
        self.assertStartsWith(msg,
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
95
            "brz: out of memory\nMemory dumped to ")
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
96
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
97
    def test_format_os_error(self):
98
        try:
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
99
            os.rmdir('nosuchfile22222')
6619.3.2 by Jelmer Vernooij
Apply 2to3 except fix.
100
        except OSError as e:
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
101
            e_str = str(e)
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
102
            msg = _format_exception()
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
103
        # Linux seems to give "No such file" but Windows gives "The system
104
        # cannot find the file specified".
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
105
        self.assertEqual('brz: ERROR: %s\n' % (e_str,), msg)
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
106
107
    def test_format_io_error(self):
108
        try:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
109
            open('nosuchfile22222')
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
110
        except IOError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
111
            msg = _format_exception()
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
112
        # Even though Windows and Linux differ for 'os.rmdir', they both give
113
        # 'No such file' for open()
6138.3.11 by Jonathan Riddell
this test gets translated so can not check for specific message
114
        # However it now gets translated so we can not test for a specific message
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
115
        self.assertContainsRe(msg,
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
116
            '^brz: ERROR: \\[Errno .*\\] .*nosuchfile')
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
117
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
118
    def test_format_pywintypes_error(self):
5200.4.5 by Martin
Move pywintypes ModuleAvailableFeature to bzrlib.tests.features
119
        self.requireFeature(features.pywintypes)
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
120
        import pywintypes, win32file
121
        try:
122
            win32file.RemoveDirectory('nosuchfile22222')
123
        except pywintypes.error:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
124
            msg = _format_exception()
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
125
        # GZ 2010-05-03: Formatting for pywintypes.error is basic, a 3-tuple
126
        #                with errno, function name, and locale error message
5200.4.2 by Martin
Treat pywintypes.error as a user error as per OSError, rather than an internal error
127
        self.assertContainsRe(msg,
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
128
            "^brz: ERROR: \\(2, 'RemoveDirectory[AW]?', .*\\)")
129
5920.2.1 by Toon Nolten
Added a test for a sockets.error that wasn't caught in versions prior to python 2.6
130
    def test_format_sockets_error(self):
131
        try:
5920.2.2 by Toon Nolten
Fixed typo, and import
132
            import socket
5920.2.1 by Toon Nolten
Added a test for a sockets.error that wasn't caught in versions prior to python 2.6
133
            sock = socket.socket()
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
134
            sock.send(b"This should fail.")
5920.2.2 by Toon Nolten
Fixed typo, and import
135
        except socket.error:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
136
            msg = _format_exception()
137
5920.2.3 by Toon Nolten
More general test.
138
        self.assertNotContainsRe(msg,
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
139
            "Traceback \\(most recent call last\\):")
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
140
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
141
    def test_format_unicode_error(self):
142
        try:
143
            raise errors.BzrCommandError(u'argument foo\xb5 does not exist')
144
        except errors.BzrCommandError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
145
            msg = _format_exception()
146
        if PY3:
147
            expected = 'brz: ERROR: argument foo\xb5 does not exist\n'
148
        else:
149
            # GZ 2017-06-10: Pretty bogus, should encode per the output stream
150
            expected = 'brz: ERROR: argument foo\xc2\xb5 does not exist\n'
151
        self.assertEqual(msg, expected)
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
152
1185.33.9 by Martin Pool
Add new selftest module.
153
    def test_format_exception(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
154
        """Short formatting of brz exceptions"""
1185.33.9 by Martin Pool
Add new selftest module.
155
        try:
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
156
            raise errors.NotBranchError('wibble')
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
157
        except errors.NotBranchError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
158
            msg = _format_exception()
159
        self.assertEqual(msg, 'brz: ERROR: Not a branch: \"wibble\".\n')
1185.33.63 by Martin Pool
Better display of BzrError classes that are not BzrNewErrors.
160
3497.3.2 by Martin Pool
Show short error for missing libraries
161
    def test_report_external_import_error(self):
162
        """Short friendly message for missing system modules."""
163
        try:
164
            import ImaginaryModule
6619.3.2 by Jelmer Vernooij
Apply 2to3 except fix.
165
        except ImportError as e:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
166
            msg = _format_exception()
3497.3.2 by Martin Pool
Show short error for missing libraries
167
        else:
168
            self.fail("somehow succeeded in importing %r" % ImaginaryModule)
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
169
        self.assertContainsRe(msg,
170
            "^brz: ERROR: No module named '?ImaginaryModule'?\n"
171
            "You may need to install this Python library separately.\n$")
3497.3.2 by Martin Pool
Show short error for missing libraries
172
173
    def test_report_import_syntax_error(self):
174
        try:
175
            raise ImportError("syntax error")
6619.3.2 by Jelmer Vernooij
Apply 2to3 except fix.
176
        except ImportError as e:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
177
            msg = _format_exception()
3497.3.2 by Martin Pool
Show short error for missing libraries
178
        self.assertContainsRe(msg,
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
179
            'Bazaar has encountered an internal error')
3497.3.2 by Martin Pool
Show short error for missing libraries
180
1185.33.51 by Martin Pool
Fix trace of non-ascii messages, and add test.
181
    def test_trace_unicode(self):
182
        """Write Unicode to trace log"""
183
        self.log(u'the unicode character for benzene is \N{BENZENE RING}')
4794.1.15 by Robert Collins
Review feedback.
184
        log = self.get_log()
4794.1.8 by Robert Collins
Move the passing of test logs to the result to be via the getDetails API and remove all public use of TestCase._get_log.
185
        self.assertContainsRe(log, "the unicode character for benzene is")
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
186
1948.1.2 by John Arbash Meinel
Fix the test_trace functions to actually test that things are written to the log
187
    def test_trace_argument_unicode(self):
188
        """Write a Unicode argument to the trace log"""
189
        mutter(u'the unicode character for benzene is %s', u'\N{BENZENE RING}')
4794.1.15 by Robert Collins
Review feedback.
190
        log = self.get_log()
4794.1.8 by Robert Collins
Move the passing of test logs to the result to be via the getDetails API and remove all public use of TestCase._get_log.
191
        self.assertContainsRe(log, 'the unicode character')
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
192
1948.1.3 by John Arbash Meinel
Fix mutter() so even if args are invalid, it still works
193
    def test_trace_argument_utf8(self):
194
        """Write a Unicode argument to the trace log"""
195
        mutter(u'the unicode character for benzene is %s',
196
               u'\N{BENZENE RING}'.encode('utf-8'))
4794.1.15 by Robert Collins
Review feedback.
197
        log = self.get_log()
4794.1.8 by Robert Collins
Move the passing of test logs to the result to be via the getDetails API and remove all public use of TestCase._get_log.
198
        self.assertContainsRe(log, 'the unicode character')
1948.1.3 by John Arbash Meinel
Fix mutter() so even if args are invalid, it still works
199
7008.2.1 by Martin
Make mutter saner with string interpolation
200
    def test_trace_argument_exception(self):
201
        err = Exception('an error')
202
        mutter(u'can format stringable classes %s', err)
203
        log = self.get_log()
204
        self.assertContainsRe(log, 'can format stringable classes an error')
205
1740.5.7 by Martin Pool
Add test for formatting of EPIPE
206
    def test_report_broken_pipe(self):
207
        try:
208
            raise IOError(errno.EPIPE, 'broken pipe foofofo')
6614.1.3 by Vincent Ladeuil
Fix assertEquals being deprecated by using assertEqual.
209
        except IOError as e:
1551.9.3 by Aaron Bentley
Revert buggy apport changes
210
            msg = _format_exception()
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
211
            self.assertEqual(msg, "brz: broken pipe\n")
1740.5.7 by Martin Pool
Add test for formatting of EPIPE
212
        else:
213
            self.fail("expected error not raised")
1740.5.9 by Martin Pool
[merge] bzr.dev
214
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
215
    def assertLogContainsLine(self, log, string):
216
        """Assert log contains a line including log timestamp."""
217
        # Does not check absolute position in log as there may be kipple.
3195.1.1 by Andrew Bennetts
Always include timestamps in the trace file (i.e. remove -Dtimes in favour of having it switched on permanently)
218
        self.assertContainsRe(log,
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
219
            '(?m)^\\d+\\.\\d+  ' + re.escape(string))
3195.1.1 by Andrew Bennetts
Always include timestamps in the trace file (i.e. remove -Dtimes in favour of having it switched on permanently)
220
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
221
    def test_mutter_callsite_1(self):
222
        """mutter_callsite can capture 1 level of stack frame."""
223
        mutter_callsite(1, "foo %s", "a string")
4794.1.15 by Robert Collins
Review feedback.
224
        log = self.get_log()
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
225
        # begin with the message
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
226
        self.assertLogContainsLine(log, 'foo a string\nCalled from:\n')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
227
        # should show two frame: this frame and the one above
228
        self.assertContainsRe(log,
3195.1.1 by Andrew Bennetts
Always include timestamps in the trace file (i.e. remove -Dtimes in favour of having it switched on permanently)
229
            'test_trace\\.py", line \\d+, in test_mutter_callsite_1\n')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
230
        # this frame should be the final one
231
        self.assertEndsWith(log, ' "a string")\n')
232
233
    def test_mutter_callsite_2(self):
234
        """mutter_callsite can capture 2 levels of stack frame."""
235
        mutter_callsite(2, "foo %s", "a string")
4794.1.15 by Robert Collins
Review feedback.
236
        log = self.get_log()
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
237
        # begin with the message
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
238
        self.assertLogContainsLine(log, 'foo a string\nCalled from:\n')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
239
        # should show two frame: this frame and the one above
240
        self.assertContainsRe(log,
6798.1.1 by Jelmer Vernooij
Properly escape backslashes.
241
            'test_trace.py", line \\d+, in test_mutter_callsite_2\n')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
242
        # this frame should be the final one
243
        self.assertEndsWith(log, ' "a string")\n')
244
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
245
    def test_mutter_never_fails(self):
7008.2.1 by Martin
Make mutter saner with string interpolation
246
        """Even with unencodable input mutter should not raise errors."""
247
        mutter(u'can write unicode \xa7')
248
        mutter('can interpolate unicode %s', u'\xa7')
249
        mutter(b'can write bytes \xa7')
250
        mutter('can repr bytes %r', b'\xa7')
251
        mutter('can interpolate bytes %s', b'\xa7')
252
        # Log will always be written as utf-8
4794.1.15 by Robert Collins
Review feedback.
253
        log = self.get_log()
7008.2.1 by Martin
Make mutter saner with string interpolation
254
        self.assertContainsRe(
255
            log,
256
            u'.* +can write unicode \xa7\n'
257
            u'.* +can interpolate unicode \xa7\n'
258
            u'.* +can write bytes \ufffd\n'
259
            u'.* +can repr bytes b\'\\\\xa7\'\n'
260
            u'.* +can interpolate bytes (?:\ufffd|b\'\\\\xa7\')\n')
6325.3.1 by Vincent Ladeuil
Give meaningful deprecation warnings for deprecated test features
261
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
262
    def test_show_error(self):
263
        show_error('error1')
264
        show_error(u'error2 \xb5 blah')
5055.4.2 by Gordon Tyler
Improved test_show_error to test kwargs passing.
265
        show_error('arg: %s', 'blah')
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
266
        show_error('arg2: %(key)s', {'key':'stuff'})
267
        try:
268
            raise Exception("oops")
269
        except:
270
            show_error('kwarg', exc_info=True)
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
271
        log = self.get_log()
272
        self.assertContainsRe(log, 'error1')
273
        self.assertContainsRe(log, u'error2 \xb5 blah')
5055.4.2 by Gordon Tyler
Improved test_show_error to test kwargs passing.
274
        self.assertContainsRe(log, 'arg: blah')
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
275
        self.assertContainsRe(log, 'arg2: stuff')
276
        self.assertContainsRe(log, 'kwarg')
277
        self.assertContainsRe(log, 'Traceback \\(most recent call last\\):')
278
        self.assertContainsRe(log, 'File ".*test_trace.py", line .*, in test_show_error')
279
        self.assertContainsRe(log, 'raise Exception\\("oops"\\)')
280
        self.assertContainsRe(log, 'Exception: oops')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
281
3173.1.12 by Martin Pool
Add test_push_log_file
282
    def test_push_log_file(self):
283
        """Can push and pop log file, and this catches mutter messages.
284
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
285
        This is primarily for use in the test framework.
3173.1.12 by Martin Pool
Add test_push_log_file
286
        """
287
        tmp1 = tempfile.NamedTemporaryFile()
288
        tmp2 = tempfile.NamedTemporaryFile()
289
        try:
290
            memento1 = push_log_file(tmp1)
291
            mutter("comment to file1")
292
            try:
293
                memento2 = push_log_file(tmp2)
294
                try:
295
                    mutter("comment to file2")
296
                finally:
297
                    pop_log_file(memento2)
298
                mutter("again to file1")
299
            finally:
300
                pop_log_file(memento1)
301
            # the files were opened in binary mode, so should have exactly
302
            # these bytes.  and removing the file as the log target should
3173.1.15 by Martin Pool
Update test_push_log_file to handle there always being timestamps at the start of the trace messages
303
            # have caused them to be flushed out.  need to match using regexps
304
            # as there's a timestamp at the front.
305
            tmp1.seek(0)
306
            self.assertContainsRe(tmp1.read(),
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
307
                b"\\d+\\.\\d+  comment to file1\n"
308
                b"\\d+\\.\\d+  again to file1\n")
3173.1.15 by Martin Pool
Update test_push_log_file to handle there always being timestamps at the start of the trace messages
309
            tmp2.seek(0)
310
            self.assertContainsRe(tmp2.read(),
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
311
                b"\\d+\\.\\d+  comment to file2\n")
3173.1.12 by Martin Pool
Add test_push_log_file
312
        finally:
313
            tmp1.close()
314
            tmp2.close()
315
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
316
    def test__open_brz_log_uses_stderr_for_failures(self):
317
        # If _open_brz_log cannot open the file, then we should write the
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
318
        # warning to stderr. Since this is normally happening before logging is
319
        # set up.
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
320
        self.overrideAttr(sys, 'stderr', StringIO())
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
321
        # Set the log file to something that cannot exist
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
322
        self.overrideEnv('BRZ_LOG', '/no-such-dir/brz.log')
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
323
        self.overrideAttr(trace, '_brz_log_filename')
324
        logf = trace._open_brz_log()
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
325
        self.assertIs(None, logf)
6619.3.26 by Martin
Fix fallout from 2to3 getcwdu transformation and other test uses
326
        self.assertContainsRe(
327
            sys.stderr.getvalue(),
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
328
            "failed to open trace file: .* '/no-such-dir/brz.log'$")
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
329
4985.1.5 by Vincent Ladeuil
Deploying the new overrideAttr facility further reduces the complexity
330
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
331
class TestVerbosityLevel(TestCase):
332
333
    def test_verbosity_level(self):
334
        set_verbosity_level(1)
335
        self.assertEqual(1, get_verbosity_level())
336
        self.assertTrue(is_verbose())
337
        self.assertFalse(is_quiet())
338
        set_verbosity_level(-1)
339
        self.assertEqual(-1, get_verbosity_level())
340
        self.assertFalse(is_verbose())
341
        self.assertTrue(is_quiet())
342
        set_verbosity_level(0)
343
        self.assertEqual(0, get_verbosity_level())
344
        self.assertFalse(is_verbose())
345
        self.assertFalse(is_quiet())
346
347
    def test_be_quiet(self):
348
        # Confirm the old API still works
349
        be_quiet(True)
350
        self.assertEqual(-1, get_verbosity_level())
351
        be_quiet(False)
352
        self.assertEqual(0, get_verbosity_level())
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
353
354
6015.52.1 by Martin Packman
Add tests for logging various problematic values
355
class TestLogging(TestCase):
356
    """Check logging functionality robustly records information"""
357
358
    def test_note(self):
359
        trace.note("Noted")
360
        self.assertEqual("    INFO  Noted\n", self.get_log())
361
362
    def test_warning(self):
363
        trace.warning("Warned")
364
        self.assertEqual(" WARNING  Warned\n", self.get_log())
365
366
    def test_log(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
367
        logging.getLogger("brz").error("Errored")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
368
        self.assertEqual("   ERROR  Errored\n", self.get_log())
369
370
    def test_log_sub(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
371
        logging.getLogger("brz.test_log_sub").debug("Whispered")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
372
        self.assertEqual("   DEBUG  Whispered\n", self.get_log())
373
374
    def test_log_unicode_msg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
375
        logging.getLogger("brz").debug(u"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
376
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
377
378
    def test_log_unicode_arg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
379
        logging.getLogger("brz").debug("%s", u"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
380
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
381
382
    def test_log_utf8_msg(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
383
        logging.getLogger("brz").debug(b"\xc2\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
384
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
385
386
    def test_log_utf8_arg(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
387
        logging.getLogger("brz").debug(b"%s", b"\xc2\xa7")
388
        if PY3:
389
            expected = u"   DEBUG  b'\\xc2\\xa7'\n"
390
        else:
391
            expected = u"   DEBUG  \xa7\n"
392
        self.assertEqual(expected, self.get_log())
6015.52.1 by Martin Packman
Add tests for logging various problematic values
393
394
    def test_log_bytes_msg(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
395
        logging.getLogger("brz").debug(b"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
396
        log = self.get_log()
397
        self.assertContainsString(log, "UnicodeDecodeError: ")
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
398
        self.assertContainsRe(log,
399
            "Logging record unformattable: b?'\\\\xa7' % \\(\\)\n")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
400
401
    def test_log_bytes_arg(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
402
        logging.getLogger("brz").debug(b"%s", b"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
403
        log = self.get_log()
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
404
        if PY3:
405
            self.assertEqual(u"   DEBUG  b'\\xa7'\n", self.get_log())
406
        else:
407
            self.assertContainsString(log, "UnicodeDecodeError: ")
408
            self.assertContainsRe(log,
409
                "Logging record unformattable: ?'%s' % \\(b?'\\\\xa7',\\)\n")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
410
411
    def test_log_mixed_strings(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
412
        logging.getLogger("brz").debug(u"%s", b"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
413
        log = self.get_log()
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
414
        if PY3:
415
            self.assertEqual(u"   DEBUG  b'\\xa7'\n", self.get_log())
416
        else:
417
            self.assertContainsString(log, "UnicodeDecodeError: ")
418
            self.assertContainsRe(log,
419
                "Logging record unformattable: u'%s' % \\('\\\\xa7',\\)\n")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
420
421
    def test_log_repr_broken(self):
422
        class BadRepr(object):
423
            def __repr__(self):
424
                raise ValueError("Broken object")
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
425
        logging.getLogger("brz").debug("%s", BadRepr())
6015.52.1 by Martin Packman
Add tests for logging various problematic values
426
        log = self.get_log()
427
        self.assertContainsRe(log, "ValueError: Broken object\n")
428
        self.assertContainsRe(log, "Logging record unformattable: '%s' % .*\n")
429
430
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
431
class TestBzrLog(TestCaseInTempDir):
432
433
    def test_log_rollover(self):
434
        temp_log_name = 'test-log'
435
        trace_file = open(temp_log_name, 'at')
4789.22.2 by John Arbash Meinel
Speed up a slow memory-hungry test that doesn't need to be.
436
        trace_file.writelines(['test_log_rollover padding\n'] * 200000)
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
437
        trace_file.close()
438
        _rollover_trace_maybe(temp_log_name)
439
        # should have been rolled over
440
        self.assertFalse(os.access(temp_log_name, os.R_OK))
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
441
442
443
class TestTraceConfiguration(TestCaseInTempDir):
444
445
    def test_default_config(self):
446
        config = trace.DefaultConfig()
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
447
        self.overrideAttr(trace, "_brz_log_filename", None)
448
        trace._brz_log_filename = None
449
        expected_filename = trace._get_brz_log_filename()
450
        self.assertEqual(None, trace._brz_log_filename)
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
451
        config.__enter__()
452
        try:
453
            # Should have entered and setup a default filename.
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
454
            self.assertEqual(expected_filename, trace._brz_log_filename)
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
455
        finally:
456
            config.__exit__(None, None, None)
457
            # Should have exited and cleaned up.
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
458
            self.assertEqual(None, trace._brz_log_filename)