mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Thanks Carl Meyer for the review. Squashed commit of the following: commit4f290bdb60Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Wed Feb 13 21:21:30 2013 +0100 Used '0:00' instead of 'UTC' which doesn't always exist in Oracle. Thanks Ian Kelly for the suggestion. commit01b6366f3cAuthor: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Wed Feb 13 13:38:43 2013 +0100 Made tzname a parameter of datetime_extract/trunc_sql. This is required to work around a bug in Oracle. commit924a144ef8Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Wed Feb 13 14:47:44 2013 +0100 Added support for parameters in SELECT clauses. commitb4351d2890Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Mon Feb 11 22:30:22 2013 +0100 Documented backwards incompatibilities in the two previous commits. commit91ef84713cAuthor: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Mon Feb 11 09:42:31 2013 +0100 Used QuerySet.datetimes for the admin's date_hierarchy. commit0d0de288a5Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Mon Feb 11 09:29:38 2013 +0100 Used QuerySet.datetimes in date-based generic views. commit9c0859ff7cAuthor: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 21:43:25 2013 +0100 Implemented QuerySet.datetimes on Oracle. commit68ab511a4fAuthor: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 21:43:14 2013 +0100 Implemented QuerySet.datetimes on MySQL. commit22d52681d3Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 21:42:29 2013 +0100 Implemented QuerySet.datetimes on SQLite. commitf6800fd04cAuthor: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 21:43:03 2013 +0100 Implemented QuerySet.datetimes on PostgreSQL. commit0c829c23f4Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 21:41:08 2013 +0100 Added datetime-handling infrastructure in the ORM layers. commit104d82a777Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Mon Feb 11 10:05:55 2013 +0100 Updated null_queries tests to avoid clashing with the __second lookup. commitc01bbb3235Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 23:07:41 2013 +0100 Updated tests of .dates(). Replaced .dates() by .datetimes() for DateTimeFields. Replaced dates with datetimes in the expected output for DateFields. commit50fb7a5246Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 21:40:09 2013 +0100 Updated and added tests for QuerySet.datetimes. commita8451a5004Author: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 22:34:46 2013 +0100 Documented the new time lookups and updated the date lookups. commit29413eab2bAuthor: Aymeric Augustin <aymeric.augustin@m4x.org> Date: Sun Feb 10 16:15:49 2013 +0100 Documented QuerySet.datetimes and updated QuerySet.dates.
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from __future__ import absolute_import
 | |
| 
 | |
| from django.test import TestCase
 | |
| from django.core.exceptions import FieldError
 | |
| 
 | |
| from .models import Poll, Choice, OuterA, Inner, OuterB
 | |
| 
 | |
| 
 | |
| class NullQueriesTests(TestCase):
 | |
| 
 | |
|     def test_none_as_null(self):
 | |
|         """
 | |
|         Regression test for the use of None as a query value.
 | |
| 
 | |
|         None is interpreted as an SQL NULL, but only in __exact queries.
 | |
|         Set up some initial polls and choices
 | |
|         """
 | |
|         p1 = Poll(question='Why?')
 | |
|         p1.save()
 | |
|         c1 = Choice(poll=p1, choice='Because.')
 | |
|         c1.save()
 | |
|         c2 = Choice(poll=p1, choice='Why Not?')
 | |
|         c2.save()
 | |
| 
 | |
|         # Exact query with value None returns nothing ("is NULL" in sql,
 | |
|         # but every 'id' field has a value).
 | |
|         self.assertQuerysetEqual(Choice.objects.filter(choice__exact=None), [])
 | |
| 
 | |
|         # Excluding the previous result returns everything.
 | |
|         self.assertQuerysetEqual(
 | |
|                 Choice.objects.exclude(choice=None).order_by('id'),
 | |
|                 [
 | |
|                     '<Choice: Choice: Because. in poll Q: Why? >',
 | |
|                     '<Choice: Choice: Why Not? in poll Q: Why? >'
 | |
|                 ]
 | |
|         )
 | |
| 
 | |
|         # Valid query, but fails because foo isn't a keyword
 | |
|         self.assertRaises(FieldError, Choice.objects.filter, foo__exact=None)
 | |
| 
 | |
|         # Can't use None on anything other than __exact
 | |
|         self.assertRaises(ValueError, Choice.objects.filter, id__gt=None)
 | |
| 
 | |
|         # Can't use None on anything other than __exact
 | |
|         self.assertRaises(ValueError, Choice.objects.filter, foo__gt=None)
 | |
| 
 | |
|         # Related managers use __exact=None implicitly if the object hasn't been saved.
 | |
|         p2 = Poll(question="How?")
 | |
|         self.assertEqual(repr(p2.choice_set.all()), '[]')
 | |
| 
 | |
|     def test_reverse_relations(self):
 | |
|         """
 | |
|         Querying across reverse relations and then another relation should
 | |
|         insert outer joins correctly so as not to exclude results.
 | |
|         """
 | |
|         obj = OuterA.objects.create()
 | |
|         self.assertQuerysetEqual(
 | |
|             OuterA.objects.filter(inner__third=None),
 | |
|             ['<OuterA: OuterA object>']
 | |
|         )
 | |
|         self.assertQuerysetEqual(
 | |
|             OuterA.objects.filter(inner__third__data=None),
 | |
|             ['<OuterA: OuterA object>']
 | |
|         )
 | |
| 
 | |
|         inner_obj = Inner.objects.create(first=obj)
 | |
|         self.assertQuerysetEqual(
 | |
|             Inner.objects.filter(first__inner__third=None),
 | |
|             ['<Inner: Inner object>']
 | |
|         )
 | |
| 
 | |
|         # Ticket #13815: check if <reverse>_isnull=False does not produce
 | |
|         # faulty empty lists
 | |
|         objB = OuterB.objects.create(data="reverse")
 | |
|         self.assertQuerysetEqual(
 | |
|             OuterB.objects.filter(inner__isnull=False),
 | |
|             []
 | |
|         )
 | |
|         Inner.objects.create(first=obj)
 | |
|         self.assertQuerysetEqual(
 | |
|             OuterB.objects.exclude(inner__isnull=False),
 | |
|             ['<OuterB: OuterB object>']
 | |
|         )
 |