381 lines
14 KiB
Python
381 lines
14 KiB
Python
|
|
import py
|
|
from py.impl.test.outcome import Skipped
|
|
|
|
class TestCollectDeprecated:
|
|
|
|
def test_collect_with_deprecated_run_and_join(self, testdir, recwarn):
|
|
testdir.makeconftest("""
|
|
import py
|
|
|
|
class MyInstance(py.test.collect.Instance):
|
|
def run(self):
|
|
return ['check2']
|
|
def join(self, name):
|
|
if name == 'check2':
|
|
return self.Function(name=name, parent=self)
|
|
|
|
class MyClass(py.test.collect.Class):
|
|
def run(self):
|
|
return ['check2']
|
|
def join(self, name):
|
|
return MyInstance(name='i', parent=self)
|
|
|
|
class MyModule(py.test.collect.Module):
|
|
def run(self):
|
|
return ['check', 'Cls']
|
|
def join(self, name):
|
|
if name == 'check':
|
|
return self.Function(name, parent=self)
|
|
if name == 'Cls':
|
|
return MyClass(name, parent=self)
|
|
|
|
class MyDirectory(py.test.collect.Directory):
|
|
Module = MyModule
|
|
def run(self):
|
|
return ['somefile.py']
|
|
def join(self, name):
|
|
if name == "somefile.py":
|
|
return self.Module(self.fspath.join(name), parent=self)
|
|
|
|
def pytest_collect_directory(path, parent):
|
|
if path.basename == "subconf":
|
|
return MyDirectory(path, parent)
|
|
""")
|
|
subconf = testdir.mkpydir("subconf")
|
|
somefile = subconf.join("somefile.py")
|
|
somefile.write(py.code.Source("""
|
|
def check(): pass
|
|
class Cls:
|
|
def check2(self): pass
|
|
"""))
|
|
config = testdir.parseconfig(somefile)
|
|
dirnode = config.getnode(somefile.dirpath())
|
|
colitems = dirnode.collect()
|
|
w = recwarn.pop(DeprecationWarning)
|
|
assert w.filename.find("conftest.py") != -1
|
|
#recwarn.resetregistry()
|
|
#assert 0, (w.message, w.filename, w.lineno)
|
|
assert len(colitems) == 1
|
|
modcol = colitems[0]
|
|
assert modcol.name == "somefile.py"
|
|
colitems = modcol.collect()
|
|
recwarn.pop(DeprecationWarning)
|
|
assert len(colitems) == 2
|
|
assert colitems[0].name == 'check'
|
|
assert colitems[1].name == 'Cls'
|
|
clscol = colitems[1]
|
|
|
|
colitems = clscol.collect()
|
|
recwarn.pop(DeprecationWarning)
|
|
assert len(colitems) == 1
|
|
icol = colitems[0]
|
|
colitems = icol.collect()
|
|
recwarn.pop(DeprecationWarning)
|
|
assert len(colitems) == 1
|
|
assert colitems[0].name == 'check2'
|
|
|
|
def test_collect_with_deprecated_join_but_no_run(self, testdir, recwarn):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
|
|
class Module(py.test.collect.Module):
|
|
def funcnamefilter(self, name):
|
|
if name.startswith("check_"):
|
|
return True
|
|
return super(Module, self).funcnamefilter(name)
|
|
def join(self, name):
|
|
if name.startswith("check_"):
|
|
return self.Function(name, parent=self)
|
|
assert name != "SomeClass", "join should not be called with this name"
|
|
""")
|
|
col = testdir.getmodulecol("""
|
|
def somefunc(): pass
|
|
def check_one(): pass
|
|
class SomeClass: pass
|
|
""")
|
|
colitems = col.collect()
|
|
recwarn.pop(DeprecationWarning)
|
|
assert len(colitems) == 1
|
|
funcitem = colitems[0]
|
|
assert funcitem.name == "check_one"
|
|
|
|
def test_function_custom_run(self, testdir, recwarn):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
class Function(py.test.collect.Function):
|
|
def run(self):
|
|
pass
|
|
""")
|
|
modcol = testdir.getmodulecol("def test_func(): pass")
|
|
funcitem = modcol.collect()[0]
|
|
assert funcitem.name == 'test_func'
|
|
recwarn.clear()
|
|
funcitem._deprecated_testexecution()
|
|
recwarn.pop(DeprecationWarning)
|
|
|
|
def test_function_custom_execute(self, testdir, recwarn):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
|
|
class MyFunction(py.test.collect.Function):
|
|
def execute(self, obj, *args):
|
|
pass
|
|
Function=MyFunction
|
|
""")
|
|
modcol = testdir.getmodulecol("def test_func2(): pass")
|
|
funcitem = modcol.collect()[0]
|
|
w = recwarn.pop(DeprecationWarning) # for defining conftest.Function
|
|
assert funcitem.name == 'test_func2'
|
|
funcitem._deprecated_testexecution()
|
|
w = recwarn.pop(DeprecationWarning)
|
|
assert w.filename.find("conftest.py") != -1
|
|
|
|
def test_function_deprecated_run_execute(self, testdir, recwarn):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
|
|
class Function(py.test.collect.Function):
|
|
|
|
def run(self):
|
|
pass
|
|
""")
|
|
modcol = testdir.getmodulecol("def test_some2(): pass")
|
|
funcitem = modcol.collect()[0]
|
|
w = recwarn.pop(DeprecationWarning)
|
|
assert "conftest.py" in str(w.message)
|
|
|
|
recwarn.clear()
|
|
funcitem._deprecated_testexecution()
|
|
recwarn.pop(DeprecationWarning)
|
|
|
|
def test_function_deprecated_run_recursive(self, testdir):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
class Module(py.test.collect.Module):
|
|
def run(self):
|
|
return super(Module, self).run()
|
|
""")
|
|
modcol = testdir.getmodulecol("def test_some(): pass")
|
|
colitems = py.test.deprecated_call(modcol.collect)
|
|
funcitem = colitems[0]
|
|
|
|
def test_conftest_subclasses_Module_with_non_pyfile(self, testdir):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
class Module(py.test.collect.Module):
|
|
def run(self):
|
|
return []
|
|
class Directory(py.test.collect.Directory):
|
|
def consider_file(self, path):
|
|
if path.basename == "testme.xxx":
|
|
return Module(path, parent=self)
|
|
return super(Directory, self).consider_file(path)
|
|
""")
|
|
testme = testdir.makefile('xxx', testme="hello")
|
|
config = testdir.parseconfig(testme)
|
|
col = config.getnode(testme)
|
|
assert col.collect() == []
|
|
|
|
|
|
|
|
class TestDisabled:
|
|
def test_disabled_module(self, recwarn, testdir):
|
|
modcol = testdir.getmodulecol("""
|
|
disabled = True
|
|
def setup_module(mod):
|
|
raise ValueError
|
|
def test_method():
|
|
pass
|
|
""")
|
|
l = modcol.collect()
|
|
assert len(l) == 1
|
|
recwarn.clear()
|
|
py.test.raises(Skipped, "modcol.setup()")
|
|
recwarn.pop(DeprecationWarning)
|
|
|
|
def test_disabled_class(self, recwarn, testdir):
|
|
modcol = testdir.getmodulecol("""
|
|
class TestClass:
|
|
disabled = True
|
|
def test_method(self):
|
|
pass
|
|
""")
|
|
l = modcol.collect()
|
|
assert len(l) == 1
|
|
modcol = l[0]
|
|
assert isinstance(modcol, py.test.collect.Class)
|
|
l = modcol.collect()
|
|
assert len(l) == 1
|
|
recwarn.clear()
|
|
py.test.raises(Skipped, "modcol.setup()")
|
|
recwarn.pop(DeprecationWarning)
|
|
|
|
def test_disabled_class_functional(self, testdir):
|
|
reprec = testdir.inline_runsource("""
|
|
class TestSimpleClassSetup:
|
|
disabled = True
|
|
def test_classlevel(self): pass
|
|
def test_classlevel2(self): pass
|
|
""")
|
|
reprec.assertoutcome(skipped=2)
|
|
|
|
@py.test.mark.multi(name="Directory Module Class Function".split())
|
|
def test_function_deprecated_run_execute(self, name, testdir, recwarn):
|
|
testdir.makeconftest("""
|
|
import py
|
|
class %s(py.test.collect.%s):
|
|
pass
|
|
""" % (name, name))
|
|
p = testdir.makepyfile("""
|
|
class TestClass:
|
|
def test_method(self):
|
|
pass
|
|
def test_function():
|
|
pass
|
|
""")
|
|
config = testdir.parseconfig()
|
|
if name == "Directory":
|
|
config.getnode(testdir.tmpdir)
|
|
elif name in ("Module", "File"):
|
|
config.getnode(p)
|
|
else:
|
|
fnode = config.getnode(p)
|
|
recwarn.clear()
|
|
fnode.collect()
|
|
w = recwarn.pop(DeprecationWarning)
|
|
assert "conftest.py" in str(w.message)
|
|
|
|
def test_config_cmdline_options(recwarn, testdir):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
def _callback(option, opt_str, value, parser, *args, **kwargs):
|
|
option.tdest = True
|
|
Option = py.test.config.Option
|
|
option = py.test.config.addoptions("testing group",
|
|
Option('-G', '--glong', action="store", default=42,
|
|
type="int", dest="gdest", help="g value."),
|
|
# XXX note: special case, option without a destination
|
|
Option('-T', '--tlong', action="callback", callback=_callback,
|
|
help='t value'),
|
|
)
|
|
""")
|
|
recwarn.clear()
|
|
config = testdir.reparseconfig(['-G', '17'])
|
|
recwarn.pop(DeprecationWarning)
|
|
assert config.option.gdest == 17
|
|
|
|
def test_dist_conftest_options(testdir):
|
|
p1 = testdir.tmpdir.ensure("dir", 'p1.py')
|
|
p1.dirpath("__init__.py").write("")
|
|
p1.dirpath("conftest.py").write(py.code.Source("""
|
|
import py
|
|
from py.builtin import print_
|
|
print_("importing conftest", __file__)
|
|
Option = py.test.config.Option
|
|
option = py.test.config.addoptions("someopt",
|
|
Option('--someopt', action="store_true",
|
|
dest="someopt", default=False))
|
|
dist_rsync_roots = ['../dir']
|
|
print_("added options", option)
|
|
print_("config file seen from conftest", py.test.config)
|
|
"""))
|
|
p1.write(py.code.Source("""
|
|
import py
|
|
from %s import conftest
|
|
from py.builtin import print_
|
|
def test_1():
|
|
print_("config from test_1", py.test.config)
|
|
print_("conftest from test_1", conftest.__file__)
|
|
print_("test_1: py.test.config.option.someopt", py.test.config.option.someopt)
|
|
print_("test_1: conftest", conftest)
|
|
print_("test_1: conftest.option.someopt", conftest.option.someopt)
|
|
assert conftest.option.someopt
|
|
""" % p1.dirpath().purebasename ))
|
|
result = testdir.runpytest('-d', '--tx=popen', p1, '--someopt')
|
|
assert result.ret == 0
|
|
result.stderr.fnmatch_lines([
|
|
"*Deprecation*pytest_addoptions*",
|
|
])
|
|
result.stdout.fnmatch_lines([
|
|
"*1 passed*",
|
|
])
|
|
|
|
def test_conftest_non_python_items(recwarn, testdir):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
class CustomItem(py.test.collect.Item):
|
|
def run(self):
|
|
pass
|
|
class Directory(py.test.collect.Directory):
|
|
def consider_file(self, fspath):
|
|
if fspath.ext == ".xxx":
|
|
return CustomItem(fspath.basename, parent=self)
|
|
""")
|
|
checkfile = testdir.makefile(ext="xxx", hello="world")
|
|
testdir.makepyfile(x="")
|
|
testdir.maketxtfile(x="")
|
|
config = testdir.parseconfig()
|
|
recwarn.clear()
|
|
dircol = config.getnode(checkfile.dirpath())
|
|
w = recwarn.pop(DeprecationWarning)
|
|
assert str(w.message).find("conftest.py") != -1
|
|
colitems = dircol.collect()
|
|
assert len(colitems) == 1
|
|
assert colitems[0].name == "hello.xxx"
|
|
assert colitems[0].__class__.__name__ == "CustomItem"
|
|
|
|
item = config.getnode(checkfile)
|
|
assert item.name == "hello.xxx"
|
|
assert item.__class__.__name__ == "CustomItem"
|
|
|
|
def test_extra_python_files_and_functions(testdir):
|
|
testdir.makepyfile(conftest="""
|
|
import py
|
|
class MyFunction(py.test.collect.Function):
|
|
pass
|
|
class Directory(py.test.collect.Directory):
|
|
def consider_file(self, path):
|
|
if path.check(fnmatch="check_*.py"):
|
|
return self.Module(path, parent=self)
|
|
return super(Directory, self).consider_file(path)
|
|
class myfuncmixin:
|
|
Function = MyFunction
|
|
def funcnamefilter(self, name):
|
|
return name.startswith('check_')
|
|
class Module(myfuncmixin, py.test.collect.Module):
|
|
def classnamefilter(self, name):
|
|
return name.startswith('CustomTestClass')
|
|
class Instance(myfuncmixin, py.test.collect.Instance):
|
|
pass
|
|
""")
|
|
checkfile = testdir.makepyfile(check_file="""
|
|
def check_func():
|
|
assert 42 == 42
|
|
class CustomTestClass:
|
|
def check_method(self):
|
|
assert 23 == 23
|
|
""")
|
|
# check that directory collects "check_" files
|
|
config = testdir.parseconfig()
|
|
col = config.getnode(checkfile.dirpath())
|
|
colitems = col.collect()
|
|
assert len(colitems) == 1
|
|
assert isinstance(colitems[0], py.test.collect.Module)
|
|
|
|
# check that module collects "check_" functions and methods
|
|
config = testdir.parseconfig(checkfile)
|
|
col = config.getnode(checkfile)
|
|
assert isinstance(col, py.test.collect.Module)
|
|
colitems = col.collect()
|
|
assert len(colitems) == 2
|
|
funccol = colitems[0]
|
|
assert isinstance(funccol, py.test.collect.Function)
|
|
assert funccol.name == "check_func"
|
|
clscol = colitems[1]
|
|
assert isinstance(clscol, py.test.collect.Class)
|
|
colitems = clscol.collect()[0].collect()
|
|
assert len(colitems) == 1
|
|
assert colitems[0].name == "check_method"
|
|
|