2008-09-10 17:47:37 +08:00
|
|
|
import py
|
2009-08-28 00:46:42 +08:00
|
|
|
mypath = py.path.local(__file__).new(ext=".py")
|
2008-09-10 17:47:37 +08:00
|
|
|
|
2009-04-10 05:04:51 +08:00
|
|
|
def test_forwarding_to_warnings_module():
|
|
|
|
py.test.deprecated_call(py.log._apiwarn, "1.3", "..")
|
|
|
|
|
2010-07-05 04:13:12 +08:00
|
|
|
def test_apiwarn_functional(recwarn):
|
2009-04-10 05:04:51 +08:00
|
|
|
capture = py.io.StdCapture()
|
2009-09-07 23:53:50 +08:00
|
|
|
py.log._apiwarn("x.y.z", "something", stacklevel=1)
|
2009-04-10 05:04:51 +08:00
|
|
|
out, err = capture.reset()
|
2009-08-30 02:04:48 +08:00
|
|
|
py.builtin.print_("out", out)
|
|
|
|
py.builtin.print_("err", err)
|
2009-04-10 05:04:51 +08:00
|
|
|
assert err.find("x.y.z") != -1
|
2009-09-01 22:10:21 +08:00
|
|
|
lno = py.code.getrawcode(test_apiwarn_functional).co_firstlineno + 2
|
2009-04-10 05:04:51 +08:00
|
|
|
exp = "%s:%s" % (mypath, lno)
|
|
|
|
assert err.find(exp) != -1
|
|
|
|
|
2010-07-05 04:13:12 +08:00
|
|
|
def test_stacklevel(recwarn):
|
2009-04-10 05:04:51 +08:00
|
|
|
def f():
|
|
|
|
py.log._apiwarn("x", "some", stacklevel=2)
|
|
|
|
# 3
|
|
|
|
# 4
|
|
|
|
capture = py.io.StdCapture()
|
|
|
|
f()
|
|
|
|
out, err = capture.reset()
|
2009-09-01 22:10:21 +08:00
|
|
|
lno = py.code.getrawcode(test_stacklevel).co_firstlineno + 6
|
2009-04-10 05:04:51 +08:00
|
|
|
warning = str(err)
|
|
|
|
assert warning.find(":%s" % lno) != -1
|
2009-05-06 04:31:18 +08:00
|
|
|
|
2010-07-05 04:13:12 +08:00
|
|
|
def test_stacklevel_initpkg_with_resolve(testdir, recwarn):
|
2009-11-12 20:10:30 +08:00
|
|
|
testdir.makepyfile(modabc="""
|
2009-08-28 03:12:55 +08:00
|
|
|
import py
|
|
|
|
def f():
|
2009-11-12 20:10:30 +08:00
|
|
|
py.log._apiwarn("x", "some", stacklevel="apipkg123")
|
|
|
|
""")
|
|
|
|
testdir.makepyfile(apipkg123="""
|
|
|
|
def __getattr__():
|
|
|
|
import modabc
|
|
|
|
modabc.f()
|
|
|
|
""")
|
|
|
|
p = testdir.makepyfile("""
|
|
|
|
import apipkg123
|
|
|
|
apipkg123.__getattr__()
|
|
|
|
""")
|
2009-08-28 03:12:55 +08:00
|
|
|
capture = py.io.StdCapture()
|
2009-11-12 20:10:30 +08:00
|
|
|
p.pyimport()
|
2009-08-28 03:12:55 +08:00
|
|
|
out, err = capture.reset()
|
|
|
|
warning = str(err)
|
2009-11-12 20:10:30 +08:00
|
|
|
loc = 'test_stacklevel_initpkg_with_resolve.py:2'
|
|
|
|
assert warning.find(loc) != -1
|
2009-08-28 03:12:55 +08:00
|
|
|
|
2010-07-05 04:13:12 +08:00
|
|
|
def test_stacklevel_initpkg_no_resolve(recwarn):
|
2009-08-28 03:12:55 +08:00
|
|
|
def f():
|
2009-11-12 20:10:30 +08:00
|
|
|
py.log._apiwarn("x", "some", stacklevel="apipkg")
|
2009-08-28 03:12:55 +08:00
|
|
|
capture = py.io.StdCapture()
|
|
|
|
f()
|
|
|
|
out, err = capture.reset()
|
2009-09-01 22:10:21 +08:00
|
|
|
lno = py.code.getrawcode(test_stacklevel_initpkg_no_resolve).co_firstlineno + 2
|
2009-08-28 03:12:55 +08:00
|
|
|
warning = str(err)
|
|
|
|
assert warning.find(":%s" % lno) != -1
|
|
|
|
|
|
|
|
|
2010-07-05 04:13:12 +08:00
|
|
|
def test_function(recwarn):
|
2009-05-06 04:31:18 +08:00
|
|
|
capture = py.io.StdCapture()
|
|
|
|
py.log._apiwarn("x.y.z", "something", function=test_function)
|
|
|
|
out, err = capture.reset()
|
2009-08-30 02:04:48 +08:00
|
|
|
py.builtin.print_("out", out)
|
|
|
|
py.builtin.print_("err", err)
|
2009-05-06 04:31:18 +08:00
|
|
|
assert err.find("x.y.z") != -1
|
2010-07-27 03:15:15 +08:00
|
|
|
lno = py.code.getrawcode(test_function).co_firstlineno
|
2009-05-06 04:31:18 +08:00
|
|
|
exp = "%s:%s" % (mypath, lno)
|
|
|
|
assert err.find(exp) != -1
|
|
|
|
|