[svn r62256] getting rid of "--session", you can do it by

creating a plugin and calling setsessionclass
from "pytest_configure".

--HG--
branch : trunk
This commit is contained in:
hpk 2009-02-27 22:32:49 +01:00
parent 6f145b7c3c
commit 3561d2e9ff
9 changed files with 87 additions and 121 deletions

View File

@ -26,6 +26,7 @@ class Config(object):
""" central bus for dealing with configuration/initialization data. """ """ central bus for dealing with configuration/initialization data. """
Option = py.compat.optparse.Option # deprecated Option = py.compat.optparse.Option # deprecated
_initialized = False _initialized = False
_sessionclass = None
def __init__(self, pytestplugins=None): def __init__(self, pytestplugins=None):
self.option = CmdOptions() self.option = CmdOptions()
@ -79,7 +80,6 @@ class Config(object):
self.topdir = py.path.local(topdir) self.topdir = py.path.local(topdir)
self._mergerepr(self._repr) self._mergerepr(self._repr)
del self._repr del self._repr
self.pytestplugins.configure(config=self)
def _makerepr(self): def _makerepr(self):
l = [] l = []
@ -155,40 +155,19 @@ class Config(object):
except AttributeError: except AttributeError:
return self._conftest.rget(name, path) return self._conftest.rget(name, path)
def setsessionclass(self, cls):
if self._sessionclass is not None:
raise ValueError("sessionclass already set to: %r" %(
self._sessionclass))
self._sessionclass = cls
def initsession(self): def initsession(self):
""" return an initialized session object. """ """ return an initialized session object. """
cls = self._getsessionclass() cls = self._sessionclass
session = cls(self) if cls is None:
session.fixoptions() from py.__.test.session import Session
return session cls = Session
return cls(self)
def _getsessionclass(self):
""" return Session class determined from cmdline options
and looked up in initial config modules.
"""
if self.option.session is not None:
return self._conftest.rget(self.option.session)
else:
name = self._getsessionname()
try:
return self._conftest.rget(name)
except KeyError:
pass
importpath = globals()[name]
mod = __import__(importpath, None, None, '__doc__')
return getattr(mod, name)
def _getsessionname(self):
""" return default session name as determined from options. """
if self.option.collectonly:
name = 'Session'
elif self.option.looponfailing:
name = 'LooponfailingSession'
elif self.option.numprocesses or self.option.dist or self.option.executable:
name = 'DSession'
else:
name = 'Session'
return name
def _reparse(self, args): def _reparse(self, args):
""" this is used from tests that want to re-invoke parse(). """ """ this is used from tests that want to re-invoke parse(). """
@ -222,12 +201,6 @@ config_per_process = Config(
pytestplugins=py.test._PytestPlugins(py._com.pyplugins) pytestplugins=py.test._PytestPlugins(py._com.pyplugins)
) )
# default import paths for sessions
Session = 'py.__.test.session'
LooponfailingSession = 'py.__.test.looponfail.remote'
DSession = 'py.__.test.dsession.dsession'
# #
# helpers # helpers
# #

View File

@ -41,6 +41,9 @@ class DSession(Session):
self.host2pending = {} self.host2pending = {}
self.item2host = {} self.item2host = {}
self._testsfailed = False self._testsfailed = False
if self.config.getvalue("executable") and \
not self.config.getvalue("numprocesses"):
self.config.option.numprocesses = 1
def fixoptions(self): def fixoptions(self):
""" check, fix and determine conflicting options. """ """ check, fix and determine conflicting options. """

View File

@ -113,6 +113,7 @@ class SlaveNode(object):
self.channel.send((eventname, args, kwargs)) self.channel.send((eventname, args, kwargs))
def run(self): def run(self):
self.config.pytestplugins.configure(self.config)
from py.__.test.dsession.hostmanage import makehostup from py.__.test.dsession.hostmanage import makehostup
channel = self.channel channel = self.channel
self.host = host = channel.receive() self.host = host = channel.receive()

View File

@ -26,6 +26,7 @@ def dumpqueue(queue):
class TestDSession: class TestDSession:
def test_fixoptions(self, testdir): def test_fixoptions(self, testdir):
config = testdir.parseconfig("--exec=xxx") config = testdir.parseconfig("--exec=xxx")
config.pytestplugins.configure(config)
config.initsession().fixoptions() config.initsession().fixoptions()
assert config.option.numprocesses == 1 assert config.option.numprocesses == 1
config = testdir.parseconfig("--exec=xxx", '-n3') config = testdir.parseconfig("--exec=xxx", '-n3')

View File

@ -11,10 +11,6 @@ import os
class TestAsyncFunctional: class TestAsyncFunctional:
def test_dist_no_disthost(self, testdir):
config = testdir.parseconfig(testdir.tmpdir, '-d')
py.test.raises(SystemExit, "config.initsession()")
def test_conftest_options(self, testdir): def test_conftest_options(self, testdir):
testdir.makepyfile(conftest=""" testdir.makepyfile(conftest="""
print "importing conftest" print "importing conftest"

View File

@ -129,7 +129,7 @@ def slave_runsession(channel, config, fullwidth, hasmarkup):
config.option.usepdb = False config.option.usepdb = False
config.option.executable = None config.option.executable = None
trails = channel.receive() trails = channel.receive()
config.pytestplugins.configure(config)
DEBUG("SLAVE: initsession()") DEBUG("SLAVE: initsession()")
session = config.initsession() session = config.initsession()
# XXX configure the reporter object's terminal writer more directly # XXX configure the reporter object's terminal writer more directly

View File

@ -1,3 +1,5 @@
import py
class DefaultPlugin: class DefaultPlugin:
""" Plugin implementing defaults and general options. """ """ Plugin implementing defaults and general options. """
@ -72,12 +74,40 @@ class DefaultPlugin:
action="store_true", dest="runbrowser", default=False, action="store_true", dest="runbrowser", default=False,
help="run browser (implies --startserver)." help="run browser (implies --startserver)."
), ),
group._addoption('', '--boxed', group._addoption('--boxed',
action="store_true", dest="boxed", default=False, action="store_true", dest="boxed", default=False,
help="box each test run in a separate process"), help="box each test run in a separate process"),
group._addoption('', '--rest', group._addoption('--rest',
action='store_true', dest="restreport", default=False, action='store_true', dest="restreport", default=False,
help="restructured text output reporting."), help="restructured text output reporting."),
group._addoption('', '--session',
action="store", dest="session", default=None, def pytest_configure(self, config):
help="lookup given sessioname in conftest.py files and use it."), self.setsession(config)
def setsession(self, config):
val = config.getvalue
if val("collectonly"):
from py.__.test.session import Session
config.setsessionclass(Session)
elif val("looponfailing"):
from py.__.test.looponfail.remote import LooponfailingSession
config.setsessionclass(LooponfailingSession)
elif val("numprocesses") or val("dist") or val("executable"):
from py.__.test.dsession.dsession import DSession
config.setsessionclass(DSession)
def test_implied_different_sessions(tmpdir):
def x(*args):
config = py.test.config._reparse([tmpdir] + list(args))
try:
config.pytestplugins.configure(config)
except ValueError:
return Exception
return getattr(config._sessionclass, '__name__', None)
assert x() == None
assert x('--dist') == 'DSession'
assert x('-n3') == 'DSession'
assert x('-f') == 'LooponfailingSession'
assert x('--exec=x') == 'DSession'
assert x('-f', '--exec=x') == 'LooponfailingSession'
assert x('--dist', '--exec=x', '--collectonly') == 'Session'

View File

@ -1,20 +1,6 @@
import py import py
pytest_plugins = 'pytest_iocapture'
class TestConfigCmdlineParsing: class TestConfigCmdlineParsing:
@py.test.mark(xfail="commit parser")
def test_config_addoption(self, stdcapture):
from py.__.test.config import Config
config = Config()
config.addoption("cat1", "--option1", action="store_true")
config.addoption("cat1", "--option2", action="store_true")
config.parse(["-h"])
out, err = stdcapture.reset()
assert out.count("cat1") == 1
assert out.find("option1") != -1
assert out.find("option2") != -1
def test_config_cmdline_options(self, testdir): def test_config_cmdline_options(self, testdir):
testdir.makepyfile(conftest=""" testdir.makepyfile(conftest="""
import py import py
@ -71,9 +57,8 @@ class TestConfigCmdlineParsing:
opts = spec.split() opts = spec.split()
yield check_conflict_option, opts yield check_conflict_option, opts
class TestConfigAPI: class TestConfigAPI:
@py.test.mark(issue="ensuretemp should call config.maketemp(basename)") @py.test.mark.issue("ensuretemp should call config.maketemp(basename)")
def test_tmpdir(self): def test_tmpdir(self):
d1 = py.test.ensuretemp('hello') d1 = py.test.ensuretemp('hello')
d2 = py.test.ensuretemp('hello') d2 = py.test.ensuretemp('hello')
@ -120,6 +105,20 @@ class TestConfigAPI:
pl = config.getvalue_pathlist('mypathlist') pl = config.getvalue_pathlist('mypathlist')
assert pl == [py.path.local()] assert pl == [py.path.local()]
def test_setsessionclass_and_initsession(self, testdir):
from py.__.test.config import Config
config = Config()
class Session1:
def __init__(self, config):
self.config = config
config.setsessionclass(Session1)
session = config.initsession()
assert isinstance(session, Session1)
assert session.config is config
py.test.raises(ValueError, "config.setsessionclass(Session1)")
class TestConfigApi_getcolitems: class TestConfigApi_getcolitems:
def test_getcolitems_onedir(self, tmpdir): def test_getcolitems_onedir(self, tmpdir):
config = py.test.config._reparse([tmpdir]) config = py.test.config._reparse([tmpdir])
@ -395,63 +394,21 @@ class TestConfigPickling:
assert newcol2.fspath.basename == dir1.basename assert newcol2.fspath.basename == dir1.basename
assert newcol2.fspath.relto(topdir) assert newcol2.fspath.relto(topdir)
class TestSessionAndOptions: def test_options_on_small_file_do_not_blow_up(testdir):
def test_implied_dsession(self, testdir): def runfiletest(opts):
for x in 'startserver runbrowser rest'.split(): sorter = testdir.inline_run(*opts)
config = testdir.parseconfig(testdir.tmpdir, '--dist', '--%s' % x) passed, skipped, failed = sorter.countoutcomes()
assert config._getsessionname() == 'DSession' assert failed == 2
assert skipped == passed == 0
path = testdir.makepyfile("""
def test_f1(): assert 0
def test_f2(): assert 0
""")
def test_implied_different_sessions(self, tmpdir): for opts in ([], ['-l'], ['-s'], ['--tb=no'], ['--tb=short'],
config = py.test.config._reparse([tmpdir]) ['--tb=long'], ['--fulltrace'], ['--nomagic'],
assert config._getsessionname() == 'Session' ['--traceconfig'], ['-v'], ['-v', '-v']):
config = py.test.config._reparse([tmpdir, '--dist']) runfiletest(opts + [path])
assert config._getsessionname() == 'DSession'
config = py.test.config._reparse([tmpdir, '-n3'])
assert config._getsessionname() == 'DSession'
config = py.test.config._reparse([tmpdir, '--looponfailing'])
assert config._getsessionname() == 'LooponfailingSession'
config = py.test.config._reparse([tmpdir, '--exec=x'])
assert config._getsessionname() == 'DSession'
config = py.test.config._reparse([tmpdir, '--dist', '--exec=x'])
assert config._getsessionname() == 'DSession'
config = py.test.config._reparse([tmpdir, '-f',
'--dist', '--exec=x'])
assert config._getsessionname() == 'LooponfailingSession'
config = py.test.config._reparse([tmpdir, '-f', '-n3',
'--dist', '--exec=x',
'--collectonly'])
assert config._getsessionname() == 'Session'
def test_sessionname_lookup_custom(self, testdir):
testdir.makepyfile(conftest="""
from py.__.test.session import Session
class MySession(Session):
pass
""")
config = testdir.parseconfig("--session=MySession", testdir.tmpdir)
session = config.initsession()
assert session.__class__.__name__ == 'MySession'
def test_initsession(self, tmpdir):
config = py.test.config._reparse([tmpdir])
session = config.initsession()
assert session.config is config
def test_default_session_options(self, testdir):
def runfiletest(opts):
sorter = testdir.inline_run(*opts)
passed, skipped, failed = sorter.countoutcomes()
assert failed == 2
assert skipped == passed == 0
path = testdir.makepyfile("""
def test_f1(): assert 0
def test_f2(): assert 0
""")
for opts in ([], ['-l'], ['-s'], ['--tb=no'], ['--tb=short'],
['--tb=long'], ['--fulltrace'], ['--nomagic'],
['--traceconfig'], ['-v'], ['-v', '-v']):
runfiletest(opts + [path])
def test_default_bus(): def test_default_bus():
assert py.test.config.bus is py._com.pyplugins assert py.test.config.bus is py._com.pyplugins

View File

@ -1,6 +1,11 @@
import py import py
class SessionTests: class SessionTests:
def test_initsession(self, tmpdir):
config = py.test.config._reparse([tmpdir])
session = config.initsession()
assert session.config is config
def test_basic_testitem_events(self, testdir): def test_basic_testitem_events(self, testdir):
tfile = testdir.makepyfile(""" tfile = testdir.makepyfile("""
def test_one(): def test_one():