1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
|
import os
from contextlib import contextmanager
from functools import wraps
import logging
from io import StringIO
from time import tzset
from unittest.mock import patch
import tzlocal
def skip_by_server_version(testcase, version_required):
testcase.skipTest(
'Minimum revision required: {}'.format(
'.'.join(str(x) for x in version_required)
)
)
def require_server_version(*version_required):
def check(f):
@wraps(f)
def wrapper(*args, **kwargs):
self = args[0]
self.client.connection.connect()
current = self.client.connection.server_info.version_tuple()
if version_required <= current:
return f(*args, **kwargs)
else:
skip_by_server_version(self, version_required)
return wrapper
return check
class LoggingCapturer(object):
def __init__(self, logger_name, level):
self.old_stdout_handlers = []
self.logger = logging.getLogger(logger_name)
self.level = level
super(LoggingCapturer, self).__init__()
def __enter__(self):
buffer = StringIO()
self.new_handler = logging.StreamHandler(buffer)
self.logger.addHandler(self.new_handler)
self.old_logger_level = self.logger.level
self.logger.setLevel(self.level)
return buffer
def __exit__(self, *exc_info):
self.logger.setLevel(self.old_logger_level)
self.logger.removeHandler(self.new_handler)
capture_logging = LoggingCapturer
def bust_tzlocal_cache():
try:
tzlocal.unix._cache_tz = None
tzlocal.unix._cache_tz_name = None
except AttributeError:
pass
try:
tzlocal.win32._cache_tz = None
tzlocal.unix._cache_tz_name = None
except AttributeError:
pass
@contextmanager
def patch_env_tz(tz_name):
bust_tzlocal_cache()
# Although in many cases, changing the TZ environment variable may
# affect the output of functions like localtime() without calling
# tzset(), this behavior should not be relied on.
# https://docs.python.org/3/library/time.html#time.tzset
with patch.dict(os.environ, {'TZ': tz_name}):
tzset()
yield
tzset()
|