simplify session object and rename some more hooks, not exposed/released yet

This commit is contained in:
holger krekel 2010-11-01 00:27:12 +01:00
parent 5616874823
commit 209140fea0
2 changed files with 40 additions and 47 deletions

View File

@ -37,17 +37,17 @@ def pytest_configure(config):
def pytest_unconfigure(config): def pytest_unconfigure(config):
""" called before test process is exited. """ """ called before test process is exited. """
def pytest_runtest_mainloop(session): def pytest_runtestloop(session):
""" called for performing the main runtest loop (after collection. """ """ called for performing the main runtest loop (after collection. """
pytest_runtest_mainloop.firstresult = True pytest_runtestloop.firstresult = True
# ------------------------------------------------------------------------- # -------------------------------------------------------------------------
# collection hooks # collection hooks
# ------------------------------------------------------------------------- # -------------------------------------------------------------------------
def pytest_collection_perform(session): def pytest_collection(session):
""" perform the collection protocol for the given session. """ """ perform the collection protocol for the given session. """
pytest_collection_perform.firstresult = True pytest_collection.firstresult = True
def pytest_collection_modifyitems(config, items): def pytest_collection_modifyitems(config, items):
""" called after collection has been performed, may filter or re-order """ called after collection has been performed, may filter or re-order

View File

@ -8,6 +8,13 @@ import py
import pytest import pytest
import os, sys import os, sys
# exitcodes for the command line
EXIT_OK = 0
EXIT_TESTSFAILED = 1
EXIT_INTERRUPTED = 2
EXIT_INTERNALERROR = 3
EXIT_NOHOSTS = 4
def pytest_addoption(parser): def pytest_addoption(parser):
group = parser.getgroup("general", "running and selection options") group = parser.getgroup("general", "running and selection options")
@ -44,9 +51,35 @@ def pytest_configure(config):
config.option.maxfail = 1 config.option.maxfail = 1
def pytest_cmdline_main(config): def pytest_cmdline_main(config):
return Session(config).main() """ default command line protocol for initialization, collection,
running tests and reporting. """
session = Session(config)
session.exitstatus = EXIT_OK
try:
config.pluginmanager.do_configure(config)
config.hook.pytest_sessionstart(session=session)
config.hook.pytest_collection(session=session)
config.hook.pytest_runtestloop(session=session)
except pytest.UsageError:
raise
except KeyboardInterrupt:
excinfo = py.code.ExceptionInfo()
config.hook.pytest_keyboard_interrupt(excinfo=excinfo)
session.exitstatus = EXIT_INTERRUPTED
except:
excinfo = py.code.ExceptionInfo()
config.pluginmanager.notify_exception(excinfo)
session.exitstatus = EXIT_INTERNALERROR
if excinfo.errisinstance(SystemExit):
sys.stderr.write("mainloop: caught Spurious SystemExit!\n")
if not session.exitstatus and session._testsfailed:
session.exitstatus = EXIT_TESTSFAILED
config.hook.pytest_sessionfinish(session=session,
exitstatus=session.exitstatus)
config.pluginmanager.do_unconfigure(config)
return session.exitstatus
def pytest_collection_perform(session): def pytest_collection(session):
collection = session.collection collection = session.collection
assert not hasattr(collection, 'items') assert not hasattr(collection, 'items')
hook = session.config.hook hook = session.config.hook
@ -55,7 +88,7 @@ def pytest_collection_perform(session):
hook.pytest_collection_finish(collection=collection) hook.pytest_collection_finish(collection=collection)
return True return True
def pytest_runtest_mainloop(session): def pytest_runtestloop(session):
if session.config.option.collectonly: if session.config.option.collectonly:
return True return True
for item in session.collection.items: for item in session.collection.items:
@ -86,16 +119,7 @@ def pytest_collect_directory(path, parent):
def pytest_report_iteminfo(item): def pytest_report_iteminfo(item):
return item.reportinfo() return item.reportinfo()
# exitcodes for the command line
EXIT_OK = 0
EXIT_TESTSFAILED = 1
EXIT_INTERRUPTED = 2
EXIT_INTERNALERROR = 3
EXIT_NOHOSTS = 4
class Session(object): class Session(object):
nodeid = ""
class Interrupted(KeyboardInterrupt): class Interrupted(KeyboardInterrupt):
""" signals an interrupted test run. """ """ signals an interrupted test run. """
__module__ = 'builtins' # for py3 __module__ = 'builtins' # for py3
@ -120,37 +144,6 @@ class Session(object):
self._testsfailed) self._testsfailed)
pytest_collectreport = pytest_runtest_logreport pytest_collectreport = pytest_runtest_logreport
def main(self):
""" main loop for running tests. """
self.shouldstop = False
self.exitstatus = EXIT_OK
config = self.config
try:
config.pluginmanager.do_configure(config)
config.hook.pytest_sessionstart(session=self)
config.hook.pytest_collection_perform(session=self)
config.hook.pytest_runtest_mainloop(session=self)
except pytest.UsageError:
raise
except KeyboardInterrupt:
excinfo = py.code.ExceptionInfo()
self.config.hook.pytest_keyboard_interrupt(excinfo=excinfo)
self.exitstatus = EXIT_INTERRUPTED
except:
excinfo = py.code.ExceptionInfo()
self.config.pluginmanager.notify_exception(excinfo)
self.exitstatus = EXIT_INTERNALERROR
if excinfo.errisinstance(SystemExit):
sys.stderr.write("mainloop: caught Spurious SystemExit!\n")
if not self.exitstatus and self._testsfailed:
self.exitstatus = EXIT_TESTSFAILED
self.config.hook.pytest_sessionfinish(
session=self, exitstatus=self.exitstatus,
)
config.pluginmanager.do_unconfigure(config)
return self.exitstatus
class Collection: class Collection:
def __init__(self, config): def __init__(self, config):
self.config = config self.config = config