~bzr-pqm/bzr/bzr.dev

5273.1.7 by Vincent Ladeuil
No more use of the get_transport imported *symbol*, all uses are through
1
# Copyright (C) 2009, 2010 Canonical Ltd
4070.8.3 by Martin Pool
Finish debug_flags support and add a test case
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
4070.8.3 by Martin Pool
Finish debug_flags support and add a test case
16
17
"""Tests for bzrlib.debug"""
18
19
5273.1.7 by Vincent Ladeuil
No more use of the get_transport imported *symbol*, all uses are through
20
from bzrlib import (
5345.1.10 by Vincent Ladeuil
Cleanup and simplify bt.test_debug.
21
    config,
5273.1.7 by Vincent Ladeuil
No more use of the get_transport imported *symbol*, all uses are through
22
    debug,
23
    tests,
24
    )
25
26
27
class TestDebugFlags(tests.TestCaseInTempDir):
4070.8.3 by Martin Pool
Finish debug_flags support and add a test case
28
6499.3.1 by Vincent Ladeuil
Split eager test.
29
    def test_set_no_debug_flags_from_config(self):
30
        self.assertDebugFlags([], '')
31
32
    def test_set_single_debug_flags_from_config(self):
33
        self.assertDebugFlags(['hpss'], 'debug_flags = hpss\n')
34
35
    def test_set_multiple_debug_flags_from_config(self):
6059.4.5 by Vincent Ladeuil
Migrate debug_flags to stack-based config.
36
        self.assertDebugFlags(['hpss', 'error'], 'debug_flags = hpss, error\n')
5345.1.10 by Vincent Ladeuil
Cleanup and simplify bt.test_debug.
37
6059.4.5 by Vincent Ladeuil
Migrate debug_flags to stack-based config.
38
    def assertDebugFlags(self, expected_flags, conf_bytes):
39
        conf = config.GlobalStack()
6260.3.2 by Vincent Ladeuil
Only the DEFAULT section is searched for the normal uses of bazaar.conf
40
        conf.store._load_from_string('[DEFAULT]\n' + conf_bytes)
6059.4.5 by Vincent Ladeuil
Migrate debug_flags to stack-based config.
41
        conf.store.save()
5345.1.10 by Vincent Ladeuil
Cleanup and simplify bt.test_debug.
42
        self.overrideAttr(debug, 'debug_flags', set())
43
        debug.set_debug_flags_from_config()
44
        self.assertEqual(set(expected_flags), debug.debug_flags)