2016-08-22 18:17:59 +00:00
|
|
|
from __future__ import absolute_import, unicode_literals
|
|
|
|
|
|
|
|
import atexit
|
|
|
|
import os
|
|
|
|
import pytest
|
|
|
|
import sys
|
|
|
|
|
|
|
|
from kombu.exceptions import VersionMismatch
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='session')
|
|
|
|
def multiprocessing_workaround(request):
|
2016-09-29 21:57:42 +00:00
|
|
|
yield
|
|
|
|
# Workaround for multiprocessing bug where logging
|
|
|
|
# is attempted after global already collected at shutdown.
|
|
|
|
canceled = set()
|
|
|
|
try:
|
|
|
|
import multiprocessing.util
|
|
|
|
canceled.add(multiprocessing.util._exit_function)
|
|
|
|
except (AttributeError, ImportError):
|
|
|
|
pass
|
2016-08-22 18:17:59 +00:00
|
|
|
|
2016-09-29 21:57:42 +00:00
|
|
|
try:
|
|
|
|
atexit._exithandlers[:] = [
|
|
|
|
e for e in atexit._exithandlers if e[0] not in canceled
|
|
|
|
]
|
|
|
|
except AttributeError: # pragma: no cover
|
|
|
|
pass # Py3 missing _exithandlers
|
2016-08-22 18:17:59 +00:00
|
|
|
|
|
|
|
|
2016-10-27 21:22:19 +00:00
|
|
|
def zzz_reset_memory_transport_state():
|
2016-09-29 21:57:42 +00:00
|
|
|
yield
|
2016-10-27 21:22:19 +00:00
|
|
|
from kombu.transport import memory
|
|
|
|
memory.Transport.state.clear()
|
2016-08-22 18:17:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def test_cases_has_patching(request, patching):
|
|
|
|
if request.instance:
|
|
|
|
request.instance.patching = patching
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def hub(request):
|
|
|
|
from kombu.async import Hub, get_event_loop, set_event_loop
|
|
|
|
_prev_hub = get_event_loop()
|
|
|
|
hub = Hub()
|
|
|
|
set_event_loop(hub)
|
|
|
|
|
2016-09-29 21:57:42 +00:00
|
|
|
yield hub
|
|
|
|
|
|
|
|
if _prev_hub is not None:
|
|
|
|
set_event_loop(_prev_hub)
|
2016-08-22 18:17:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
def find_distribution_modules(name=__name__, file=__file__):
|
|
|
|
current_dist_depth = len(name.split('.')) - 1
|
|
|
|
current_dist = os.path.join(os.path.dirname(file),
|
|
|
|
*([os.pardir] * current_dist_depth))
|
|
|
|
abs = os.path.abspath(current_dist)
|
|
|
|
dist_name = os.path.basename(abs)
|
|
|
|
|
|
|
|
for dirpath, dirnames, filenames in os.walk(abs):
|
|
|
|
package = (dist_name + dirpath[len(abs):]).replace('/', '.')
|
|
|
|
if '__init__.py' in filenames:
|
|
|
|
yield package
|
|
|
|
for filename in filenames:
|
|
|
|
if filename.endswith('.py') and filename != '__init__.py':
|
|
|
|
yield '.'.join([package, filename])[:-3]
|
|
|
|
|
|
|
|
|
|
|
|
def import_all_modules(name=__name__, file=__file__, skip=[]):
|
|
|
|
for module in find_distribution_modules(name, file):
|
|
|
|
if module not in skip:
|
|
|
|
print('preimporting %r for coverage...' % (module,))
|
|
|
|
try:
|
|
|
|
__import__(module)
|
|
|
|
except (ImportError, VersionMismatch, AttributeError):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
def is_in_coverage():
|
|
|
|
return (os.environ.get('COVER_ALL_MODULES') or
|
|
|
|
any('--cov' in arg for arg in sys.argv))
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='session')
|
|
|
|
def cover_all_modules():
|
|
|
|
# so coverage sees all our modules.
|
|
|
|
if is_in_coverage():
|
|
|
|
import_all_modules()
|