2013-10-11 17:28:32 +00:00
|
|
|
# testing/warnings.py
|
2014-09-30 16:15:32 +00:00
|
|
|
# Copyright (C) 2005-2014 the SQLAlchemy authors and contributors
|
|
|
|
# <see AUTHORS file>
|
2013-10-11 17:28:32 +00:00
|
|
|
#
|
|
|
|
# This module is part of SQLAlchemy and is released under
|
|
|
|
# the MIT License: http://www.opensource.org/licenses/mit-license.php
|
|
|
|
|
|
|
|
from __future__ import absolute_import
|
|
|
|
|
|
|
|
import warnings
|
|
|
|
from .. import exc as sa_exc
|
|
|
|
from .. import util
|
|
|
|
import re
|
|
|
|
|
2014-09-30 16:15:32 +00:00
|
|
|
|
2013-10-11 17:28:32 +00:00
|
|
|
def testing_warn(msg, stacklevel=3):
|
|
|
|
"""Replaces sqlalchemy.util.warn during tests."""
|
|
|
|
|
|
|
|
filename = "sqlalchemy.testing.warnings"
|
|
|
|
lineno = 1
|
|
|
|
if isinstance(msg, util.string_types):
|
|
|
|
warnings.warn_explicit(msg, sa_exc.SAWarning, filename, lineno)
|
|
|
|
else:
|
|
|
|
warnings.warn_explicit(msg, filename, lineno)
|
|
|
|
|
|
|
|
|
|
|
|
def resetwarnings():
|
|
|
|
"""Reset warning behavior to testing defaults."""
|
|
|
|
|
|
|
|
util.warn = util.langhelpers.warn = testing_warn
|
|
|
|
|
|
|
|
warnings.filterwarnings('ignore',
|
|
|
|
category=sa_exc.SAPendingDeprecationWarning)
|
|
|
|
warnings.filterwarnings('error', category=sa_exc.SADeprecationWarning)
|
|
|
|
warnings.filterwarnings('error', category=sa_exc.SAWarning)
|
|
|
|
|
|
|
|
|
|
|
|
def assert_warnings(fn, warnings, regex=False):
|
|
|
|
"""Assert that each of the given warnings are emitted by fn."""
|
|
|
|
|
|
|
|
from .assertions import eq_, emits_warning
|
|
|
|
|
|
|
|
canary = []
|
|
|
|
orig_warn = util.warn
|
|
|
|
|
|
|
|
def capture_warnings(*args, **kw):
|
|
|
|
orig_warn(*args, **kw)
|
|
|
|
popwarn = warnings.pop(0)
|
|
|
|
canary.append(popwarn)
|
|
|
|
if regex:
|
|
|
|
assert re.match(popwarn, args[0])
|
|
|
|
else:
|
|
|
|
eq_(args[0], popwarn)
|
|
|
|
util.warn = util.langhelpers.warn = capture_warnings
|
|
|
|
|
|
|
|
result = emits_warning()(fn)()
|
|
|
|
assert canary, "No warning was emitted"
|
|
|
|
return result
|