diff --git a/py/test/rsession/testing/test_executor.py b/py/test/rsession/testing/test_executor.py index 12ed74eb9..b4336df60 100644 --- a/py/test/rsession/testing/test_executor.py +++ b/py/test/rsession/testing/test_executor.py @@ -5,47 +5,11 @@ import example1 from py.__.test.rsession.executor import RunExecutor, BoxExecutor,\ AsyncExecutor, ApigenExecutor from py.__.test.rsession.outcome import ReprOutcome -from py.__.test.rsession.testing.test_slave import funcprint_spec, \ - funcprintfail_spec +from py.__.test.rsession.testing.runtest import BasicRsessionTest -def setup_module(mod): - mod.rootdir = py.path.local(py.__file__).dirpath().dirpath() - mod.config = py.test.config._reparse([mod.rootdir]) - -def XXXtest_executor_passing_function(): - ex = Executor(example1.f1) - outcome = ex.execute() - assert outcome.passed - -def XXXtest_executor_raising_function(): - ex = Executor(example1.g1) - outcome = ex.execute() - assert not outcome.passed - excinfo = outcome.excinfo - assert excinfo.type == ValueError - -def XXXtest_executor_traceback(): - ex = Executor(example1.g1) - outcome = ex.execute() - excinfo = outcome.excinfo - assert len(excinfo.traceback) == 2 - assert excinfo.traceback[1].frame.code.name == 'g2' - assert excinfo.traceback[0].frame.code.name == 'g1' - -def XXX_test_executor_setup_passing(): - ex = Executor(example1.f1, setup=lambda: None) - outcome = ex.execute() - assert outcome.passed - assert not outcome.setupfailure - -def XXX_test_executor_setup_failing(): - def failingsetup(): - raise ValueError - ex = Executor(example1.f1, setup=failingsetup) - outcome = ex.execute() - assert not outcome.passed - assert outcome.setupfailure - assert outcome.excinfo.traceback[-1].frame.code.name == 'failingsetup' +#def setup_module(mod): +# mod.rootdir = py.path.local(py.__file__).dirpath().dirpath() +# mod.config = py.test.config._reparse([mod.rootdir]) class ItemTestPassing(py.test.Item): def run(self): @@ -59,112 +23,111 @@ class ItemTestSkipping(py.test.Item): def run(self): py.test.skip("hello") -def test_run_executor(): - ex = RunExecutor(ItemTestPassing("pass"), config=config) - outcome = ex.execute() - assert outcome.passed +class TestExecutor(BasicRsessionTest): + def test_run_executor(self): + ex = RunExecutor(ItemTestPassing("pass"), config=self.config) + outcome = ex.execute() + assert outcome.passed - ex = RunExecutor(ItemTestFailing("fail"), config=config) - outcome = ex.execute() - assert not outcome.passed + ex = RunExecutor(ItemTestFailing("fail"), config=self.config) + outcome = ex.execute() + assert not outcome.passed - ex = RunExecutor(ItemTestSkipping("skip"), config=config) - outcome = ex.execute() - assert outcome.skipped - assert not outcome.passed - assert not outcome.excinfo + ex = RunExecutor(ItemTestSkipping("skip"), config=self.config) + outcome = ex.execute() + assert outcome.skipped + assert not outcome.passed + assert not outcome.excinfo -def test_box_executor(): - ex = BoxExecutor(ItemTestPassing("pass"), config=config) - outcome_repr = ex.execute() - outcome = ReprOutcome(outcome_repr) - assert outcome.passed + def test_box_executor(self): + ex = BoxExecutor(ItemTestPassing("pass"), config=self.config) + outcome_repr = ex.execute() + outcome = ReprOutcome(outcome_repr) + assert outcome.passed - ex = BoxExecutor(ItemTestFailing("fail"), config=config) - outcome_repr = ex.execute() - outcome = ReprOutcome(outcome_repr) - assert not outcome.passed + ex = BoxExecutor(ItemTestFailing("fail"), config=self.config) + outcome_repr = ex.execute() + outcome = ReprOutcome(outcome_repr) + assert not outcome.passed - ex = BoxExecutor(ItemTestSkipping("skip"), config=config) - outcome_repr = ex.execute() - outcome = ReprOutcome(outcome_repr) - assert outcome.skipped - assert not outcome.passed - assert not outcome.excinfo + ex = BoxExecutor(ItemTestSkipping("skip"), config=self.config) + outcome_repr = ex.execute() + outcome = ReprOutcome(outcome_repr) + assert outcome.skipped + assert not outcome.passed + assert not outcome.excinfo -def test_box_executor_stdout(): - rootcol = py.test.collect.Directory(rootdir) - item = rootcol._getitembynames(funcprint_spec) - ex = BoxExecutor(item, config=config) - outcome_repr = ex.execute() - outcome = ReprOutcome(outcome_repr) - assert outcome.passed - assert outcome.stdout.find("samfing") != -1 + def test_box_executor_stdout(self): + item = self.rootcol._getitembynames(self.funcprint_spec) + ex = BoxExecutor(item, config=self.config) + outcome_repr = ex.execute() + outcome = ReprOutcome(outcome_repr) + assert outcome.passed + assert outcome.stdout.find("samfing") != -1 -def test_box_executor_stdout_error(): - rootcol = py.test.collect.Directory(rootdir) - item = rootcol._getitembynames(funcprintfail_spec) - ex = BoxExecutor(item, config=config) - outcome_repr = ex.execute() - outcome = ReprOutcome(outcome_repr) - assert not outcome.passed - assert outcome.stdout.find("samfing elz") != -1 + def test_box_executor_stdout_error(self): + item = self.rootcol._getitembynames(self.funcprintfail_spec) + ex = BoxExecutor(item, config=self.config) + outcome_repr = ex.execute() + outcome = ReprOutcome(outcome_repr) + assert not outcome.passed + assert outcome.stdout.find("samfing elz") != -1 -def test_cont_executor(): - rootcol = py.test.collect.Directory(rootdir) - item = rootcol._getitembynames(funcprintfail_spec) - ex = AsyncExecutor(item, config=config) - cont, pid = ex.execute() - assert pid - outcome_repr = cont() - outcome = ReprOutcome(outcome_repr) - assert not outcome.passed - assert outcome.stdout.find("samfing elz") != -1 + def test_cont_executor(self): + item = self.rootcol._getitembynames(self.funcprintfail_spec) + ex = AsyncExecutor(item, config=self.config) + cont, pid = ex.execute() + assert pid + outcome_repr = cont() + outcome = ReprOutcome(outcome_repr) + assert not outcome.passed + assert outcome.stdout.find("samfing elz") != -1 -def test_apigen_executor(): - class Tracer(object): - def __init__(self): - self.starts = 0 - self.ends = 0 + def test_apigen_executor(self): + class Tracer(object): + def __init__(self): + self.starts = 0 + self.ends = 0 - def start_tracing(self): - self.starts += 1 + def start_tracing(self): + self.starts += 1 - def end_tracing(self): - self.ends += 1 + def end_tracing(self): + self.ends += 1 - tmpdir = py.test.ensuretemp("apigen_executor") - tmpdir.ensure("__init__.py") - tmpdir.ensure("test_one.py").write(py.code.Source(""" - def g(): - pass + tmpdir = py.test.ensuretemp("apigen_executor") + tmpdir.ensure("__init__.py") + tmpdir.ensure("test_one.py").write(py.code.Source(""" + def g(): + pass - def test_1(): - g() + def test_1(): + g() - class TestX(object): - def setup_method(self, m): - self.ttt = 1 + class TestX(object): + def setup_method(self, m): + self.ttt = 1 - def test_one(self): - self.ttt += 1 + def test_one(self): + self.ttt += 1 - def test_raise(self): - 1/0 - """)) - rootcol = py.test.collect.Directory(tmpdir) - tracer = Tracer() - item = rootcol._getitembynames("test_one.py/test_1") - ex = ApigenExecutor(item, config=config) - out1 = ex.execute(tracer) - item = rootcol._getitembynames("test_one.py/TestX/()/test_one") - ex = ApigenExecutor(item, config=config) - out2 = ex.execute(tracer) - item = rootcol._getitembynames("test_one.py/TestX/()/test_raise") - ex = ApigenExecutor(item, config=config) - out3 = ex.execute(tracer) - assert tracer.starts == 3 - assert tracer.ends == 3 - assert out1.passed - assert out2.passed - assert not out3.passed + def test_raise(self): + 1/0 + """)) + config = py.test.config._reparse([tmpdir]) + rootcol = config._getcollector(tmpdir) + tracer = Tracer() + item = rootcol._getitembynames("test_one.py/test_1") + ex = ApigenExecutor(item, config=config) + out1 = ex.execute(tracer) + item = rootcol._getitembynames("test_one.py/TestX/()/test_one") + ex = ApigenExecutor(item, config=config) + out2 = ex.execute(tracer) + item = rootcol._getitembynames("test_one.py/TestX/()/test_raise") + ex = ApigenExecutor(item, config=config) + out3 = ex.execute(tracer) + assert tracer.starts == 3 + assert tracer.ends == 3 + assert out1.passed + assert out2.passed + assert not out3.passed