mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	[1.7.x] Fixed #23420 - broken warning for unbound naive datetime objects
Fixed issue with warning message displayed for unbound naive datetime
objects when USE_TZ is True. Adds unit test that demonstrates the issue
(discoverable when using a custom lookup in MySQL).
Backport of ceb1ffcc8d from master.
Conflicts:
	tests/custom_lookups/tests.py
			
			
This commit is contained in:
		
				
					committed by
					
						 Anssi Kääriäinen
						Anssi Kääriäinen
					
				
			
			
				
	
			
			
			
						parent
						
							74d0311d6b
						
					
				
				
					commit
					12e5b87b89
				
			| @@ -1,13 +1,14 @@ | ||||
| from __future__ import unicode_literals | ||||
|  | ||||
| from datetime import date | ||||
| from datetime import date, datetime | ||||
| import time | ||||
| import unittest | ||||
|  | ||||
| from django.core.exceptions import FieldError | ||||
| from django.db import models | ||||
| from django.db import connection | ||||
| from django.test import TestCase | ||||
| from .models import Author | ||||
| from django.test import TestCase, override_settings | ||||
| from .models import Author, MySQLUnixTimestamp | ||||
|  | ||||
|  | ||||
| class Div3Lookup(models.Lookup): | ||||
| @@ -150,6 +151,18 @@ class InMonth(models.lookups.Lookup): | ||||
|                 (lhs, rhs, lhs, rhs), params) | ||||
|  | ||||
|  | ||||
| class DateTimeTransform(models.Transform): | ||||
|     lookup_name = 'as_datetime' | ||||
|  | ||||
|     @property | ||||
|     def output_field(self): | ||||
|         return models.DateTimeField() | ||||
|  | ||||
|     def as_sql(self, qn, connection): | ||||
|         lhs, params = qn.compile(self.lhs) | ||||
|         return 'from_unixtime({})'.format(lhs), params | ||||
|  | ||||
|  | ||||
| class LookupTests(TestCase): | ||||
|     def test_basic_lookup(self): | ||||
|         a1 = Author.objects.create(name='a1', age=1) | ||||
| @@ -229,6 +242,21 @@ class LookupTests(TestCase): | ||||
|             models.IntegerField._unregister_lookup(Div3Transform) | ||||
|  | ||||
|  | ||||
| @override_settings(USE_TZ=True) | ||||
| class DateTimeLookupTests(TestCase): | ||||
|     @unittest.skipUnless(connection.vendor == 'mysql', "MySQL specific SQL used") | ||||
|     def test_datetime_output_field(self): | ||||
|         models.PositiveIntegerField.register_lookup(DateTimeTransform) | ||||
|         try: | ||||
|             ut = MySQLUnixTimestamp.objects.create(timestamp=time.time()) | ||||
|             y2k = datetime(2000, 1, 1) | ||||
|             self.assertQuerysetEqual( | ||||
|                 MySQLUnixTimestamp.objects.filter(timestamp__as_datetime__gt=y2k), | ||||
|                 [ut], lambda x: x) | ||||
|         finally: | ||||
|             models.PositiveIntegerField._unregister_lookup(DateTimeTransform) | ||||
|  | ||||
|  | ||||
| class YearLteTests(TestCase): | ||||
|     def setUp(self): | ||||
|         models.DateField.register_lookup(YearTransform) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user