Factorized requires_tz_support decorator in test utils
Thanks Aymeric Augustin for the suggestion. Refs #21165.
This commit is contained in:
parent
d64060a736
commit
c1c44b2506
|
@ -2,6 +2,8 @@ from contextlib import contextmanager
|
||||||
import logging
|
import logging
|
||||||
import re
|
import re
|
||||||
import sys
|
import sys
|
||||||
|
import time
|
||||||
|
from unittest import skipUnless
|
||||||
import warnings
|
import warnings
|
||||||
from functools import wraps
|
from functools import wraps
|
||||||
from xml.dom.minidom import parseString, Node
|
from xml.dom.minidom import parseString, Node
|
||||||
|
@ -21,10 +23,11 @@ from django.utils.translation import deactivate
|
||||||
|
|
||||||
__all__ = (
|
__all__ = (
|
||||||
'Approximate', 'ContextList', 'get_runner', 'override_settings',
|
'Approximate', 'ContextList', 'get_runner', 'override_settings',
|
||||||
'setup_test_environment', 'teardown_test_environment',
|
'requires_tz_support', 'setup_test_environment', 'teardown_test_environment',
|
||||||
)
|
)
|
||||||
|
|
||||||
RESTORE_LOADERS_ATTR = '_original_template_source_loaders'
|
RESTORE_LOADERS_ATTR = '_original_template_source_loaders'
|
||||||
|
TZ_SUPPORT = hasattr(time, 'tzset')
|
||||||
|
|
||||||
|
|
||||||
class Approximate(object):
|
class Approximate(object):
|
||||||
|
@ -417,3 +420,13 @@ def patch_logger(logger_name, log_level):
|
||||||
yield calls
|
yield calls
|
||||||
finally:
|
finally:
|
||||||
setattr(logger, log_level, orig)
|
setattr(logger, log_level, orig)
|
||||||
|
|
||||||
|
|
||||||
|
# On OSes that don't provide tzset (Windows), we can't set the timezone
|
||||||
|
# in which the program runs. As a consequence, we must skip tests that
|
||||||
|
# don't enforce a specific timezone (with timezone.override or equivalent),
|
||||||
|
# or attempt to interpret naive datetimes in the default timezone.
|
||||||
|
|
||||||
|
requires_tz_support = skipUnless(TZ_SUPPORT,
|
||||||
|
"This test relies on the ability to run a program in an arbitrary "
|
||||||
|
"time zone, but your operating system isn't able to do that.")
|
||||||
|
|
|
@ -1,27 +1,14 @@
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
import time
|
|
||||||
import datetime
|
import datetime
|
||||||
from unittest import skipUnless
|
|
||||||
|
|
||||||
from django.core.exceptions import ImproperlyConfigured
|
from django.core.exceptions import ImproperlyConfigured
|
||||||
from django.test import TestCase, skipUnlessDBFeature
|
from django.test import TestCase, skipUnlessDBFeature
|
||||||
from django.test.utils import override_settings
|
from django.test.utils import override_settings, requires_tz_support
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
|
||||||
from .models import Book, BookSigning
|
from .models import Book, BookSigning
|
||||||
|
|
||||||
TZ_SUPPORT = hasattr(time, 'tzset')
|
|
||||||
|
|
||||||
# On OSes that don't provide tzset (Windows), we can't set the timezone
|
|
||||||
# in which the program runs. As a consequence, we must skip tests that
|
|
||||||
# don't enforce a specific timezone (with timezone.override or equivalent),
|
|
||||||
# or attempt to interpret naive datetimes in the default timezone.
|
|
||||||
|
|
||||||
requires_tz_support = skipUnless(TZ_SUPPORT,
|
|
||||||
"This test relies on the ability to run a program in an arbitrary "
|
|
||||||
"time zone, but your operating system isn't able to do that.")
|
|
||||||
|
|
||||||
|
|
||||||
def _make_books(n, base_date):
|
def _make_books(n, base_date):
|
||||||
for i in range(n):
|
for i in range(n):
|
||||||
|
|
|
@ -4,8 +4,7 @@ import datetime
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
import sys
|
import sys
|
||||||
import time
|
from unittest import skipIf
|
||||||
from unittest import skipIf, skipUnless
|
|
||||||
import warnings
|
import warnings
|
||||||
from xml.dom.minidom import parseString
|
from xml.dom.minidom import parseString
|
||||||
|
|
||||||
|
@ -22,7 +21,7 @@ from django.db.models import Min, Max
|
||||||
from django.http import HttpRequest
|
from django.http import HttpRequest
|
||||||
from django.template import Context, RequestContext, Template, TemplateSyntaxError
|
from django.template import Context, RequestContext, Template, TemplateSyntaxError
|
||||||
from django.test import TestCase, skipIfDBFeature, skipUnlessDBFeature
|
from django.test import TestCase, skipIfDBFeature, skipUnlessDBFeature
|
||||||
from django.test.utils import override_settings
|
from django.test.utils import override_settings, requires_tz_support
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
|
||||||
|
@ -42,17 +41,6 @@ UTC = timezone.utc
|
||||||
EAT = timezone.get_fixed_timezone(180) # Africa/Nairobi
|
EAT = timezone.get_fixed_timezone(180) # Africa/Nairobi
|
||||||
ICT = timezone.get_fixed_timezone(420) # Asia/Bangkok
|
ICT = timezone.get_fixed_timezone(420) # Asia/Bangkok
|
||||||
|
|
||||||
TZ_SUPPORT = hasattr(time, 'tzset')
|
|
||||||
|
|
||||||
# On OSes that don't provide tzset (Windows), we can't set the timezone
|
|
||||||
# in which the program runs. As a consequence, we must skip tests that
|
|
||||||
# don't enforce a specific timezone (with timezone.override or equivalent),
|
|
||||||
# or attempt to interpret naive datetimes in the default timezone.
|
|
||||||
|
|
||||||
requires_tz_support = skipUnless(TZ_SUPPORT,
|
|
||||||
"This test relies on the ability to run a program in an arbitrary "
|
|
||||||
"time zone, but your operating system isn't able to do that.")
|
|
||||||
|
|
||||||
|
|
||||||
@override_settings(TIME_ZONE='Africa/Nairobi', USE_TZ=False)
|
@override_settings(TIME_ZONE='Africa/Nairobi', USE_TZ=False)
|
||||||
class LegacyDatabaseTests(TestCase):
|
class LegacyDatabaseTests(TestCase):
|
||||||
|
|
Loading…
Reference in New Issue