/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

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

  • Committer: John Arbash Meinel
  • Date: 2009-12-22 16:28:47 UTC
  • mto: This revision was merged to the branch mainline in revision 4922.
  • Revision ID: john@arbash-meinel.com-20091222162847-tvnsc69to4l4uf5r
Implement a permute_for_extension helper.

Use it for all of the 'simple' extension permutations.
It basically permutes all tests in the current module, by setting TestCase.module.
Which works well for most of our extension tests. Some had more advanced
handling of permutations (extra permutations, custom vars, etc.)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2006, 2007 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
"""Tests for display of exceptions."""
 
18
 
 
19
from cStringIO import StringIO
 
20
import os
 
21
import sys
 
22
 
 
23
from bzrlib import (
 
24
    bzrdir,
 
25
    config,
 
26
    errors,
 
27
    osutils,
 
28
    repository,
 
29
    tests,
 
30
    trace,
 
31
    )
 
32
 
 
33
from bzrlib.tests import TestCaseInTempDir, TestCase
 
34
from bzrlib.errors import NotBranchError
 
35
 
 
36
 
 
37
class TestExceptionReporting(TestCase):
 
38
 
 
39
    def test_exception_exitcode(self):
 
40
        # we must use a subprocess, because the normal in-memory mechanism
 
41
        # allows errors to propagate up through the test suite
 
42
        out, err = self.run_bzr_subprocess(['assert-fail'],
 
43
            universal_newlines=True,
 
44
            retcode=errors.EXIT_INTERNAL_ERROR)
 
45
        self.assertEqual(4, errors.EXIT_INTERNAL_ERROR)
 
46
        self.assertContainsRe(err,
 
47
                r'exceptions\.AssertionError: always fails\n')
 
48
        self.assertContainsRe(err, r'Bazaar has encountered an internal error')
 
49
 
 
50
 
 
51
class TestDeprecationWarning(tests.TestCaseWithTransport):
 
52
    """The deprecation warning is controlled via a global variable:
 
53
    repository._deprecation_warning_done. As such, it can be emitted only once
 
54
    during a bzr invocation, no matter how many repositories are involved.
 
55
 
 
56
    It would be better if it was a repo attribute instead but that's far more
 
57
    work than I want to do right now -- vila 20091215.
 
58
    """
 
59
 
 
60
    def setUp(self):
 
61
        super(TestDeprecationWarning, self).setUp()
 
62
        self.disable_deprecation_warning()
 
63
 
 
64
    def enable_deprecation_warning(self, repo=None):
 
65
        """repo is not used yet since _deprecation_warning_done is a global"""
 
66
        repository._deprecation_warning_done = False
 
67
 
 
68
    def disable_deprecation_warning(self, repo=None):
 
69
        """repo is not used yet since _deprecation_warning_done is a global"""
 
70
        repository._deprecation_warning_done = True
 
71
 
 
72
    def make_obsolete_repo(self, path):
 
73
        # We don't want the deprecation raising during the repo creation
 
74
        tree = self.make_branch_and_tree(path, format=bzrdir.BzrDirFormat5())
 
75
        return tree
 
76
 
 
77
    def check_warning(self, present):
 
78
        if present:
 
79
            check = self.assertContainsRe
 
80
        else:
 
81
            check = self.assertNotContainsRe
 
82
        check(self._get_log(keep_log_file=True), 'WARNING.*bzr upgrade')
 
83
 
 
84
    def test_repository_deprecation_warning(self):
 
85
        """Old formats give a warning"""
 
86
        self.make_obsolete_repo('foo')
 
87
        self.enable_deprecation_warning()
 
88
        out, err = self.run_bzr('status', working_dir='foo')
 
89
        self.check_warning(True)
 
90
 
 
91
    def test_repository_deprecation_warning_suppressed_global(self):
 
92
        """Old formats give a warning"""
 
93
        conf = config.GlobalConfig()
 
94
        conf.set_user_option('suppress_warnings', 'format_deprecation')
 
95
        self.make_obsolete_repo('foo')
 
96
        self.enable_deprecation_warning()
 
97
        out, err = self.run_bzr('status', working_dir='foo')
 
98
        self.check_warning(False)
 
99
 
 
100
    def test_repository_deprecation_warning_suppressed_locations(self):
 
101
        """Old formats give a warning"""
 
102
        self.make_obsolete_repo('foo')
 
103
        conf = config.LocationConfig(osutils.pathjoin(self.test_dir, 'foo'))
 
104
        conf.set_user_option('suppress_warnings', 'format_deprecation')
 
105
        self.enable_deprecation_warning()
 
106
        out, err = self.run_bzr('status', working_dir='foo')
 
107
        self.check_warning(False)
 
108
 
 
109
    def test_repository_deprecation_warning_suppressed_branch(self):
 
110
        """Old formats give a warning"""
 
111
        tree = self.make_obsolete_repo('foo')
 
112
        conf = tree.branch.get_config()
 
113
        conf.set_user_option('suppress_warnings', 'format_deprecation')
 
114
        self.enable_deprecation_warning()
 
115
        out, err = self.run_bzr('status', working_dir='foo')
 
116
        self.check_warning(False)
 
117