diff --git a/django/db/backends/oracle/base.py b/django/db/backends/oracle/base.py index d3faa96e65c..3e8eae4d3ff 100644 --- a/django/db/backends/oracle/base.py +++ b/django/db/backends/oracle/base.py @@ -292,11 +292,24 @@ WHEN (new.%(col_name)s IS NULL) return "%sTABLESPACE %s" % ((inline and "USING INDEX " or ""), self.quote_name(tablespace)) + def value_to_db_datetime(self, value): + # Oracle doesn't support tz-aware datetimes + if getattr(value, 'tzinfo', None) is not None: + raise ValueError("Oracle backend does not support timezone-aware datetimes.") + + return super(DatabaseOperations, self).value_to_db_datetime(value) + def value_to_db_time(self, value): if value is None: return None + if isinstance(value, basestring): return datetime.datetime(*(time.strptime(value, '%H:%M:%S')[:6])) + + # Oracle doesn't support tz-aware datetimes + if value.tzinfo is not None: + raise ValueError("Oracle backend does not support timezone-aware datetimes.") + return datetime.datetime(1900, 1, 1, value.hour, value.minute, value.second, value.microsecond) diff --git a/tests/regressiontests/datatypes/tests.py b/tests/regressiontests/datatypes/tests.py index 1d44552a37e..eb09a5a6371 100644 --- a/tests/regressiontests/datatypes/tests.py +++ b/tests/regressiontests/datatypes/tests.py @@ -76,8 +76,8 @@ class DataTypesTestCase(TestCase): @skipIfDBFeature('supports_timezones') def test_error_on_timezone(self): - """Regression test for #8354: the MySQL backend should raise an error - if given a timezone-aware datetime object.""" + """Regression test for #8354: the MySQL and Oracle backends should raise + an error if given a timezone-aware datetime object.""" dt = datetime.datetime(2008, 8, 31, 16, 20, tzinfo=tzinfo.FixedOffset(0)) d = Donut(name='Bear claw', consumed_at=dt) self.assertRaises(ValueError, d.save)