mirror of
https://github.com/psycopg/psycopg2.git
synced 2025-10-24 20:41:07 +03:00
Simplify 'decorate_all_tests' usage by decorating the test class
Skip tests as early as possible by decorating the whole class with unittest.skipIf instead of every test method individually.
This commit is contained in:
parent
483901ea7b
commit
a739c09f67
|
@ -25,23 +25,14 @@ import unittest
|
||||||
import psycopg2
|
import psycopg2
|
||||||
import psycopg2.extras
|
import psycopg2.extras
|
||||||
|
|
||||||
|
|
||||||
@testutils.decorate_all_tests
|
|
||||||
def skip_if_no_ipaddress(f):
|
|
||||||
@wraps(f)
|
|
||||||
def skip_if_no_ipaddress_(self):
|
|
||||||
if sys.version_info[:2] < (3, 3):
|
|
||||||
try:
|
try:
|
||||||
import ipaddress # noqa
|
import ipaddress
|
||||||
except ImportError:
|
except ImportError:
|
||||||
return self.skipTest("'ipaddress' module not available")
|
# Python 2
|
||||||
|
ipaddress = None
|
||||||
return f(self)
|
|
||||||
|
|
||||||
return skip_if_no_ipaddress_
|
|
||||||
|
|
||||||
|
|
||||||
@skip_if_no_ipaddress
|
@unittest.skipIf(ipaddress is None, "'ipaddress' module not available")
|
||||||
class NetworkingTestCase(testutils.ConnectingTestCase):
|
class NetworkingTestCase(testutils.ConnectingTestCase):
|
||||||
def test_inet_cast(self):
|
def test_inet_cast(self):
|
||||||
import ipaddress as ip
|
import ipaddress as ip
|
||||||
|
|
|
@ -298,17 +298,13 @@ def skip_before_libpq(*ver):
|
||||||
"""Skip a test if libpq we're linked to is older than a certain version."""
|
"""Skip a test if libpq we're linked to is older than a certain version."""
|
||||||
ver = ver + (0,) * (3 - len(ver))
|
ver = ver + (0,) * (3 - len(ver))
|
||||||
|
|
||||||
@decorate_all_tests
|
def skip_before_libpq_(cls):
|
||||||
def skip_before_libpq_(f):
|
|
||||||
@wraps(f)
|
|
||||||
def skip_before_libpq__(self):
|
|
||||||
v = libpq_version()
|
v = libpq_version()
|
||||||
if v < int("%d%02d%02d" % ver):
|
decorator = unittest.skipIf(
|
||||||
return self.skipTest("skipped because libpq %d" % v)
|
v < int("%d%02d%02d" % ver),
|
||||||
else:
|
"skipped because libpq %d" % v,
|
||||||
return f(self)
|
)
|
||||||
|
return decorator(cls)
|
||||||
return skip_before_libpq__
|
|
||||||
return skip_before_libpq_
|
return skip_before_libpq_
|
||||||
|
|
||||||
|
|
||||||
|
@ -316,49 +312,37 @@ def skip_after_libpq(*ver):
|
||||||
"""Skip a test if libpq we're linked to is newer than a certain version."""
|
"""Skip a test if libpq we're linked to is newer than a certain version."""
|
||||||
ver = ver + (0,) * (3 - len(ver))
|
ver = ver + (0,) * (3 - len(ver))
|
||||||
|
|
||||||
@decorate_all_tests
|
def skip_after_libpq_(cls):
|
||||||
def skip_after_libpq_(f):
|
|
||||||
@wraps(f)
|
|
||||||
def skip_after_libpq__(self):
|
|
||||||
v = libpq_version()
|
v = libpq_version()
|
||||||
if v >= int("%d%02d%02d" % ver):
|
decorator = unittest.skipIf(
|
||||||
return self.skipTest("skipped because libpq %s" % v)
|
v >= int("%d%02d%02d" % ver),
|
||||||
else:
|
"skipped because libpq %s" % v,
|
||||||
return f(self)
|
)
|
||||||
|
return decorator(cls)
|
||||||
return skip_after_libpq__
|
|
||||||
return skip_after_libpq_
|
return skip_after_libpq_
|
||||||
|
|
||||||
|
|
||||||
def skip_before_python(*ver):
|
def skip_before_python(*ver):
|
||||||
"""Skip a test on Python before a certain version."""
|
"""Skip a test on Python before a certain version."""
|
||||||
@decorate_all_tests
|
def skip_before_python_(cls):
|
||||||
def skip_before_python_(f):
|
decorator = unittest.skipIf(
|
||||||
@wraps(f)
|
sys.version_info[:len(ver)] < ver,
|
||||||
def skip_before_python__(self):
|
"skipped because Python %s"
|
||||||
if sys.version_info[:len(ver)] < ver:
|
% ".".join(map(str, sys.version_info[:len(ver)])),
|
||||||
return self.skipTest("skipped because Python %s"
|
)
|
||||||
% ".".join(map(str, sys.version_info[:len(ver)])))
|
return decorator(cls)
|
||||||
else:
|
|
||||||
return f(self)
|
|
||||||
|
|
||||||
return skip_before_python__
|
|
||||||
return skip_before_python_
|
return skip_before_python_
|
||||||
|
|
||||||
|
|
||||||
def skip_from_python(*ver):
|
def skip_from_python(*ver):
|
||||||
"""Skip a test on Python after (including) a certain version."""
|
"""Skip a test on Python after (including) a certain version."""
|
||||||
@decorate_all_tests
|
def skip_from_python_(cls):
|
||||||
def skip_from_python_(f):
|
decorator = unittest.skipIf(
|
||||||
@wraps(f)
|
sys.version_info[:len(ver)] >= ver,
|
||||||
def skip_from_python__(self):
|
"skipped because Python %s"
|
||||||
if sys.version_info[:len(ver)] >= ver:
|
% ".".join(map(str, sys.version_info[:len(ver)])),
|
||||||
return self.skipTest("skipped because Python %s"
|
)
|
||||||
% ".".join(map(str, sys.version_info[:len(ver)])))
|
return decorator(cls)
|
||||||
else:
|
|
||||||
return f(self)
|
|
||||||
|
|
||||||
return skip_from_python__
|
|
||||||
return skip_from_python_
|
return skip_from_python_
|
||||||
|
|
||||||
|
|
||||||
|
@ -381,44 +365,31 @@ def skip_if_no_superuser(f):
|
||||||
|
|
||||||
|
|
||||||
def skip_if_green(reason):
|
def skip_if_green(reason):
|
||||||
@decorate_all_tests
|
def skip_if_green_(cls):
|
||||||
def skip_if_green_(f):
|
|
||||||
@wraps(f)
|
|
||||||
def skip_if_green__(self):
|
|
||||||
from .testconfig import green
|
from .testconfig import green
|
||||||
if green:
|
decorator = unittest.skipIf(green, reason)
|
||||||
return self.skipTest(reason)
|
return decorator(cls)
|
||||||
else:
|
|
||||||
return f(self)
|
|
||||||
|
|
||||||
return skip_if_green__
|
|
||||||
return skip_if_green_
|
return skip_if_green_
|
||||||
|
|
||||||
|
|
||||||
skip_copy_if_green = skip_if_green("copy in async mode currently not supported")
|
skip_copy_if_green = skip_if_green("copy in async mode currently not supported")
|
||||||
|
|
||||||
|
|
||||||
@decorate_all_tests
|
def skip_if_no_getrefcount(cls):
|
||||||
def skip_if_no_getrefcount(f):
|
decorator = unittest.skipUnless(
|
||||||
@wraps(f)
|
hasattr(sys, 'getrefcount'),
|
||||||
def skip_if_no_getrefcount_(self):
|
'no sys.getrefcount()',
|
||||||
if not hasattr(sys, 'getrefcount'):
|
)
|
||||||
return self.skipTest('skipped, no sys.getrefcount()')
|
return decorator(cls)
|
||||||
else:
|
|
||||||
return f(self)
|
|
||||||
return skip_if_no_getrefcount_
|
|
||||||
|
|
||||||
|
|
||||||
@decorate_all_tests
|
def skip_if_windows(cls):
|
||||||
def skip_if_windows(f):
|
|
||||||
"""Skip a test if run on windows"""
|
"""Skip a test if run on windows"""
|
||||||
@wraps(f)
|
decorator = unittest.skipIf(
|
||||||
def skip_if_windows_(self):
|
platform.system() == 'Windows',
|
||||||
if platform.system() == 'Windows':
|
"Not supported on Windows",
|
||||||
return self.skipTest("Not supported on Windows")
|
)
|
||||||
else:
|
return decorator(cls)
|
||||||
return f(self)
|
|
||||||
return skip_if_windows_
|
|
||||||
|
|
||||||
|
|
||||||
class py3_raises_typeerror(object):
|
class py3_raises_typeerror(object):
|
||||||
|
|
Loading…
Reference in New Issue
Block a user