~bzr-pqm/bzr/bzr.dev

5557.1.7 by John Arbash Meinel
Merge in the bzr.dev 5582
1
# Copyright (C) 2005-2011 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
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
21
from cStringIO import StringIO
1740.5.7 by Martin Pool
Add test for formatting of EPIPE
22
import errno
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
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
28
from bzrlib 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
    )
5200.4.5 by Martin
Move pywintypes ModuleAvailableFeature to bzrlib.tests.features
33
from bzrlib.tests import features, TestCaseInTempDir, TestCase
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
34
from bzrlib.trace import (
35
    mutter, mutter_callsite, report_exception,
36
    set_verbosity_level, get_verbosity_level, is_quiet, is_verbose, be_quiet,
3173.1.12 by Martin Pool
Add test_push_log_file
37
    pop_log_file,
38
    push_log_file,
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
39
    _rollover_trace_maybe,
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
40
    show_error,
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
41
    )
1185.33.9 by Martin Pool
Add new selftest module.
42
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
43
44
def _format_exception():
45
    """Format an exception as it would normally be displayed to the user"""
46
    buf = StringIO()
5765.1.1 by John Arbash Meinel
Merge Federico Culloca's PointlessCommit message, and revert accidental changes.
47
    report_exception(sys.exc_info(), buf)
1551.9.3 by Aaron Bentley
Revert buggy apport changes
48
    return buf.getvalue()
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
49
50
1185.33.9 by Martin Pool
Add new selftest module.
51
class TestTrace(TestCase):
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
52
1551.9.3 by Aaron Bentley
Revert buggy apport changes
53
    def test_format_sys_exception(self):
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
54
        # Test handling of an internal/unexpected error that probably
55
        # indicates a bug in bzr.  The details of the message may vary
56
        # depending on whether apport is available or not.  See test_crash for
57
        # more.
1185.33.9 by Martin Pool
Add new selftest module.
58
        try:
59
            raise NotImplementedError, "time travel"
60
        except NotImplementedError:
61
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
62
        err = _format_exception()
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
63
        self.assertEqualDiff(err.splitlines()[0],
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
64
                'bzr: ERROR: exceptions.NotImplementedError: time travel')
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
65
        self.assertContainsRe(err,
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
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
73
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
74
        msg = _format_exception()
1740.5.3 by Martin Pool
Cleanup more exception-formatting code
75
        self.assertTrue(len(msg) > 0)
76
        self.assertEqualDiff(msg, 'bzr: interrupted\n')
77
4634.26.1 by Martin Pool
Cleaner message when out of memory
78
    def test_format_memory_error(self):
79
        try:
80
            raise MemoryError()
81
        except MemoryError:
82
            pass
83
        msg = _format_exception()
84
        self.assertEquals(msg,
5448.5.7 by Karl Bielefeldt
Fix test_format_memory_error self test
85
            "bzr: 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:
93
            pass
94
        msg = _format_exception()
95
        self.assertStartsWith(msg,
96
            "bzr: out of memory\nMemory dumped to ")
97
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
98
    def test_format_os_error(self):
99
        try:
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
100
            os.rmdir('nosuchfile22222')
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
101
        except OSError, e:
102
            e_str = str(e)
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
103
        msg = _format_exception()
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
104
        # Linux seems to give "No such file" but Windows gives "The system
105
        # cannot find the file specified".
106
        self.assertEqual('bzr: ERROR: %s\n' % (e_str,), msg)
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
107
108
    def test_format_io_error(self):
109
        try:
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
110
            file('nosuchfile22222')
4095.1.1 by Martin Pool
Add more distinct tests for IOError and OSError
111
        except IOError:
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
112
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
113
        msg = _format_exception()
4789.22.1 by John Arbash Meinel
Fix a test_trace failure on Windows.
114
        # Even though Windows and Linux differ for 'os.rmdir', they both give
115
        # 'No such file' for open()
6138.3.11 by Jonathan Riddell
this test gets translated so can not check for specific message
116
        # 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.
117
        self.assertContainsRe(msg,
6138.3.11 by Jonathan Riddell
this test gets translated so can not check for specific message
118
            r'^bzr: ERROR: \[Errno .*\] .*nosuchfile')
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
119
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
120
    def test_format_pywintypes_error(self):
5200.4.5 by Martin
Move pywintypes ModuleAvailableFeature to bzrlib.tests.features
121
        self.requireFeature(features.pywintypes)
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
122
        import pywintypes, win32file
123
        try:
124
            win32file.RemoveDirectory('nosuchfile22222')
125
        except pywintypes.error:
126
            pass
127
        msg = _format_exception()
128
        # GZ 2010-05-03: Formatting for pywintypes.error is basic, a 3-tuple
129
        #                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
130
        self.assertContainsRe(msg,
5200.4.3 by Martin
Allow real with terminal A or W in function name for pywin32 trace test
131
            r"^bzr: 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
132
            
133
    def test_format_sockets_error(self):
134
        try:
5920.2.2 by Toon Nolten
Fixed typo, and import
135
            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
136
            sock = socket.socket()
5920.2.3 by Toon Nolten
More general test.
137
            sock.send("This should fail.")
5920.2.2 by Toon Nolten
Fixed typo, and import
138
        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
139
            pass
140
        msg = _format_exception()
141
        
5920.2.3 by Toon Nolten
More general test.
142
        self.assertNotContainsRe(msg,
143
            r"Traceback (most recent call last):")
5200.4.1 by Martin
Test how pywintypes.error is displayed to the user
144
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
145
    def test_format_unicode_error(self):
146
        try:
147
            raise errors.BzrCommandError(u'argument foo\xb5 does not exist')
148
        except errors.BzrCommandError:
149
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
150
        msg = _format_exception()
1740.5.5 by Martin Pool
Show short form for OSError and IOError too
151
1185.33.9 by Martin Pool
Add new selftest module.
152
    def test_format_exception(self):
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
153
        """Short formatting of bzr exceptions"""
1185.33.9 by Martin Pool
Add new selftest module.
154
        try:
2067.3.1 by Martin Pool
Clean up BzrNewError, other exception classes and users.
155
            raise errors.NotBranchError('wibble')
1948.1.5 by John Arbash Meinel
Make sure BzrCommandError can handle unicode arguments
156
        except errors.NotBranchError:
1185.33.9 by Martin Pool
Add new selftest module.
157
            pass
1551.9.3 by Aaron Bentley
Revert buggy apport changes
158
        msg = _format_exception()
1740.5.2 by Martin Pool
Improved tests for display of exceptions.
159
        self.assertTrue(len(msg) > 0)
2745.3.2 by Daniel Watkins
Updated tests to reflect new error text.
160
        self.assertEqualDiff(msg, 'bzr: ERROR: Not a branch: \"wibble\".\n')
1185.33.63 by Martin Pool
Better display of BzrError classes that are not BzrNewErrors.
161
3497.3.2 by Martin Pool
Show short error for missing libraries
162
    def test_report_external_import_error(self):
163
        """Short friendly message for missing system modules."""
164
        try:
165
            import ImaginaryModule
166
        except ImportError, e:
167
            pass
168
        else:
169
            self.fail("somehow succeeded in importing %r" % ImaginaryModule)
170
        msg = _format_exception()
171
        self.assertEqual(msg,
172
            'bzr: ERROR: No module named ImaginaryModule\n'
173
            'You may need to install this Python library separately.\n')
174
175
    def test_report_import_syntax_error(self):
176
        try:
177
            raise ImportError("syntax error")
178
        except ImportError, e:
179
            pass
180
        msg = _format_exception()
181
        self.assertContainsRe(msg,
4584.3.20 by Martin Pool
Tweak trace tests to cope without the traceback being printed
182
            r'Bazaar has encountered an internal error')
3497.3.2 by Martin Pool
Show short error for missing libraries
183
1185.33.51 by Martin Pool
Fix trace of non-ascii messages, and add test.
184
    def test_trace_unicode(self):
185
        """Write Unicode to trace log"""
186
        self.log(u'the unicode character for benzene is \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 for benzene is")
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
189
1948.1.2 by John Arbash Meinel
Fix the test_trace functions to actually test that things are written to the log
190
    def test_trace_argument_unicode(self):
191
        """Write a Unicode argument to the trace log"""
192
        mutter(u'the unicode character for benzene is %s', u'\N{BENZENE RING}')
4794.1.15 by Robert Collins
Review feedback.
193
        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.
194
        self.assertContainsRe(log, 'the unicode character')
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
195
1948.1.3 by John Arbash Meinel
Fix mutter() so even if args are invalid, it still works
196
    def test_trace_argument_utf8(self):
197
        """Write a Unicode argument to the trace log"""
198
        mutter(u'the unicode character for benzene is %s',
199
               u'\N{BENZENE RING}'.encode('utf-8'))
4794.1.15 by Robert Collins
Review feedback.
200
        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.
201
        self.assertContainsRe(log, 'the unicode character')
1948.1.3 by John Arbash Meinel
Fix mutter() so even if args are invalid, it still works
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')
206
        except IOError, e:
1551.9.3 by Aaron Bentley
Revert buggy apport changes
207
            msg = _format_exception()
1740.5.7 by Martin Pool
Add test for formatting of EPIPE
208
            self.assertEquals(msg, "bzr: broken pipe\n")
209
        else:
210
            self.fail("expected error not raised")
1740.5.9 by Martin Pool
[merge] bzr.dev
211
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)
212
    def assertLogStartsWith(self, log, string):
213
        """Like assertStartsWith, but skips the log timestamp."""
214
        self.assertContainsRe(log,
215
            '^\\d+\\.\\d+  ' + re.escape(string))
216
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
217
    def test_mutter_callsite_1(self):
218
        """mutter_callsite can capture 1 level of stack frame."""
219
        mutter_callsite(1, "foo %s", "a string")
4794.1.15 by Robert Collins
Review feedback.
220
        log = self.get_log()
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
221
        # 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)
222
        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.
223
        # should show two frame: this frame and the one above
224
        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)
225
            '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.
226
        # this frame should be the final one
227
        self.assertEndsWith(log, ' "a string")\n')
228
229
    def test_mutter_callsite_2(self):
230
        """mutter_callsite can capture 2 levels of stack frame."""
231
        mutter_callsite(2, "foo %s", "a string")
4794.1.15 by Robert Collins
Review feedback.
232
        log = self.get_log()
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
233
        # 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)
234
        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.
235
        # should show two frame: this frame and the one above
236
        self.assertContainsRe(log,
237
            'test_trace.py", line \d+, in test_mutter_callsite_2\n')
238
        # this frame should be the final one
239
        self.assertEndsWith(log, ' "a string")\n')
240
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
241
    def test_mutter_never_fails(self):
242
        # Even if the decode/encode stage fails, mutter should not
243
        # 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.
244
        # This test checks that mutter doesn't fail; the current behaviour
245
        # 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
246
        mutter(u'Writing a greek mu (\xb5) works in a unicode string')
247
        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
248
        mutter('and in an ascii argument: %s', '\xb5')
4794.1.15 by Robert Collins
Review feedback.
249
        log = self.get_log()
1185.85.5 by John Arbash Meinel
mutter() should not fail because of unicode errors
250
        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
251
        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.
252
        # However, the log content object does unicode replacement on reading
253
        # to let it get unicode back where good data has been written. So we
254
        # have to do a replaceent here as well.
255
        self.assertContainsRe(log, "ascii argument: \xb5".decode('utf8',
256
            'replace'))
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
257
        
258
    def test_show_error(self):
259
        show_error('error1')
260
        show_error(u'error2 \xb5 blah')
5055.4.2 by Gordon Tyler
Improved test_show_error to test kwargs passing.
261
        show_error('arg: %s', 'blah')
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
262
        show_error('arg2: %(key)s', {'key':'stuff'})
263
        try:
264
            raise Exception("oops")
265
        except:
266
            show_error('kwarg', exc_info=True)
5055.4.1 by Gordon Tyler
Fixed show_error args and added test for show_error.
267
        log = self.get_log()
268
        self.assertContainsRe(log, 'error1')
269
        self.assertContainsRe(log, u'error2 \xb5 blah')
5055.4.2 by Gordon Tyler
Improved test_show_error to test kwargs passing.
270
        self.assertContainsRe(log, 'arg: blah')
5055.4.3 by Gordon Tyler
Improved test_show_error to check kwargs, dict substitution and exception handling.
271
        self.assertContainsRe(log, 'arg2: stuff')
272
        self.assertContainsRe(log, 'kwarg')
273
        self.assertContainsRe(log, 'Traceback \\(most recent call last\\):')
274
        self.assertContainsRe(log, 'File ".*test_trace.py", line .*, in test_show_error')
275
        self.assertContainsRe(log, 'raise Exception\\("oops"\\)')
276
        self.assertContainsRe(log, 'Exception: oops')
2725.1.1 by Robert Collins
Add -Devil flag to highlight the use of problematic API calls.
277
3173.1.12 by Martin Pool
Add test_push_log_file
278
    def test_push_log_file(self):
279
        """Can push and pop log file, and this catches mutter messages.
280
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
281
        This is primarily for use in the test framework.
3173.1.12 by Martin Pool
Add test_push_log_file
282
        """
283
        tmp1 = tempfile.NamedTemporaryFile()
284
        tmp2 = tempfile.NamedTemporaryFile()
285
        try:
286
            memento1 = push_log_file(tmp1)
287
            mutter("comment to file1")
288
            try:
289
                memento2 = push_log_file(tmp2)
290
                try:
291
                    mutter("comment to file2")
292
                finally:
293
                    pop_log_file(memento2)
294
                mutter("again to file1")
295
            finally:
296
                pop_log_file(memento1)
297
            # the files were opened in binary mode, so should have exactly
298
            # 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
299
            # have caused them to be flushed out.  need to match using regexps
300
            # as there's a timestamp at the front.
301
            tmp1.seek(0)
302
            self.assertContainsRe(tmp1.read(),
303
                r"\d+\.\d+  comment to file1\n\d+\.\d+  again to file1\n")
304
            tmp2.seek(0)
305
            self.assertContainsRe(tmp2.read(),
306
                r"\d+\.\d+  comment to file2\n")
3173.1.12 by Martin Pool
Add test_push_log_file
307
        finally:
308
            tmp1.close()
309
            tmp2.close()
310
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
311
    def test__open_bzr_log_uses_stderr_for_failures(self):
312
        # If _open_bzr_log cannot open the file, then we should write the
313
        # warning to stderr. Since this is normally happening before logging is
314
        # set up.
4985.1.5 by Vincent Ladeuil
Deploying the new overrideAttr facility further reduces the complexity
315
        self.overrideAttr(sys, 'stderr', StringIO())
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
316
        # Set the log file to something that cannot exist
5570.3.9 by Vincent Ladeuil
More use cases for overrideEnv, _cleanEnvironment *may* contain too much variables now.
317
        self.overrideEnv('BZR_LOG', os.getcwd() + '/no-dir/bzr.log')
4985.1.5 by Vincent Ladeuil
Deploying the new overrideAttr facility further reduces the complexity
318
        self.overrideAttr(trace, '_bzr_log_filename')
4634.118.1 by John Arbash Meinel
Fix bug #503886, errors setting up logging go to stderr.
319
        logf = trace._open_bzr_log()
320
        self.assertIs(None, logf)
321
        self.assertContainsRe(sys.stderr.getvalue(),
322
                              'failed to open trace file: .*/no-dir/bzr.log')
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
323
4985.1.5 by Vincent Ladeuil
Deploying the new overrideAttr facility further reduces the complexity
324
2768.1.10 by Ian Clatworthy
Add tests for new methods in trace.py
325
class TestVerbosityLevel(TestCase):
326
327
    def test_verbosity_level(self):
328
        set_verbosity_level(1)
329
        self.assertEqual(1, get_verbosity_level())
330
        self.assertTrue(is_verbose())
331
        self.assertFalse(is_quiet())
332
        set_verbosity_level(-1)
333
        self.assertEqual(-1, get_verbosity_level())
334
        self.assertFalse(is_verbose())
335
        self.assertTrue(is_quiet())
336
        set_verbosity_level(0)
337
        self.assertEqual(0, get_verbosity_level())
338
        self.assertFalse(is_verbose())
339
        self.assertFalse(is_quiet())
340
341
    def test_be_quiet(self):
342
        # Confirm the old API still works
343
        be_quiet(True)
344
        self.assertEqual(-1, get_verbosity_level())
345
        be_quiet(False)
346
        self.assertEqual(0, get_verbosity_level())
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
347
348
349
class TestBzrLog(TestCaseInTempDir):
350
351
    def test_log_rollover(self):
352
        temp_log_name = 'test-log'
353
        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.
354
        trace_file.writelines(['test_log_rollover padding\n'] * 200000)
2851.3.1 by Martin Pool
Add unit test for _rollover_trace_maybe
355
        trace_file.close()
356
        _rollover_trace_maybe(temp_log_name)
357
        # should have been rolled over
358
        self.assertFalse(os.access(temp_log_name, os.R_OK))
5320.2.5 by Robert Collins
Make bzrlib startup use a trace context manager.
359
360
361
class TestTraceConfiguration(TestCaseInTempDir):
362
363
    def test_default_config(self):
364
        config = trace.DefaultConfig()
365
        self.overrideAttr(trace, "_bzr_log_filename", None)
366
        trace._bzr_log_filename = None
367
        expected_filename = trace._get_bzr_log_filename()
368
        self.assertEqual(None, trace._bzr_log_filename)
369
        config.__enter__()
370
        try:
371
            # Should have entered and setup a default filename.
372
            self.assertEqual(expected_filename, trace._bzr_log_filename)
373
        finally:
374
            config.__exit__(None, None, None)
375
            # Should have exited and cleaned up.
376
            self.assertEqual(None, trace._bzr_log_filename)