/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 (
6621.22.2 by Martin
Use BytesIO or StringIO from bzrlib.sixish
34
    BytesIO,
35
    )
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
36
from . import features, TestCaseInTempDir, TestCase
37
from ..trace import (
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
38
    mutter, mutter_callsite, report_exception,
39
    set_verbosity_level, get_verbosity_level, is_quiet, is_verbose, be_quiet,
3173.1.12 by Martin Pool
Add test_push_log_file
40
    pop_log_file,
41
    push_log_file,
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
42
    _rollover_trace_maybe,
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
43
    show_error,
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
44
    )
1185.33.9 by Martin Pool
Add new selftest module.
45
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
46
47
def _format_exception():
48
    """Format an exception as it would normally be displayed to the user"""
6621.22.2 by Martin
Use BytesIO or StringIO from bzrlib.sixish
49
    buf = BytesIO()
5765.1.1 by John Arbash Meinel
Merge Federico Culloca's PointlessCommit message, and revert accidental changes.
50
    report_exception(sys.exc_info(), buf)
1551.9.3 by Aaron Bentley
Revert buggy apport changes
51
    return buf.getvalue()
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
52
53
1185.33.9 by Martin Pool
Add new selftest module.
54
class TestTrace(TestCase):
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
55
1551.9.3 by Aaron Bentley
Revert buggy apport changes
56
    def test_format_sys_exception(self):
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
57
        # Test handling of an internal/unexpected error that probably
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
58
        # 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
59
        # depending on whether apport is available or not.  See test_crash for
60
        # more.
1185.33.9 by Martin Pool
Add new selftest module.
61
        try:
6619.3.11 by Jelmer Vernooij
Use modern exceptions.
62
            raise NotImplementedError("time travel")
1185.33.9 by Martin Pool
Add new selftest module.
63
        except NotImplementedError:
64
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
65
        err = _format_exception()
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
66
        self.assertEqualDiff(err.splitlines()[0],
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
67
                'brz: ERROR: exceptions.NotImplementedError: time travel')
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
68
        self.assertContainsRe(err,
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
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
76
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
77
        msg = _format_exception()
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
78
        self.assertTrue(len(msg) > 0)
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
79
        self.assertEqualDiff(msg, 'brz: interrupted\n')
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
80
4634.26.1 by Martin Pool
Cleaner message when out of memory
81
    def test_format_memory_error(self):
82
        try:
83
            raise MemoryError()
84
        except MemoryError:
85
            pass
86
        msg = _format_exception()
6614.1.3 by Vincent Ladeuil
Fix assertEquals being deprecated by using assertEqual.
87
        self.assertEqual(msg,
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
88
            "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
89
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
90
    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
91
        self.requireFeature(features.meliae)
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
92
        debug.debug_flags.add('mem_dump')
93
        try:
94
            raise MemoryError()
95
        except MemoryError:
96
            pass
97
        msg = _format_exception()
98
        self.assertStartsWith(msg,
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
99
            "brz: out of memory\nMemory dumped to ")
5448.5.8 by Karl Bielefeldt
Add test for message format with -Dmem_dump
100
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
101
    def test_format_os_error(self):
102
        try:
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
103
            os.rmdir('nosuchfile22222')
6619.3.2 by Jelmer Vernooij
Apply 2to3 except fix.
104
        except OSError as e:
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
105
            e_str = str(e)
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
106
        msg = _format_exception()
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
107
        # Linux seems to give "No such file" but Windows gives "The system
108
        # cannot find the file specified".
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
109
        self.assertEqual('brz: ERROR: %s\n' % (e_str,), msg)
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
110
111
    def test_format_io_error(self):
112
        try:
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
113
            file('nosuchfile22222')
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
114
        except IOError:
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
115
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
116
        msg = _format_exception()
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
117
        # Even though Windows and Linux differ for 'os.rmdir', they both give
118
        # 'No such file' for open()
6138.3.11 by Jonathan Riddell
this test gets translated so can not check for specific message
119
        # 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.
120
        self.assertContainsRe(msg,
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
121
            r'^brz: ERROR: \[Errno .*\] .*nosuchfile')
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
122
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
123
    def test_format_pywintypes_error(self):
5200.4.5 by Martin
Move pywintypes ModuleAvailableFeature to bzrlib.tests.features
124
        self.requireFeature(features.pywintypes)
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
125
        import pywintypes, win32file
126
        try:
127
            win32file.RemoveDirectory('nosuchfile22222')
128
        except pywintypes.error:
129
            pass
130
        msg = _format_exception()
131
        # GZ 2010-05-03: Formatting for pywintypes.error is basic, a 3-tuple
132
        #                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
133
        self.assertContainsRe(msg,
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
134
            r"^brz: ERROR: \(2, 'RemoveDirectory[AW]?', .*\)")
5920.2.1 by Toon Nolten
Added a test for a sockets.error that wasn't caught in versions prior to python 2.6
135
            
136
    def test_format_sockets_error(self):
137
        try:
5920.2.2 by Toon Nolten
Fixed typo, and import
138
            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
139
            sock = socket.socket()
5920.2.3 by Toon Nolten
More general test.
140
            sock.send("This should fail.")
5920.2.2 by Toon Nolten
Fixed typo, and import
141
        except socket.error:
5920.2.1 by Toon Nolten
Added a test for a sockets.error that wasn't caught in versions prior to python 2.6
142
            pass
143
        msg = _format_exception()
144
        
5920.2.3 by Toon Nolten
More general test.
145
        self.assertNotContainsRe(msg,
146
            r"Traceback (most recent call last):")
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
147
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
148
    def test_format_unicode_error(self):
149
        try:
150
            raise errors.BzrCommandError(u'argument foo\xb5 does not exist')
151
        except errors.BzrCommandError:
152
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
153
        msg = _format_exception()
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
154
1185.33.9 by Martin Pool
Add new selftest module.
155
    def test_format_exception(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
156
        """Short formatting of brz exceptions"""
1185.33.9 by Martin Pool
Add new selftest module.
157
        try:
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
158
            raise errors.NotBranchError('wibble')
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
159
        except errors.NotBranchError:
1185.33.9 by Martin Pool
Add new selftest module.
160
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
161
        msg = _format_exception()
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
162
        self.assertTrue(len(msg) > 0)
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
163
        self.assertEqualDiff(msg, 'brz: ERROR: Not a branch: \"wibble\".\n')
1185.33.63 by Martin Pool
Better display of BzrError classes that are not BzrNewErrors.
164
3497.3.2 by Martin Pool
Show short error for missing libraries
165
    def test_report_external_import_error(self):
166
        """Short friendly message for missing system modules."""
167
        try:
168
            import ImaginaryModule
6619.3.2 by Jelmer Vernooij
Apply 2to3 except fix.
169
        except ImportError as e:
3497.3.2 by Martin Pool
Show short error for missing libraries
170
            pass
171
        else:
172
            self.fail("somehow succeeded in importing %r" % ImaginaryModule)
173
        msg = _format_exception()
174
        self.assertEqual(msg,
6622.1.27 by Jelmer Vernooij
s/bzr/brz/
175
            'brz: ERROR: No module named ImaginaryModule\n'
3497.3.2 by Martin Pool
Show short error for missing libraries
176
            'You may need to install this Python library separately.\n')
177
178
    def test_report_import_syntax_error(self):
179
        try:
180
            raise ImportError("syntax error")
6619.3.2 by Jelmer Vernooij
Apply 2to3 except fix.
181
        except ImportError as e:
3497.3.2 by Martin Pool
Show short error for missing libraries
182
            pass
183
        msg = _format_exception()
184
        self.assertContainsRe(msg,
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
185
            r'Bazaar has encountered an internal error')
3497.3.2 by Martin Pool
Show short error for missing libraries
186
1185.33.51 by Martin Pool
Fix trace of non-ascii messages, and add test.
187
    def test_trace_unicode(self):
188
        """Write Unicode to trace log"""
189
        self.log(u'the unicode character for benzene is \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 for benzene is")
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
192
1948.1.2 by John Arbash Meinel
Fix the test_trace functions to actually test that things are written to the log
193
    def test_trace_argument_unicode(self):
194
        """Write a Unicode argument to the trace log"""
195
        mutter(u'the unicode character for benzene is %s', u'\N{BENZENE RING}')
4794.1.15 by Robert Collins
Review feedback.
196
        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.
197
        self.assertContainsRe(log, 'the unicode character')
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
198
1948.1.3 by John Arbash Meinel
Fix mutter() so even if args are invalid, it still works
199
    def test_trace_argument_utf8(self):
200
        """Write a Unicode argument to the trace log"""
201
        mutter(u'the unicode character for benzene is %s',
202
               u'\N{BENZENE RING}'.encode('utf-8'))
4794.1.15 by Robert Collins
Review feedback.
203
        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.
204
        self.assertContainsRe(log, 'the unicode character')
1948.1.3 by John Arbash Meinel
Fix mutter() so even if args are invalid, it still works
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
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
    def assertLogStartsWith(self, log, string):
216
        """Like assertStartsWith, but skips the log timestamp."""
217
        self.assertContainsRe(log,
218
            '^\\d+\\.\\d+  ' + re.escape(string))
219
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
220
    def test_mutter_callsite_1(self):
221
        """mutter_callsite can capture 1 level of stack frame."""
222
        mutter_callsite(1, "foo %s", "a string")
4794.1.15 by Robert Collins
Review feedback.
223
        log = self.get_log()
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
224
        # begin with the message
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)
225
        self.assertLogStartsWith(log, 'foo a string\nCalled from:\n')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
226
        # should show two frame: this frame and the one above
227
        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)
228
            '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.
229
        # this frame should be the final one
230
        self.assertEndsWith(log, ' "a string")\n')
231
232
    def test_mutter_callsite_2(self):
233
        """mutter_callsite can capture 2 levels of stack frame."""
234
        mutter_callsite(2, "foo %s", "a string")
4794.1.15 by Robert Collins
Review feedback.
235
        log = self.get_log()
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
236
        # begin with the message
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)
237
        self.assertLogStartsWith(log, 'foo a string\nCalled from:\n')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
238
        # should show two frame: this frame and the one above
239
        self.assertContainsRe(log,
240
            'test_trace.py", line \d+, in test_mutter_callsite_2\n')
241
        # this frame should be the final one
242
        self.assertEndsWith(log, ' "a string")\n')
243
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
244
    def test_mutter_never_fails(self):
245
        # Even if the decode/encode stage fails, mutter should not
246
        # raise an exception
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.
247
        # This test checks that mutter doesn't fail; the current behaviour
248
        # is that it doesn't fail *and writes non-utf8*.
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
249
        mutter(u'Writing a greek mu (\xb5) works in a unicode string')
250
        mutter('But fails in an ascii string \xb5')
1948.1.4 by John Arbash Meinel
Update test_never_fails, to cover one of the failure points
251
        mutter('and in an ascii argument: %s', '\xb5')
4794.1.15 by Robert Collins
Review feedback.
252
        log = self.get_log()
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
253
        self.assertContainsRe(log, 'Writing a greek mu')
1948.1.9 by John Arbash Meinel
Change mutter() so that it doesn't try so hard to write out perfect utf8, instead, rather than using a utf8 file, it changes unicode to utf8 manually
254
        self.assertContainsRe(log, "But fails in an ascii string")
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.
255
        # However, the log content object does unicode replacement on reading
256
        # to let it get unicode back where good data has been written. So we
257
        # have to do a replaceent here as well.
258
        self.assertContainsRe(log, "ascii argument: \xb5".decode('utf8',
259
            'replace'))
6325.3.1 by Vincent Ladeuil
Give meaningful deprecation warnings for deprecated test features
260
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
261
    def test_show_error(self):
262
        show_error('error1')
263
        show_error(u'error2 \xb5 blah')
5055.4.2 by Gordon Tyler
Improved test_show_error to test kwargs passing.
264
        show_error('arg: %s', 'blah')
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
265
        show_error('arg2: %(key)s', {'key':'stuff'})
266
        try:
267
            raise Exception("oops")
268
        except:
269
            show_error('kwarg', exc_info=True)
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
270
        log = self.get_log()
271
        self.assertContainsRe(log, 'error1')
272
        self.assertContainsRe(log, u'error2 \xb5 blah')
5055.4.2 by Gordon Tyler
Improved test_show_error to test kwargs passing.
273
        self.assertContainsRe(log, 'arg: blah')
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
274
        self.assertContainsRe(log, 'arg2: stuff')
275
        self.assertContainsRe(log, 'kwarg')
276
        self.assertContainsRe(log, 'Traceback \\(most recent call last\\):')
277
        self.assertContainsRe(log, 'File ".*test_trace.py", line .*, in test_show_error')
278
        self.assertContainsRe(log, 'raise Exception\\("oops"\\)')
279
        self.assertContainsRe(log, 'Exception: oops')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
280
3173.1.12 by Martin Pool
Add test_push_log_file
281
    def test_push_log_file(self):
282
        """Can push and pop log file, and this catches mutter messages.
283
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
284
        This is primarily for use in the test framework.
3173.1.12 by Martin Pool
Add test_push_log_file
285
        """
286
        tmp1 = tempfile.NamedTemporaryFile()
287
        tmp2 = tempfile.NamedTemporaryFile()
288
        try:
289
            memento1 = push_log_file(tmp1)
290
            mutter("comment to file1")
291
            try:
292
                memento2 = push_log_file(tmp2)
293
                try:
294
                    mutter("comment to file2")
295
                finally:
296
                    pop_log_file(memento2)
297
                mutter("again to file1")
298
            finally:
299
                pop_log_file(memento1)
300
            # the files were opened in binary mode, so should have exactly
301
            # 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
302
            # have caused them to be flushed out.  need to match using regexps
303
            # as there's a timestamp at the front.
304
            tmp1.seek(0)
305
            self.assertContainsRe(tmp1.read(),
306
                r"\d+\.\d+  comment to file1\n\d+\.\d+  again to file1\n")
307
            tmp2.seek(0)
308
            self.assertContainsRe(tmp2.read(),
309
                r"\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.
6621.22.2 by Martin
Use BytesIO or StringIO from bzrlib.sixish
318
        self.overrideAttr(sys, 'stderr', BytesIO())
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()
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
323
        self.assertIs(None, logf)
6619.3.26 by Martin
Fix fallout from 2to3 getcwdu transformation and other test uses
324
        self.assertContainsRe(
325
            sys.stderr.getvalue(),
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
326
            "failed to open trace file: .* '/no-such-dir/brz.log'$")
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
327
4985.1.5 by Vincent Ladeuil
Deploying the new overrideAttr facility further reduces the complexity
328
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
329
class TestVerbosityLevel(TestCase):
330
331
    def test_verbosity_level(self):
332
        set_verbosity_level(1)
333
        self.assertEqual(1, get_verbosity_level())
334
        self.assertTrue(is_verbose())
335
        self.assertFalse(is_quiet())
336
        set_verbosity_level(-1)
337
        self.assertEqual(-1, get_verbosity_level())
338
        self.assertFalse(is_verbose())
339
        self.assertTrue(is_quiet())
340
        set_verbosity_level(0)
341
        self.assertEqual(0, get_verbosity_level())
342
        self.assertFalse(is_verbose())
343
        self.assertFalse(is_quiet())
344
345
    def test_be_quiet(self):
346
        # Confirm the old API still works
347
        be_quiet(True)
348
        self.assertEqual(-1, get_verbosity_level())
349
        be_quiet(False)
350
        self.assertEqual(0, get_verbosity_level())
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
351
352
6015.52.1 by Martin Packman
Add tests for logging various problematic values
353
class TestLogging(TestCase):
354
    """Check logging functionality robustly records information"""
355
356
    def test_note(self):
357
        trace.note("Noted")
358
        self.assertEqual("    INFO  Noted\n", self.get_log())
359
360
    def test_warning(self):
361
        trace.warning("Warned")
362
        self.assertEqual(" WARNING  Warned\n", self.get_log())
363
364
    def test_log(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
365
        logging.getLogger("brz").error("Errored")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
366
        self.assertEqual("   ERROR  Errored\n", self.get_log())
367
368
    def test_log_sub(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
369
        logging.getLogger("brz.test_log_sub").debug("Whispered")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
370
        self.assertEqual("   DEBUG  Whispered\n", self.get_log())
371
372
    def test_log_unicode_msg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
373
        logging.getLogger("brz").debug(u"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
374
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
375
376
    def test_log_unicode_arg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
377
        logging.getLogger("brz").debug("%s", u"\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
378
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
379
380
    def test_log_utf8_msg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
381
        logging.getLogger("brz").debug("\xc2\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
382
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
383
384
    def test_log_utf8_arg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
385
        logging.getLogger("brz").debug("%s", "\xc2\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
386
        self.assertEqual(u"   DEBUG  \xa7\n", self.get_log())
387
388
    def test_log_bytes_msg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
389
        logging.getLogger("brz").debug("\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
390
        log = self.get_log()
391
        self.assertContainsString(log, "UnicodeDecodeError: ")
392
        self.assertContainsString(log,
393
            "Logging record unformattable: '\\xa7' % ()\n")
394
395
    def test_log_bytes_arg(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
396
        logging.getLogger("brz").debug("%s", "\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
397
        log = self.get_log()
398
        self.assertContainsString(log, "UnicodeDecodeError: ")
399
        self.assertContainsString(log,
400
            "Logging record unformattable: '%s' % ('\\xa7',)\n")
401
402
    def test_log_mixed_strings(self):
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
403
        logging.getLogger("brz").debug(u"%s", "\xa7")
6015.52.1 by Martin Packman
Add tests for logging various problematic values
404
        log = self.get_log()
405
        self.assertContainsString(log, "UnicodeDecodeError: ")
406
        self.assertContainsString(log,
407
            "Logging record unformattable: u'%s' % ('\\xa7',)\n")
408
409
    def test_log_repr_broken(self):
410
        class BadRepr(object):
411
            def __repr__(self):
412
                raise ValueError("Broken object")
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
413
        logging.getLogger("brz").debug("%s", BadRepr())
6015.52.1 by Martin Packman
Add tests for logging various problematic values
414
        log = self.get_log()
415
        self.assertContainsRe(log, "ValueError: Broken object\n")
416
        self.assertContainsRe(log, "Logging record unformattable: '%s' % .*\n")
417
418
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
419
class TestBzrLog(TestCaseInTempDir):
420
421
    def test_log_rollover(self):
422
        temp_log_name = 'test-log'
423
        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.
424
        trace_file.writelines(['test_log_rollover padding\n'] * 200000)
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
425
        trace_file.close()
426
        _rollover_trace_maybe(temp_log_name)
427
        # should have been rolled over
428
        self.assertFalse(os.access(temp_log_name, os.R_OK))
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
429
430
431
class TestTraceConfiguration(TestCaseInTempDir):
432
433
    def test_default_config(self):
434
        config = trace.DefaultConfig()
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
435
        self.overrideAttr(trace, "_brz_log_filename", None)
436
        trace._brz_log_filename = None
437
        expected_filename = trace._get_brz_log_filename()
438
        self.assertEqual(None, trace._brz_log_filename)
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
439
        config.__enter__()
440
        try:
441
            # Should have entered and setup a default filename.
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
442
            self.assertEqual(expected_filename, trace._brz_log_filename)
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
443
        finally:
444
            config.__exit__(None, None, None)
445
            # Should have exited and cleaned up.
6622.1.33 by Jelmer Vernooij
Fix more tests (all?)
446
            self.assertEqual(None, trace._brz_log_filename)