2007-01-24 22:24:01 +08:00
|
|
|
|
|
|
|
""" local-only operations
|
|
|
|
"""
|
|
|
|
|
2007-02-01 23:20:39 +08:00
|
|
|
import py
|
2007-01-31 00:59:32 +08:00
|
|
|
from py.__.test.rsession.executor import BoxExecutor, RunExecutor,\
|
|
|
|
ApigenExecutor
|
2007-02-05 07:34:23 +08:00
|
|
|
from py.__.test.rsession import repevent
|
2007-01-24 22:24:01 +08:00
|
|
|
from py.__.test.rsession.outcome import ReprOutcome
|
|
|
|
|
|
|
|
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):
|
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
|
|
|
return outcome
|
|
|
|
|
|
|
|
def benchmark_runner(item, session, reporter):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
def apigen_runner(item, session, reporter):
|
2007-01-26 03:59:17 +08:00
|
|
|
#retval = plain_runner(item, session, reporter)
|
2007-01-31 00:59:32 +08:00
|
|
|
r = ApigenExecutor(item, reporter=reporter, config=session.config)
|
|
|
|
outcome = r.execute(session.tracer)
|
2007-02-11 05:56:23 +08:00
|
|
|
return ReprOutcome(outcome.make_repr(session.config.option.tbstyle))
|
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)
|
2007-02-05 07:34:23 +08:00
|
|
|
reporter(repevent.ReceivedItemOutcome(None, item, outcome))
|
2007-01-24 22:24:01 +08:00
|
|
|
except StopIteration:
|
|
|
|
break
|