1
# Copyright (C) 2006-2010 Canonical Ltd
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.
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.
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
17
"""UI tests for the test framework."""
24
from breezy.tests import (
27
from breezy.transport import memory
32
def get_params_passed_to_core(self, cmdline):
35
def selftest(*args, **kwargs):
36
"""Capture the arguments selftest was run with."""
37
params.append((args, kwargs))
39
# Yes this prevents using threads to run the test suite in parallel,
40
# however we don't have a clean dependency injector for commands,
41
# and even if we did - we'd still be testing that the glue is wired
42
# up correctly. XXX: TODO: Solve this testing problem.
43
original_selftest = tests.selftest
44
tests.selftest = selftest
49
tests.selftest = original_selftest
52
class TestOptions(tests.TestCase, SelfTestPatch):
54
def test_load_list(self):
55
params = self.get_params_passed_to_core('selftest --load-list foo')
56
self.assertEqual('foo', params[1]['load_list'])
58
def test_transport_set_to_sftp(self):
59
# Test that we can pass a transport to the selftest core - sftp
61
self.requireFeature(features.paramiko)
62
from breezy.tests import stub_sftp
63
params = self.get_params_passed_to_core('selftest --transport=sftp')
64
self.assertEqual(stub_sftp.SFTPAbsoluteServer,
65
params[1]["transport"])
67
def test_transport_set_to_memory(self):
68
# Test that we can pass a transport to the selftest core - memory
70
params = self.get_params_passed_to_core('selftest --transport=memory')
71
self.assertEqual(memory.MemoryServer, params[1]["transport"])
73
def test_parameters_passed_to_core(self):
74
params = self.get_params_passed_to_core('selftest --list-only')
75
self.assertTrue("list_only" in params[1])
76
params = self.get_params_passed_to_core(
77
'selftest --list-only selftest')
78
self.assertTrue("list_only" in params[1])
79
params = self.get_params_passed_to_core(['selftest', '--list-only',
80
'--exclude', 'selftest'])
81
self.assertTrue("list_only" in params[1])
82
params = self.get_params_passed_to_core(['selftest', '--list-only',
83
'selftest', '--randomize', 'now'])
84
self.assertSubset(["list_only", "random_seed"], params[1])
86
def test_starting_with(self):
87
params = self.get_params_passed_to_core('selftest --starting-with foo')
88
self.assertEqual(['foo'], params[1]['starting_with'])
90
def test_starting_with_multiple_argument(self):
91
params = self.get_params_passed_to_core(
92
'selftest --starting-with foo --starting-with bar')
93
self.assertEqual(['foo', 'bar'], params[1]['starting_with'])
95
def test_subunitv1(self):
96
self.requireFeature(features.subunit)
97
params = self.get_params_passed_to_core('selftest --subunit1')
98
self.assertEqual(tests.SubUnitBzrRunnerv1, params[1]['runner_class'])
100
def test_subunitv2(self):
101
self.requireFeature(features.subunit)
102
params = self.get_params_passed_to_core('selftest --subunit2')
103
self.assertEqual(tests.SubUnitBzrRunnerv2, params[1]['runner_class'])
105
def _parse_test_list(self, lines, newlines_in_header=0):
106
"Parse a list of lines into a tuple of 3 lists (header,body,footer)."
107
in_header = newlines_in_header != 0
112
header_newlines_found = 0
116
header_newlines_found += 1
117
if header_newlines_found >= newlines_in_header:
122
if line.startswith('-------'):
128
# If the last body line is blank, drop it off the list
129
if len(body) > 0 and body[-1] == '':
131
return (header, body, footer)
133
def test_list_only(self):
134
# check that brz selftest --list-only outputs no ui noise
135
def selftest(*args, **kwargs):
136
"""Capture the arguments selftest was run with."""
139
def outputs_nothing(cmdline):
140
out, err = self.run_bzr(cmdline)
141
(header, body, footer) = self._parse_test_list(out.splitlines())
142
num_tests = len(body)
143
self.assertLength(0, header)
144
self.assertLength(0, footer)
145
self.assertEqual('', err)
146
# Yes this prevents using threads to run the test suite in parallel,
147
# however we don't have a clean dependency injector for commands,
148
# and even if we did - we'd still be testing that the glue is wired
149
# up correctly. XXX: TODO: Solve this testing problem.
150
original_selftest = tests.selftest
151
tests.selftest = selftest
153
outputs_nothing('selftest --list-only')
154
outputs_nothing('selftest --list-only selftest')
156
['selftest', '--list-only', '--exclude', 'selftest'])
158
tests.selftest = original_selftest
160
def test_lsprof_tests(self):
161
params = self.get_params_passed_to_core('selftest --lsprof-tests')
162
self.assertEqual(True, params[1]["lsprof_tests"])
164
def test_parallel_fork_unsupported(self):
165
if getattr(os, "fork", None) is not None:
166
self.addCleanup(setattr, os, "fork", os.fork)
168
out, err = self.run_bzr(["selftest", "--parallel=fork", "-s", "bt.x"],
170
self.assertIn("platform does not support fork", err)
171
self.assertFalse(out)