~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

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

  • Committer: Andrew Bennetts
  • Date: 2010-10-13 00:26:41 UTC
  • mto: This revision was merged to the branch mainline in revision 5498.
  • Revision ID: andrew.bennetts@canonical.com-20101013002641-9tlh9k89mlj1666m
Keep docs-plain working.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006, 2007, 2009, 2010, 2011 Canonical Ltd
 
1
# Copyright (C) 2006, 2007, 2009, 2010 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
16
16
 
17
17
"""Tests for display of exceptions."""
18
18
 
 
19
from cStringIO import StringIO
19
20
import os
20
 
import re
 
21
import sys
21
22
 
22
23
from bzrlib import (
23
24
    bzrdir,
24
25
    config,
25
 
    controldir,
26
26
    errors,
27
27
    osutils,
28
28
    repository,
29
29
    tests,
 
30
    trace,
30
31
    )
31
 
from bzrlib.repofmt.groupcompress_repo import RepositoryFormat2a
32
 
 
33
 
 
34
 
class TestExceptionReporting(tests.TestCaseInTempDir):
 
32
 
 
33
from bzrlib.tests import TestCaseInTempDir, TestCase
 
34
from bzrlib.errors import NotBranchError
 
35
 
 
36
 
 
37
class TestExceptionReporting(TestCase):
35
38
 
36
39
    def test_exception_exitcode(self):
37
40
        # we must use a subprocess, because the normal in-memory mechanism
44
47
                r'exceptions\.AssertionError: always fails\n')
45
48
        self.assertContainsRe(err, r'Bazaar has encountered an internal error')
46
49
 
47
 
    def test_undecodable_argv(self):
48
 
        """A user error must be reported if argv is not in the locale encoding
49
 
 
50
 
        A subprocess with an environment ascii-only setting is used so the test
51
 
        can run without worrying about the locale the test suite is using.
52
 
        """
53
 
        if os.name != "posix":
54
 
            raise tests.TestNotApplicable("Needs system beholden to C locales")
55
 
        out, err = self.run_bzr_subprocess(["\xa0"],
56
 
            env_changes={"LANG": "C", "LC_ALL": "C"},
57
 
            universal_newlines=True,
58
 
            retcode=errors.EXIT_ERROR)
59
 
        self.assertContainsRe(err, r"^bzr: ERROR: .*'\\xa0'.* unsupported",
60
 
            flags=re.MULTILINE)
61
 
        self.assertEquals(out, "")
62
 
 
63
 
 
64
 
class TestOptParseBugHandling(tests.TestCase):
65
 
    "Test that we handle http://bugs.python.org/issue2931"
66
 
 
67
 
    def test_nonascii_optparse(self):
68
 
        """Reasonable error raised when non-ascii in option name"""
69
 
        error_re = 'Only ASCII permitted in option names'
70
 
        out = self.run_bzr_error([error_re], ['st',u'-\xe4'])
71
 
 
72
 
 
73
 
class TestObsoleteRepoFormat(RepositoryFormat2a):
74
 
 
75
 
    @classmethod
76
 
    def get_format_string(cls):
77
 
        return "Test Obsolete Repository Format"
78
 
 
79
 
    def is_deprecated(self):
80
 
        return True
81
 
 
82
50
 
83
51
class TestDeprecationWarning(tests.TestCaseWithTransport):
84
52
    """The deprecation warning is controlled via a global variable:
91
59
 
92
60
    def setUp(self):
93
61
        super(TestDeprecationWarning, self).setUp()
94
 
        self.addCleanup(repository.format_registry.remove,
95
 
            TestObsoleteRepoFormat)
96
 
        repository.format_registry.register(TestObsoleteRepoFormat)
97
 
        self.addCleanup(controldir.format_registry.remove, "testobsolete")
98
 
        bzrdir.register_metadir(controldir.format_registry, "testobsolete",
99
 
            "bzrlib.tests.blackbox.test_exceptions.TestObsoleteRepoFormat",
100
 
            branch_format='bzrlib.branch.BzrBranchFormat7',
101
 
            tree_format='bzrlib.workingtree_4.WorkingTreeFormat6',
102
 
            deprecated=True,
103
 
            help='Same as 2a, but with an obsolete repo format.')
104
62
        self.disable_deprecation_warning()
105
63
 
106
64
    def enable_deprecation_warning(self, repo=None):
113
71
 
114
72
    def make_obsolete_repo(self, path):
115
73
        # We don't want the deprecation raising during the repo creation
116
 
        format = controldir.format_registry.make_bzrdir("testobsolete")
117
 
        tree = self.make_branch_and_tree(path, format=format)
 
74
        tree = self.make_branch_and_tree(path, format=bzrdir.BzrDirFormat5())
118
75
        return tree
119
76
 
120
77
    def check_warning(self, present):
122
79
            check = self.assertContainsRe
123
80
        else:
124
81
            check = self.assertNotContainsRe
125
 
        check(self.get_log(), 'WARNING.*bzr upgrade')
 
82
        check(self._get_log(keep_log_file=True), 'WARNING.*bzr upgrade')
126
83
 
127
84
    def test_repository_deprecation_warning(self):
128
85
        """Old formats give a warning"""