~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/blackbox/test_debug.py

(vila) Make sure the XDG_CONFIG_HOME environment variable doesn't leak into
 any test. (Wouter van Heyst)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2006, 2007, 2009, 2010, 2011 Canonical Ltd
 
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
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
16
 
 
17
"""Blackbox tests for -D debug options"""
 
18
 
 
19
import os
 
20
import signal
 
21
import sys
 
22
import time
 
23
 
 
24
from bzrlib import debug, tests
 
25
 
 
26
 
 
27
class TestDebugOption(tests.TestCaseInTempDir):
 
28
 
 
29
    def test_dash_derror(self):
 
30
        """With -Derror, tracebacks are shown even for user errors"""
 
31
        out, err = self.run_bzr("-Derror branch nonexistent-location",
 
32
                                retcode=3)
 
33
        # error output should contain a traceback; we used to look for code in
 
34
        # here but it may be missing if the source is not in sync with the
 
35
        # pyc file.
 
36
        self.assertContainsRe(err, "Traceback \\(most recent call last\\)")
 
37
 
 
38
    def test_dash_dlock(self):
 
39
        # With -Dlock, locking and unlocking is recorded into the log
 
40
        self.run_bzr("-Dlock init foo")
 
41
        self.assertContainsRe(self.get_log(), "lock_write")
 
42
 
 
43
 
 
44
class TestDebugBytes(tests.TestCaseWithTransport):
 
45
 
 
46
    def test_bytes_reports_activity(self):
 
47
        tree = self.make_branch_and_tree('tree')
 
48
        self.build_tree(['tree/one'])
 
49
        tree.add('one')
 
50
        rev_id = tree.commit('first')
 
51
        remote_trans = self.make_smart_server('.')
 
52
        # I would like to avoid run_bzr_subprocess here, but we need it to be
 
53
        # connected to a real TextUIFactory. The NullProgressView always
 
54
        # ignores transport activity.
 
55
        env = {'BZR_PROGRESS_BAR': 'text'}
 
56
        out, err = self.run_bzr_subprocess('branch -Dbytes %s/tree target'
 
57
                                           % (remote_trans.base,),
 
58
                                           env_changes=env)
 
59
        self.assertContainsRe(err, 'Branched 1 revision')
 
60
        self.assertContainsRe(err, 'Transferred:.*kB')