2007-01-24 22:24:01 +08:00
|
|
|
import py
|
2007-01-28 21:25:03 +08:00
|
|
|
from setupdata import setup_module # sets up global 'tmpdir'
|
2007-02-03 20:14:46 +08:00
|
|
|
from py.__.test.outcome import Skipped, Failed, Passed, Outcome
|
2008-01-25 23:54:04 +08:00
|
|
|
from py.__.test.terminal.out import getout
|
|
|
|
from py.__.test.repevent import ReceivedItemOutcome, SkippedTryiter,\
|
|
|
|
FailedTryiter
|
2007-01-24 22:24:01 +08:00
|
|
|
|
2007-01-28 21:25:03 +08:00
|
|
|
implied_options = {
|
|
|
|
'-v': 'verbose',
|
|
|
|
'-l': 'showlocals',
|
2008-01-25 23:54:04 +08:00
|
|
|
#'--runbrowser': 'startserver and runbrowser', XXX starts browser
|
2007-01-28 21:25:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
conflict_options = ('--looponfailing --pdb',
|
|
|
|
'--dist --pdb',
|
2007-04-03 23:23:00 +08:00
|
|
|
'--exec=%s --pdb' % py.std.sys.executable,
|
2007-01-28 21:25:03 +08:00
|
|
|
)
|
|
|
|
|
2008-01-25 23:54:04 +08:00
|
|
|
def getoutcomes(all):
|
|
|
|
return [i.outcome for i in all if isinstance(i, ReceivedItemOutcome)]
|
|
|
|
|
|
|
|
|
|
|
|
def getpassed(all):
|
|
|
|
return [i for i in getoutcomes(all) if i.passed]
|
|
|
|
|
|
|
|
def getskipped(all):
|
|
|
|
return [i for i in getoutcomes(all) if i.skipped] + \
|
|
|
|
[i for i in all if isinstance(i, SkippedTryiter)]
|
|
|
|
|
|
|
|
def getfailed(all):
|
|
|
|
return [i for i in getoutcomes(all) if i.excinfo] + \
|
|
|
|
[i for i in all if isinstance(i, FailedTryiter)]
|
|
|
|
|
2007-01-28 21:25:03 +08:00
|
|
|
def test_conflict_options():
|
|
|
|
for spec in conflict_options:
|
|
|
|
opts = spec.split()
|
|
|
|
yield check_conflict_option, opts
|
|
|
|
|
|
|
|
def check_conflict_option(opts):
|
|
|
|
print "testing if options conflict:", " ".join(opts)
|
|
|
|
config = py.test.config._reparse(opts + [datadir/'filetest.py'])
|
|
|
|
py.test.raises((ValueError, SystemExit), """
|
|
|
|
config.initsession()
|
|
|
|
""")
|
|
|
|
|
|
|
|
def test_implied_options():
|
|
|
|
for key, expr in implied_options.items():
|
|
|
|
yield check_implied_option, [key], expr
|
|
|
|
|
|
|
|
def check_implied_option(opts, expr):
|
|
|
|
config = py.test.config._reparse(opts + [datadir/'filetest.py'])
|
|
|
|
session = config.initsession()
|
|
|
|
assert eval(expr, session.config.option.__dict__)
|
2007-01-24 22:24:01 +08:00
|
|
|
|
2007-01-25 00:46:46 +08:00
|
|
|
def test_default_session_options():
|
|
|
|
for opts in ([], ['-l'], ['-s'], ['--tb=no'], ['--tb=short'],
|
|
|
|
['--tb=long'], ['--fulltrace'], ['--nomagic'],
|
|
|
|
['--traceconfig'], ['-v'], ['-v', '-v']):
|
|
|
|
yield runfiletest, opts
|
2007-01-24 22:24:01 +08:00
|
|
|
|
2007-01-25 00:46:46 +08:00
|
|
|
def runfiletest(opts):
|
2008-01-25 23:54:04 +08:00
|
|
|
config = py.test.config._reparse(opts + [datadir/'filetest.py'])
|
|
|
|
all = []
|
2007-01-25 00:46:46 +08:00
|
|
|
session = config.initsession()
|
2008-01-25 23:54:04 +08:00
|
|
|
session.main(all.append)
|
|
|
|
assert len(getfailed(all)) == 2
|
|
|
|
assert not getskipped(all)
|
2007-01-24 22:24:01 +08:00
|
|
|
|
2007-02-08 02:43:23 +08:00
|
|
|
def test_is_not_boxed_by_default():
|
|
|
|
config = py.test.config._reparse([datadir])
|
|
|
|
assert not config.option.boxed
|
|
|
|
|
2007-01-24 22:24:01 +08:00
|
|
|
class TestKeywordSelection:
|
2007-10-19 21:46:10 +08:00
|
|
|
def test_select_simple(self):
|
|
|
|
def check(keyword, name):
|
2007-01-24 22:24:01 +08:00
|
|
|
config = py.test.config._reparse([datadir/'filetest.py',
|
2007-10-19 21:46:10 +08:00
|
|
|
'-s', '-k', keyword])
|
2008-01-25 23:54:04 +08:00
|
|
|
all = []
|
|
|
|
session = config._getsessionclass()(config)
|
|
|
|
session.main(all.append)
|
|
|
|
outcomes = [i for i in all if isinstance(i, ReceivedItemOutcome)]
|
|
|
|
assert len(getfailed(all)) == 1
|
|
|
|
assert outcomes[0].item.name == name
|
|
|
|
l = getskipped(all)
|
2007-10-19 21:46:10 +08:00
|
|
|
assert len(l) == 1
|
|
|
|
|
|
|
|
for keyword in ['test_one', 'est_on']:
|
|
|
|
check(keyword, 'test_one')
|
|
|
|
check('TestClass.test', 'test_method_one')
|
2007-01-24 22:24:01 +08:00
|
|
|
|
2007-10-19 21:46:10 +08:00
|
|
|
def test_select_extra_keywords(self):
|
2007-01-24 22:24:01 +08:00
|
|
|
o = tmpdir.ensure('selecttest', dir=1)
|
|
|
|
tfile = o.join('test_select.py').write(py.code.Source("""
|
|
|
|
def test_1():
|
|
|
|
pass
|
|
|
|
class TestClass:
|
|
|
|
def test_2(self):
|
|
|
|
pass
|
|
|
|
"""))
|
|
|
|
conftest = o.join('conftest.py').write(py.code.Source("""
|
|
|
|
import py
|
|
|
|
class Class(py.test.collect.Class):
|
2007-10-19 21:46:10 +08:00
|
|
|
def _keywords(self):
|
|
|
|
return ['xxx', self.name]
|
2007-01-24 22:24:01 +08:00
|
|
|
"""))
|
|
|
|
for keyword in ('xxx', 'xxx test_2', 'TestClass', 'xxx -test_1',
|
|
|
|
'TestClass test_2', 'xxx TestClass test_2',):
|
2008-01-25 23:54:04 +08:00
|
|
|
config = py.test.config._reparse([o, '-s', '-k', keyword])
|
|
|
|
all = []
|
|
|
|
session = config._getsessionclass()(config)
|
|
|
|
session.main(all.append)
|
2007-01-24 22:24:01 +08:00
|
|
|
print "keyword", repr(keyword)
|
2008-01-25 23:54:04 +08:00
|
|
|
l = getpassed(all)
|
|
|
|
outcomes = [i for i in all if isinstance(i, ReceivedItemOutcome)]
|
2007-01-24 22:24:01 +08:00
|
|
|
assert len(l) == 1
|
2008-01-25 23:54:04 +08:00
|
|
|
assert outcomes[0].item.name == 'test_2'
|
|
|
|
l = getskipped(all)
|
|
|
|
assert l[0].item.name == 'test_1'
|
2007-04-03 23:23:00 +08:00
|
|
|
|
|
|
|
def test_select_starton(self):
|
2008-05-10 21:55:22 +08:00
|
|
|
config = py.test.config._reparse([datadir/'testevenmore.py',
|
|
|
|
'-j', '-k', "test_three"])
|
2008-01-25 23:54:04 +08:00
|
|
|
all = []
|
|
|
|
session = config._getsessionclass()(config)
|
|
|
|
session.main(all.append)
|
|
|
|
assert len(getpassed(all)) == 2
|
2008-05-10 21:55:22 +08:00
|
|
|
assert len(getskipped(all)) == 2
|
2007-04-03 23:23:00 +08:00
|
|
|
|
2007-01-24 22:24:01 +08:00
|
|
|
|
2008-01-25 23:54:04 +08:00
|
|
|
class TestTerminalSession:
|
|
|
|
def mainsession(self, *args):
|
|
|
|
from py.__.test.session import Session
|
|
|
|
from py.__.test.terminal.out import getout
|
2007-01-24 22:24:01 +08:00
|
|
|
config = py.test.config._reparse(list(args))
|
2008-01-25 23:54:04 +08:00
|
|
|
all = []
|
|
|
|
session = Session(config)
|
|
|
|
session.main(all.append)
|
|
|
|
return session, all
|
2007-01-24 22:24:01 +08:00
|
|
|
|
|
|
|
def test_terminal(self):
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession(datadir / 'filetest.py')
|
|
|
|
outcomes = getoutcomes(all)
|
|
|
|
assert len(getfailed(all)) == 2
|
2007-01-24 22:24:01 +08:00
|
|
|
|
|
|
|
def test_syntax_error_module(self):
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession(datadir / 'syntax_error.py')
|
|
|
|
l = getfailed(all)
|
|
|
|
assert len(l) == 1
|
|
|
|
out = l[0].excinfo.exconly()
|
2007-01-24 22:24:01 +08:00
|
|
|
assert out.find(str('syntax_error.py')) != -1
|
|
|
|
assert out.find(str('not python')) != -1
|
|
|
|
|
|
|
|
def test_exit_first_problem(self):
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession("--exitfirst",
|
|
|
|
datadir / 'filetest.py')
|
2007-01-24 22:24:01 +08:00
|
|
|
assert session.config.option.exitfirst
|
2008-01-25 23:54:04 +08:00
|
|
|
assert len(getfailed(all)) == 1
|
|
|
|
assert not getpassed(all)
|
2007-01-24 22:24:01 +08:00
|
|
|
|
|
|
|
def test_generator_yields_None(self):
|
|
|
|
o = tmpdir.ensure('generatornonetest', dir=1)
|
|
|
|
tfile = o.join('test_generatornone.py')
|
|
|
|
tfile.write(py.code.Source("""
|
|
|
|
def test_1():
|
|
|
|
yield None
|
|
|
|
"""))
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession(o)
|
2007-01-24 22:24:01 +08:00
|
|
|
#print out
|
2008-01-25 23:54:04 +08:00
|
|
|
failures = getfailed(all)
|
|
|
|
out = failures[0].excinfo.exconly()
|
2007-01-24 22:24:01 +08:00
|
|
|
i = out.find('TypeError')
|
|
|
|
assert i != -1
|
|
|
|
|
|
|
|
def test_capturing_hooks_simple(self):
|
|
|
|
o = tmpdir.ensure('capturing', dir=1)
|
|
|
|
tfile = o.join('test_capturing.py').write(py.code.Source("""
|
|
|
|
import py
|
|
|
|
print "module level output"
|
|
|
|
def test_capturing():
|
|
|
|
print 42
|
|
|
|
print >>py.std.sys.stderr, 23
|
|
|
|
def test_capturing_error():
|
|
|
|
print 1
|
|
|
|
print >>py.std.sys.stderr, 2
|
|
|
|
raise ValueError
|
|
|
|
"""))
|
|
|
|
conftest = o.join('conftest.py').write(py.code.Source("""
|
|
|
|
import py
|
2007-02-14 03:21:53 +08:00
|
|
|
class Function(py.test.collect.Function):
|
2007-01-24 22:24:01 +08:00
|
|
|
def startcapture(self):
|
2007-02-12 00:25:01 +08:00
|
|
|
self._mycapture = None
|
2007-01-24 22:24:01 +08:00
|
|
|
|
|
|
|
def finishcapture(self):
|
2007-02-12 00:25:01 +08:00
|
|
|
self._testmycapture = None
|
2007-01-24 22:24:01 +08:00
|
|
|
"""))
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession(o)
|
|
|
|
l = getpassed(all)
|
|
|
|
outcomes = getoutcomes(all)
|
2007-01-24 22:24:01 +08:00
|
|
|
assert len(l) == 1
|
2008-01-25 23:54:04 +08:00
|
|
|
item = all[3].item # item is not attached to outcome, but it's the
|
|
|
|
# started before
|
2007-01-24 22:24:01 +08:00
|
|
|
assert hasattr(item, '_testmycapture')
|
|
|
|
print item._testmycapture
|
|
|
|
|
|
|
|
assert isinstance(item.parent, py.test.collect.Module)
|
|
|
|
|
|
|
|
def test_raises_output(self):
|
|
|
|
o = tmpdir.ensure('raisestest', dir=1)
|
|
|
|
tfile = o.join('test_raisesoutput.py')
|
|
|
|
tfile.write(py.code.Source("""
|
|
|
|
import py
|
|
|
|
def test_raises_doesnt():
|
|
|
|
py.test.raises(ValueError, int, "3")
|
|
|
|
"""))
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession(o)
|
|
|
|
outcomes = getoutcomes(all)
|
|
|
|
out = outcomes[0].excinfo.exconly()
|
2007-01-24 22:24:01 +08:00
|
|
|
if not out.find("DID NOT RAISE") != -1:
|
|
|
|
print out
|
|
|
|
py.test.fail("incorrect raises() output")
|
|
|
|
|
|
|
|
def test_order_of_execution(self):
|
|
|
|
o = tmpdir.ensure('ordertest', dir=1)
|
|
|
|
tfile = o.join('test_orderofexecution.py')
|
|
|
|
tfile.write(py.code.Source("""
|
|
|
|
l = []
|
|
|
|
def test_1():
|
|
|
|
l.append(1)
|
|
|
|
def test_2():
|
|
|
|
l.append(2)
|
|
|
|
def test_3():
|
|
|
|
assert l == [1,2]
|
|
|
|
class Testmygroup:
|
|
|
|
reslist = l
|
|
|
|
def test_1(self):
|
|
|
|
self.reslist.append(1)
|
|
|
|
def test_2(self):
|
|
|
|
self.reslist.append(2)
|
|
|
|
def test_3(self):
|
|
|
|
self.reslist.append(3)
|
|
|
|
def test_4(self):
|
|
|
|
assert self.reslist == [1,2,1,2,3]
|
|
|
|
"""))
|
|
|
|
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession(o)
|
|
|
|
assert len(getfailed(all)) == 0
|
|
|
|
assert len(getpassed(all)) == 7
|
2007-01-24 22:24:01 +08:00
|
|
|
# also test listnames() here ...
|
|
|
|
|
|
|
|
def test_nested_import_error(self):
|
|
|
|
o = tmpdir.ensure('Ians_importfailure', dir=1)
|
|
|
|
tfile = o.join('test_import_fail.py')
|
|
|
|
tfile.write(py.code.Source("""
|
|
|
|
import import_fails
|
|
|
|
def test_this():
|
|
|
|
assert import_fails.a == 1
|
|
|
|
"""))
|
|
|
|
o.join('import_fails.py').write(py.code.Source("""
|
|
|
|
import does_not_work
|
|
|
|
a = 1
|
|
|
|
"""))
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession(o)
|
|
|
|
l = getfailed(all)
|
2007-01-24 22:24:01 +08:00
|
|
|
assert len(l) == 1
|
2008-01-25 23:54:04 +08:00
|
|
|
out = l[0].excinfo.exconly()
|
|
|
|
assert out.find('does_not_work') != -1
|
2007-01-24 22:24:01 +08:00
|
|
|
|
|
|
|
def test_safe_repr(self):
|
2008-01-25 23:54:04 +08:00
|
|
|
session, all = self.mainsession(datadir/'brokenrepr.py')
|
|
|
|
#print 'Output of simulated "py.test brokenrepr.py":'
|
|
|
|
#print all
|
|
|
|
|
|
|
|
l = getfailed(all)
|
2007-01-24 22:24:01 +08:00
|
|
|
assert len(l) == 2
|
2008-01-25 23:54:04 +08:00
|
|
|
out = l[0].excinfo.exconly()
|
2007-01-24 22:24:01 +08:00
|
|
|
assert out.find("""[Exception("Ha Ha fooled you, I'm a broken repr().") raised in repr()]""") != -1 #'
|
2008-01-25 23:54:04 +08:00
|
|
|
out = l[1].excinfo.exconly()
|
2007-01-24 22:24:01 +08:00
|
|
|
assert out.find("[unknown exception raised in repr()]") != -1
|
2007-08-14 17:48:15 +08:00
|
|
|
|
|
|
|
def test_skip_reasons():
|
|
|
|
tmp = py.test.ensuretemp("check_skip_reasons")
|
|
|
|
tmp.ensure("test_one.py").write(py.code.Source("""
|
|
|
|
import py
|
|
|
|
def test_1():
|
2008-07-04 14:51:51 +08:00
|
|
|
py.test.skip("Broken: stuff")
|
2007-08-14 17:48:15 +08:00
|
|
|
|
|
|
|
def test_2():
|
2008-07-04 14:51:51 +08:00
|
|
|
py.test.skip("Not implemented: stuff")
|
2007-08-14 17:48:15 +08:00
|
|
|
"""))
|
|
|
|
tmp.ensure("__init__.py")
|
|
|
|
config = py.test.config._reparse([tmp])
|
2008-01-25 23:54:04 +08:00
|
|
|
all = []
|
2007-08-14 17:48:15 +08:00
|
|
|
session = config.initsession()
|
2008-01-25 23:54:04 +08:00
|
|
|
session.main(all.append)
|
|
|
|
skips = getskipped(all)
|
2007-08-14 17:48:15 +08:00
|
|
|
assert len(skips) == 2
|
2008-07-04 14:51:51 +08:00
|
|
|
assert str(skips[0].skipped.value).find('Broken: stuff') != -1
|
|
|
|
assert str(skips[1].skipped.value).find('Not implemented: stuff') != -1
|
2007-08-14 17:48:15 +08:00
|
|
|
|