2007-01-24 22:24:01 +08:00
|
|
|
|
|
|
|
""" local-only operations
|
|
|
|
"""
|
|
|
|
|
|
|
|
from py.__.test.rsession.executor import BoxExecutor, RunExecutor
|
|
|
|
from py.__.test.rsession import report
|
|
|
|
from py.__.test.rsession.outcome import ReprOutcome
|
|
|
|
|
|
|
|
# XXX copied from session.py
|
|
|
|
def startcapture(session):
|
|
|
|
if not session.config.option.nocapture and not session.config.option.usepdb:
|
|
|
|
# XXX refactor integrate capturing
|
|
|
|
from py.__.misc.simplecapture import SimpleOutErrCapture
|
|
|
|
session._capture = SimpleOutErrCapture()
|
|
|
|
|
|
|
|
def finishcapture(session):
|
|
|
|
if hasattr(session, '_capture'):
|
|
|
|
capture = session._capture
|
|
|
|
del session._capture
|
|
|
|
return capture.reset()
|
|
|
|
return "", ""
|
|
|
|
|
|
|
|
def box_runner(item, session, reporter):
|
2007-01-25 00:46:46 +08:00
|
|
|
r = BoxExecutor(item, config=session.config)
|
2007-01-24 22:24:01 +08:00
|
|
|
return ReprOutcome(r.execute())
|
|
|
|
|
|
|
|
def plain_runner(item, session, reporter):
|
|
|
|
# box executor is doing stdout/err catching for us, let's do it here
|
|
|
|
startcapture(session)
|
2007-01-25 00:46:46 +08:00
|
|
|
r = RunExecutor(item, usepdb=session.config.option.usepdb, reporter=reporter, config=session.config)
|
2007-01-24 22:24:01 +08:00
|
|
|
outcome = r.execute()
|
2007-01-25 00:46:46 +08:00
|
|
|
outcome = ReprOutcome(outcome.make_repr(session.config.option.tbstyle))
|
2007-01-24 22:24:01 +08:00
|
|
|
outcome.stdout, outcome.stderr = finishcapture(session)
|
|
|
|
return outcome
|
|
|
|
|
|
|
|
def benchmark_runner(item, session, reporter):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
def apigen_runner(item, session, reporter):
|
2007-01-26 03:59:17 +08:00
|
|
|
r = RunExecutor(item, reporter=reporter, config=session.config)
|
|
|
|
startcapture(session)
|
|
|
|
#retval = plain_runner(item, session, reporter)
|
2007-01-25 01:30:29 +08:00
|
|
|
r = RunExecutor(item, reporter=reporter, config=session.config)
|
2007-01-24 22:24:01 +08:00
|
|
|
session.tracer.start_tracing()
|
2007-01-26 03:59:17 +08:00
|
|
|
outcome = r.execute()
|
2007-01-24 22:24:01 +08:00
|
|
|
session.tracer.end_tracing()
|
2007-01-26 03:59:17 +08:00
|
|
|
outcome = ReprOutcome(outcome.make_repr(session.config.option.tbstyle))
|
|
|
|
outcome.stdout, outcome.stderr = finishcapture(session)
|
|
|
|
return outcome
|
2007-01-24 22:24:01 +08:00
|
|
|
|
|
|
|
def exec_runner(item, session, reporter):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
# runner interface is here to perform several different types of run
|
|
|
|
#+1. box_runner - for running normal boxed tests
|
|
|
|
#+2. plain_runner - for performing running without boxing (necessary for pdb)
|
|
|
|
# XXX: really?
|
|
|
|
#-3. exec_runner - for running under different interpreter
|
|
|
|
#-4. benchmark_runner - for running with benchmarking
|
|
|
|
#-5. apigen_runner - for running under apigen to generate api out of it.
|
|
|
|
def local_loop(session, reporter, itemgenerator, shouldstop, config, runner=None):
|
|
|
|
assert runner is not None
|
|
|
|
#if runner is None:
|
|
|
|
# if session.config.option.apigen:
|
|
|
|
# runner = apigen_runner
|
|
|
|
# else:
|
|
|
|
# runner = box_runner
|
|
|
|
while 1:
|
|
|
|
try:
|
|
|
|
item = itemgenerator.next()
|
|
|
|
if shouldstop():
|
|
|
|
return
|
|
|
|
outcome = runner(item, session, reporter)
|
|
|
|
reporter(report.ReceivedItemOutcome(None, item, outcome))
|
|
|
|
except StopIteration:
|
|
|
|
break
|