mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Merge branch 'master' into lookups_3
Conflicts: django/db/models/fields/__init__.py django/db/models/sql/compiler.py django/db/models/sql/query.py tests/null_queries/tests.py
This commit is contained in:
		| @@ -12,7 +12,8 @@ class NullQueriesTests(TestCase): | ||||
|         """ | ||||
|         Regression test for the use of None as a query value. | ||||
|  | ||||
|         None is interpreted as an SQL NULL, but only in __exact queries. | ||||
|         None is interpreted as an SQL NULL, but only in __exact and __iexact | ||||
|         queries. | ||||
|         Set up some initial polls and choices | ||||
|         """ | ||||
|         p1 = Poll(question='Why?') | ||||
| @@ -26,6 +27,9 @@ class NullQueriesTests(TestCase): | ||||
|         # but every 'id' field has a value). | ||||
|         self.assertQuerysetEqual(Choice.objects.filter(choice__exact=None), []) | ||||
|  | ||||
|         # The same behavior for iexact query. | ||||
|         self.assertQuerysetEqual(Choice.objects.filter(choice__iexact=None), []) | ||||
|  | ||||
|         # Excluding the previous result returns everything. | ||||
|         self.assertQuerysetEqual( | ||||
|             Choice.objects.exclude(choice=None).order_by('id'), | ||||
| @@ -38,7 +42,7 @@ class NullQueriesTests(TestCase): | ||||
|         # 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 | ||||
|         # Can't use None on anything other than __exact and __iexact | ||||
|         self.assertRaises(ValueError, Choice.objects.filter, id__gt=None) | ||||
|  | ||||
|         # Related managers use __exact=None implicitly if the object hasn't been saved. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user