/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
7479.2.1 by Jelmer Vernooij
Drop python2 support.
22
from io import StringIO
6015.52.1 by Martin Packman
Add tests for logging various problematic values
23
import logging
1185.33.9 by Martin Pool
Add new selftest module.
24
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)
25
import re
1185.33.9 by Martin Pool
Add new selftest module.
26
import sys
3173.1.12 by Martin Pool
Add test_push_log_file
27
import tempfile
1185.33.9 by Martin Pool
Add new selftest module.
28
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
29
from .. import (
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
30
    debug,
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
31
    errors,
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
32
    trace,
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
33
    )
7427.1.1 by Jelmer Vernooij
Skip test when directory creation always succeeds.
34
from . import features, TestCaseInTempDir, TestCase, TestSkipped
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
35
from ..trace import (
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
36
    mutter, mutter_callsite, report_exception,
37
    set_verbosity_level, get_verbosity_level, is_quiet, is_verbose, be_quiet,
3173.1.12 by Martin Pool
Add test_push_log_file
38
    pop_log_file,
39
    push_log_file,
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
40
    _rollover_trace_maybe,
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
41
    show_error,
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
42
    )
1185.33.9 by Martin Pool
Add new selftest module.
43
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
44
45
def _format_exception():
46
    """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
47
    buf = StringIO()
5765.1.1 by John Arbash Meinel
Merge Federico Culloca's PointlessCommit message, and revert accidental changes.
48
    report_exception(sys.exc_info(), buf)
1551.9.3 by Aaron Bentley
Revert buggy apport changes
49
    return buf.getvalue()
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
50
51
1185.33.9 by Martin Pool
Add new selftest module.
52
class TestTrace(TestCase):
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
53
1551.9.3 by Aaron Bentley
Revert buggy apport changes
54
    def test_format_sys_exception(self):
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
55
        # Test handling of an internal/unexpected error that probably
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
56
        # 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
57
        # depending on whether apport is available or not.  See test_crash for
58
        # more.
1185.33.9 by Martin Pool
Add new selftest module.
59
        try:
6619.3.11 by Jelmer Vernooij
Use modern exceptions.
60
            raise NotImplementedError("time travel")
1185.33.9 by Martin Pool
Add new selftest module.
61
        except NotImplementedError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
62
            err = _format_exception()
63
        self.assertContainsRe(err,
7143.15.2 by Jelmer Vernooij
Run autopep8.
64
                              '^brz: ERROR: NotImplementedError: time travel')
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
65
        self.assertContainsRe(err,
7143.15.2 by Jelmer Vernooij
Run autopep8.
66
                              'Bazaar has encountered an internal error.')
1185.33.9 by Martin Pool
Add new selftest module.
67
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
68
    def test_format_interrupt_exception(self):
69
        try:
70
            raise KeyboardInterrupt()
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
71
        except KeyboardInterrupt:
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
72
            # 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
73
            msg = _format_exception()
74
        self.assertEqual(msg, 'brz: interrupted\n')
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
75
4634.26.1 by Martin Pool
Cleaner message when out of memory
76
    def test_format_memory_error(self):
77
        try:
78
            raise MemoryError()
79
        except MemoryError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
80
            msg = _format_exception()
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
81
        self.assertEqual(
82
            msg,
83
            "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
84
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
85
    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
86
        self.requireFeature(features.meliae)
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
87
        debug.debug_flags.add('mem_dump')
88
        try:
89
            raise MemoryError()
90
        except MemoryError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
91
            msg = _format_exception()
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
92
        self.assertStartsWith(msg,
7143.15.2 by Jelmer Vernooij
Run autopep8.
93
                              "brz: out of memory\nMemory dumped to ")
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
94
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
95
    def test_format_os_error(self):
96
        try:
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
97
            os.rmdir('nosuchfile22222')
6619.3.2 by Jelmer Vernooij
Apply 2to3 except fix.
98
        except OSError as e:
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
99
            e_str = str(e)
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
100
            msg = _format_exception()
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
101
        # Linux seems to give "No such file" but Windows gives "The system
102
        # cannot find the file specified".
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
103
        self.assertEqual('brz: ERROR: %s\n' % (e_str,), msg)
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
104
105
    def test_format_io_error(self):
106
        try:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
107
            open('nosuchfile22222')
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
108
        except IOError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
109
            msg = _format_exception()
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
110
        # Even though Windows and Linux differ for 'os.rmdir', they both give
111
        # 'No such file' for open()
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
112
        # However it now gets translated so we can not test for a specific
113
        # message
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
114
        self.assertContainsRe(msg,
7143.15.2 by Jelmer Vernooij
Run autopep8.
115
                              '^brz: ERROR: \\[Errno .*\\] .*nosuchfile')
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
116
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
117
    def test_format_pywintypes_error(self):
5200.4.5 by Martin
Move pywintypes ModuleAvailableFeature to bzrlib.tests.features
118
        self.requireFeature(features.pywintypes)
7143.15.2 by Jelmer Vernooij
Run autopep8.
119
        import pywintypes
120
        import win32file
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
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
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
127
        self.assertContainsRe(
128
            msg, "^brz: ERROR: \\(2, 'RemoveDirectory[AW]?', .*\\)")
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
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,
7143.15.2 by Jelmer Vernooij
Run autopep8.
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()
7479.2.1 by Jelmer Vernooij
Drop python2 support.
146
        expected = 'brz: ERROR: argument foo\xb5 does not exist\n'
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
147
        self.assertEqual(msg, expected)
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
148
1185.33.9 by Martin Pool
Add new selftest module.
149
    def test_format_exception(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
150
        """Short formatting of brz exceptions"""
1185.33.9 by Martin Pool
Add new selftest module.
151
        try:
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
152
            raise errors.NotBranchError('wibble')
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
153
        except errors.NotBranchError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
154
            msg = _format_exception()
155
        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.
156
3497.3.2 by Martin Pool
Show short error for missing libraries
157
    def test_report_external_import_error(self):
158
        """Short friendly message for missing system modules."""
159
        try:
160
            import ImaginaryModule
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
161
        except ImportError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
162
            msg = _format_exception()
3497.3.2 by Martin Pool
Show short error for missing libraries
163
        else:
164
            self.fail("somehow succeeded in importing %r" % ImaginaryModule)
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
165
        self.assertContainsRe(
166
            msg,
167
            "^brz: ERROR: No module named '?ImaginaryModule'?\n"
168
            "You may need to install this Python library separately.\n$")
3497.3.2 by Martin Pool
Show short error for missing libraries
169
170
    def test_report_import_syntax_error(self):
171
        try:
172
            raise ImportError("syntax error")
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
173
        except ImportError:
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
174
            msg = _format_exception()
3497.3.2 by Martin Pool
Show short error for missing libraries
175
        self.assertContainsRe(msg,
7143.15.2 by Jelmer Vernooij
Run autopep8.
176
                              'Bazaar has encountered an internal error')
3497.3.2 by Martin Pool
Show short error for missing libraries
177
1185.33.51 by Martin Pool
Fix trace of non-ascii messages, and add test.
178
    def test_trace_unicode(self):
179
        """Write Unicode to trace log"""
180
        self.log(u'the unicode character for benzene is \N{BENZENE RING}')
4794.1.15 by Robert Collins
Review feedback.
181
        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.
182
        self.assertContainsRe(log, "the unicode character for benzene is")
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
183
1948.1.2 by John Arbash Meinel
Fix the test_trace functions to actually test that things are written to the log
184
    def test_trace_argument_unicode(self):
185
        """Write a Unicode argument to the trace log"""
186
        mutter(u'the unicode character for benzene is %s', u'\N{BENZENE RING}')
4794.1.15 by Robert Collins
Review feedback.
187
        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.
188
        self.assertContainsRe(log, 'the unicode character')
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
189
1948.1.3 by John Arbash Meinel
Fix mutter() so even if args are invalid, it still works
190
    def test_trace_argument_utf8(self):
191
        """Write a Unicode argument to the trace log"""
192
        mutter(u'the unicode character for benzene is %s',
193
               u'\N{BENZENE RING}'.encode('utf-8'))
4794.1.15 by Robert Collins
Review feedback.
194
        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.
195
        self.assertContainsRe(log, 'the unicode character')
1948.1.3 by John Arbash Meinel
Fix mutter() so even if args are invalid, it still works
196
7008.2.1 by Martin
Make mutter saner with string interpolation
197
    def test_trace_argument_exception(self):
198
        err = Exception('an error')
199
        mutter(u'can format stringable classes %s', err)
200
        log = self.get_log()
201
        self.assertContainsRe(log, 'can format stringable classes an error')
202
1740.5.7 by Martin Pool
Add test for formatting of EPIPE
203
    def test_report_broken_pipe(self):
204
        try:
205
            raise IOError(errno.EPIPE, 'broken pipe foofofo')
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
206
        except IOError:
1551.9.3 by Aaron Bentley
Revert buggy apport changes
207
            msg = _format_exception()
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
208
            self.assertEqual(msg, "brz: broken pipe\n")
1740.5.7 by Martin Pool
Add test for formatting of EPIPE
209
        else:
210
            self.fail("expected error not raised")
1740.5.9 by Martin Pool
[merge] bzr.dev
211
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
212
    def assertLogContainsLine(self, log, string):
213
        """Assert log contains a line including log timestamp."""
214
        # 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)
215
        self.assertContainsRe(log,
7143.15.2 by Jelmer Vernooij
Run autopep8.
216
                              '(?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)
217
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
218
    def test_mutter_callsite_1(self):
219
        """mutter_callsite can capture 1 level of stack frame."""
220
        mutter_callsite(1, "foo %s", "a string")
4794.1.15 by Robert Collins
Review feedback.
221
        log = self.get_log()
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
222
        # begin with the message
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
223
        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.
224
        # should show two frame: this frame and the one above
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
225
        self.assertContainsRe(
226
            log, '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.
227
        # this frame should be the final one
228
        self.assertEndsWith(log, ' "a string")\n')
229
230
    def test_mutter_callsite_2(self):
231
        """mutter_callsite can capture 2 levels of stack frame."""
232
        mutter_callsite(2, "foo %s", "a string")
4794.1.15 by Robert Collins
Review feedback.
233
        log = self.get_log()
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
234
        # begin with the message
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
235
        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.
236
        # should show two frame: this frame and the one above
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
237
        self.assertContainsRe(
238
            log, '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.
239
        # this frame should be the final one
240
        self.assertEndsWith(log, ' "a string")\n')
241
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
242
    def test_mutter_never_fails(self):
7008.2.1 by Martin
Make mutter saner with string interpolation
243
        """Even with unencodable input mutter should not raise errors."""
244
        mutter(u'can write unicode \xa7')
245
        mutter('can interpolate unicode %s', u'\xa7')
246
        mutter(b'can write bytes \xa7')
247
        mutter('can repr bytes %r', b'\xa7')
248
        mutter('can interpolate bytes %s', b'\xa7')
249
        # Log will always be written as utf-8
4794.1.15 by Robert Collins
Review feedback.
250
        log = self.get_log()
7008.2.1 by Martin
Make mutter saner with string interpolation
251
        self.assertContainsRe(
252
            log,
253
            u'.* +can write unicode \xa7\n'
254
            u'.* +can interpolate unicode \xa7\n'
255
            u'.* +can write bytes \ufffd\n'
256
            u'.* +can repr bytes b\'\\\\xa7\'\n'
257
            u'.* +can interpolate bytes (?:\ufffd|b\'\\\\xa7\')\n')
6325.3.1 by Vincent Ladeuil
Give meaningful deprecation warnings for deprecated test features
258
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
259
    def test_show_error(self):
260
        show_error('error1')
261
        show_error(u'error2 \xb5 blah')
5055.4.2 by Gordon Tyler
Improved test_show_error to test kwargs passing.
262
        show_error('arg: %s', 'blah')
7143.15.2 by Jelmer Vernooij
Run autopep8.
263
        show_error('arg2: %(key)s', {'key': 'stuff'})
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
264
        try:
265
            raise Exception("oops")
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
266
        except BaseException:
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
267
            show_error('kwarg', exc_info=True)
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
268
        log = self.get_log()
269
        self.assertContainsRe(log, 'error1')
270
        self.assertContainsRe(log, u'error2 \xb5 blah')
5055.4.2 by Gordon Tyler
Improved test_show_error to test kwargs passing.
271
        self.assertContainsRe(log, 'arg: blah')
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
272
        self.assertContainsRe(log, 'arg2: stuff')
273
        self.assertContainsRe(log, 'kwarg')
274
        self.assertContainsRe(log, 'Traceback \\(most recent call last\\):')
7143.15.2 by Jelmer Vernooij
Run autopep8.
275
        self.assertContainsRe(
276
            log, 'File ".*test_trace.py", line .*, in test_show_error')
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
277
        self.assertContainsRe(log, 'raise Exception\\("oops"\\)')
278
        self.assertContainsRe(log, 'Exception: oops')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
279
3173.1.12 by Martin Pool
Add test_push_log_file
280
    def test_push_log_file(self):
281
        """Can push and pop log file, and this catches mutter messages.
282
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
283
        This is primarily for use in the test framework.
3173.1.12 by Martin Pool
Add test_push_log_file
284
        """
285
        tmp1 = tempfile.NamedTemporaryFile()
286
        tmp2 = tempfile.NamedTemporaryFile()
287
        try:
288
            memento1 = push_log_file(tmp1)
289
            mutter("comment to file1")
290
            try:
291
                memento2 = push_log_file(tmp2)
292
                try:
293
                    mutter("comment to file2")
294
                finally:
295
                    pop_log_file(memento2)
296
                mutter("again to file1")
297
            finally:
298
                pop_log_file(memento1)
299
            # the files were opened in binary mode, so should have exactly
300
            # 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
301
            # have caused them to be flushed out.  need to match using regexps
302
            # as there's a timestamp at the front.
303
            tmp1.seek(0)
304
            self.assertContainsRe(tmp1.read(),
7143.15.2 by Jelmer Vernooij
Run autopep8.
305
                                  b"\\d+\\.\\d+  comment to file1\n"
306
                                  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
307
            tmp2.seek(0)
308
            self.assertContainsRe(tmp2.read(),
7143.15.2 by Jelmer Vernooij
Run autopep8.
309
                                  b"\\d+\\.\\d+  comment to file2\n")
3173.1.12 by Martin Pool
Add test_push_log_file
310
        finally:
311
            tmp1.close()
312
            tmp2.close()
313
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
314
    def test__open_brz_log_uses_stderr_for_failures(self):
315
        # 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.
316
        # warning to stderr. Since this is normally happening before logging is
317
        # set up.
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
318
        self.overrideAttr(sys, 'stderr', StringIO())
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
319
        # Set the log file to something that cannot exist
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
320
        self.overrideEnv('BRZ_LOG', '/no-such-dir/brz.log')
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
321
        self.overrideAttr(trace, '_brz_log_filename')
322
        logf = trace._open_brz_log()
7427.1.2 by Jelmer Vernooij
One more.
323
        if os.path.isdir('/no-such-dir'):
324
            raise TestSkipped('directory creation succeeded')
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
7371.1.1 by Jelmer Vernooij
Don't crash when we are unable to create the cache directory.
330
    def test__open_brz_log_ignores_cache_dir_error(self):
331
        # If the cache directory can not be created and _open_brz_log can thus
332
        # not open the file, then we should write the warning to stderr. Since
333
        # this is normally happening before logging is set up.
334
        self.overrideAttr(sys, 'stderr', StringIO())
335
        # Set the cache directory to something that cannot exist
336
        self.overrideEnv('BRZ_LOG', None)
337
        self.overrideEnv('BRZ_HOME', '/no-such-dir')
338
        self.overrideEnv('XDG_CACHE_HOME', '/no-such-dir')
339
        self.overrideAttr(trace, '_brz_log_filename')
340
        logf = trace._open_brz_log()
7427.1.1 by Jelmer Vernooij
Skip test when directory creation always succeeds.
341
        if os.path.isdir('/no-such-dir'):
342
            raise TestSkipped('directory creation succeeded')
7371.1.1 by Jelmer Vernooij
Don't crash when we are unable to create the cache directory.
343
        self.assertIs(None, logf)
344
        self.assertContainsRe(
345
            sys.stderr.getvalue(),
346
            "failed to open trace file: .* '/no-such-dir'$")
347
4985.1.5 by Vincent Ladeuil
Deploying the new overrideAttr facility further reduces the complexity
348
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
349
class TestVerbosityLevel(TestCase):
350
351
    def test_verbosity_level(self):
352
        set_verbosity_level(1)
353
        self.assertEqual(1, get_verbosity_level())
354
        self.assertTrue(is_verbose())
355
        self.assertFalse(is_quiet())
356
        set_verbosity_level(-1)
357
        self.assertEqual(-1, get_verbosity_level())
358
        self.assertFalse(is_verbose())
359
        self.assertTrue(is_quiet())
360
        set_verbosity_level(0)
361
        self.assertEqual(0, get_verbosity_level())
362
        self.assertFalse(is_verbose())
363
        self.assertFalse(is_quiet())
364
365
    def test_be_quiet(self):
366
        # Confirm the old API still works
367
        be_quiet(True)
368
        self.assertEqual(-1, get_verbosity_level())
369
        be_quiet(False)
370
        self.assertEqual(0, get_verbosity_level())
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
371
372
6015.52.1 by Martin Packman
Add tests for logging various problematic values
373
class TestLogging(TestCase):
374
    """Check logging functionality robustly records information"""
375
376
    def test_note(self):
377
        trace.note("Noted")
378
        self.assertEqual("    INFO  Noted\n", self.get_log())
379
380
    def test_warning(self):
381
        trace.warning("Warned")
382
        self.assertEqual(" WARNING  Warned\n", self.get_log())
383
384
    def test_log(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
385
        logging.getLogger("brz").error("Errored")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
386
        self.assertEqual("   ERROR  Errored\n", self.get_log())
387
388
    def test_log_sub(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
389
        logging.getLogger("brz.test_log_sub").debug("Whispered")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
390
        self.assertEqual("   DEBUG  Whispered\n", self.get_log())
391
392
    def test_log_unicode_msg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
393
        logging.getLogger("brz").debug(u"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
394
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
395
396
    def test_log_unicode_arg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
397
        logging.getLogger("brz").debug("%s", u"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
398
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
399
400
    def test_log_utf8_msg(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
401
        logging.getLogger("brz").debug(b"\xc2\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
402
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
403
404
    def test_log_utf8_arg(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
405
        logging.getLogger("brz").debug(b"%s", b"\xc2\xa7")
7479.2.1 by Jelmer Vernooij
Drop python2 support.
406
        expected = u"   DEBUG  b'\\xc2\\xa7'\n"
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
407
        self.assertEqual(expected, self.get_log())
6015.52.1 by Martin Packman
Add tests for logging various problematic values
408
409
    def test_log_bytes_msg(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
410
        logging.getLogger("brz").debug(b"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
411
        log = self.get_log()
412
        self.assertContainsString(log, "UnicodeDecodeError: ")
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
413
        self.assertContainsRe(
414
            log, "Logging record unformattable: b?'\\\\xa7' % \\(\\)\n")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
415
416
    def test_log_bytes_arg(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
417
        logging.getLogger("brz").debug(b"%s", b"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
418
        log = self.get_log()
7479.2.1 by Jelmer Vernooij
Drop python2 support.
419
        self.assertEqual(u"   DEBUG  b'\\xa7'\n", self.get_log())
6015.52.1 by Martin Packman
Add tests for logging various problematic values
420
421
    def test_log_mixed_strings(self):
6677.1.5 by Martin
Make crash debug and trace modules pass on Python 3
422
        logging.getLogger("brz").debug(u"%s", b"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
423
        log = self.get_log()
7479.2.1 by Jelmer Vernooij
Drop python2 support.
424
        self.assertEqual(u"   DEBUG  b'\\xa7'\n", self.get_log())
6015.52.1 by Martin Packman
Add tests for logging various problematic values
425
426
    def test_log_repr_broken(self):
427
        class BadRepr(object):
428
            def __repr__(self):
429
                raise ValueError("Broken object")
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
430
        logging.getLogger("brz").debug("%s", BadRepr())
6015.52.1 by Martin Packman
Add tests for logging various problematic values
431
        log = self.get_log()
432
        self.assertContainsRe(log, "ValueError: Broken object\n")
433
        self.assertContainsRe(log, "Logging record unformattable: '%s' % .*\n")
434
435
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
436
class TestBzrLog(TestCaseInTempDir):
437
438
    def test_log_rollover(self):
439
        temp_log_name = 'test-log'
440
        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.
441
        trace_file.writelines(['test_log_rollover padding\n'] * 200000)
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
442
        trace_file.close()
443
        _rollover_trace_maybe(temp_log_name)
444
        # should have been rolled over
445
        self.assertFalse(os.access(temp_log_name, os.R_OK))
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
446
447
448
class TestTraceConfiguration(TestCaseInTempDir):
449
450
    def test_default_config(self):
451
        config = trace.DefaultConfig()
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
452
        self.overrideAttr(trace, "_brz_log_filename", None)
453
        trace._brz_log_filename = None
454
        expected_filename = trace._get_brz_log_filename()
455
        self.assertEqual(None, trace._brz_log_filename)
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
456
        config.__enter__()
457
        try:
458
            # Should have entered and setup a default filename.
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
459
            self.assertEqual(expected_filename, trace._brz_log_filename)
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
460
        finally:
461
            config.__exit__(None, None, None)
462
            # Should have exited and cleaned up.
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
463
            self.assertEqual(None, trace._brz_log_filename)