mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Migrated string_lookup doctests. Thanks to Stephan Jaekel.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@13895 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -43,67 +43,3 @@ class Article(models.Model): | |||||||
|  |  | ||||||
|     def __str__(self): |     def __str__(self): | ||||||
|         return "Article %s" % self.name |         return "Article %s" % self.name | ||||||
|  |  | ||||||
| __test__ = {'API_TESTS': ur""" |  | ||||||
| # Regression test for #1661 and #1662: Check that string form referencing of |  | ||||||
| # models works, both as pre and post reference, on all RelatedField types. |  | ||||||
|  |  | ||||||
| >>> f1 = Foo(name="Foo1") |  | ||||||
| >>> f1.save() |  | ||||||
| >>> f2 = Foo(name="Foo2") |  | ||||||
| >>> f2.save() |  | ||||||
|  |  | ||||||
| >>> w1 = Whiz(name="Whiz1") |  | ||||||
| >>> w1.save() |  | ||||||
|  |  | ||||||
| >>> b1 = Bar(name="Bar1", normal=f1, fwd=w1, back=f2) |  | ||||||
| >>> b1.save() |  | ||||||
|  |  | ||||||
| >>> b1.normal |  | ||||||
| <Foo: Foo Foo1> |  | ||||||
|  |  | ||||||
| >>> b1.fwd |  | ||||||
| <Whiz: Whiz Whiz1> |  | ||||||
|  |  | ||||||
| >>> b1.back |  | ||||||
| <Foo: Foo Foo2> |  | ||||||
|  |  | ||||||
| >>> base1 = Base(name="Base1") |  | ||||||
| >>> base1.save() |  | ||||||
|  |  | ||||||
| >>> child1 = Child(name="Child1", parent=base1) |  | ||||||
| >>> child1.save() |  | ||||||
|  |  | ||||||
| >>> child1.parent |  | ||||||
| <Base: Base Base1> |  | ||||||
|  |  | ||||||
| # Regression tests for #3937: make sure we can use unicode characters in |  | ||||||
| # queries. |  | ||||||
| # BUG: These tests fail on MySQL, but it's a problem with the test setup. A |  | ||||||
| # properly configured UTF-8 database can handle this. |  | ||||||
|  |  | ||||||
| >>> fx = Foo(name='Bjorn', friend=u'François') |  | ||||||
| >>> fx.save() |  | ||||||
| >>> Foo.objects.get(friend__contains=u'\xe7') |  | ||||||
| <Foo: Foo Bjorn> |  | ||||||
|  |  | ||||||
| # We can also do the above query using UTF-8 strings. |  | ||||||
| >>> Foo.objects.get(friend__contains='\xc3\xa7') |  | ||||||
| <Foo: Foo Bjorn> |  | ||||||
|  |  | ||||||
| # Regression tests for #5087: make sure we can perform queries on TextFields. |  | ||||||
| >>> a = Article(name='Test', text='The quick brown fox jumps over the lazy dog.') |  | ||||||
| >>> a.save() |  | ||||||
| >>> Article.objects.get(text__exact='The quick brown fox jumps over the lazy dog.') |  | ||||||
| <Article: Article Test> |  | ||||||
|  |  | ||||||
| >>> Article.objects.get(text__contains='quick brown fox') |  | ||||||
| <Article: Article Test> |  | ||||||
|  |  | ||||||
| # Regression test for #708: "like" queries on IP address fields require casting |  | ||||||
| # to text (on PostgreSQL). |  | ||||||
| >>> Article(name='IP test', text='The body', submitted_from='192.0.2.100').save() |  | ||||||
| >>> Article.objects.filter(submitted_from__contains='192.0.2') |  | ||||||
| [<Article: Article IP test>] |  | ||||||
|  |  | ||||||
| """} |  | ||||||
|   | |||||||
							
								
								
									
										78
									
								
								tests/regressiontests/string_lookup/tests.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								tests/regressiontests/string_lookup/tests.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | |||||||
|  | # -*- coding: utf-8 -*- | ||||||
|  | from django.test import TestCase | ||||||
|  | from regressiontests.string_lookup.models import Foo, Whiz, Bar, Article, Base, Child | ||||||
|  |  | ||||||
|  | class StringLookupTests(TestCase): | ||||||
|  |  | ||||||
|  |     def test_string_form_referencing(self): | ||||||
|  |         """ | ||||||
|  |         Regression test for #1661 and #1662 | ||||||
|  |  | ||||||
|  |         Check that string form referencing of | ||||||
|  |         models works, both as pre and post reference, on all RelatedField types. | ||||||
|  |         """ | ||||||
|  |  | ||||||
|  |         f1 = Foo(name="Foo1") | ||||||
|  |         f1.save() | ||||||
|  |         f2 = Foo(name="Foo2") | ||||||
|  |         f2.save() | ||||||
|  |  | ||||||
|  |         w1 = Whiz(name="Whiz1") | ||||||
|  |         w1.save() | ||||||
|  |  | ||||||
|  |         b1 = Bar(name="Bar1", normal=f1, fwd=w1, back=f2) | ||||||
|  |         b1.save() | ||||||
|  |  | ||||||
|  |         self.assertEquals(b1.normal, f1) | ||||||
|  |  | ||||||
|  |         self.assertEquals(b1.fwd, w1) | ||||||
|  |  | ||||||
|  |         self.assertEquals(b1.back, f2) | ||||||
|  |  | ||||||
|  |         base1 = Base(name="Base1") | ||||||
|  |         base1.save() | ||||||
|  |  | ||||||
|  |         child1 = Child(name="Child1", parent=base1) | ||||||
|  |         child1.save() | ||||||
|  |  | ||||||
|  |         self.assertEquals(child1.parent, base1) | ||||||
|  |  | ||||||
|  |     def test_unicode_chars_in_queries(self): | ||||||
|  |         """ | ||||||
|  |         Regression tests for #3937 | ||||||
|  |  | ||||||
|  |         make sure we can use unicode characters in queries. | ||||||
|  |         If these tests fail on MySQL, it's a problem with the test setup. | ||||||
|  |         A properly configured UTF-8 database can handle this. | ||||||
|  |         """ | ||||||
|  |  | ||||||
|  |         fx = Foo(name='Bjorn', friend=u'François') | ||||||
|  |         fx.save() | ||||||
|  |         self.assertEquals(Foo.objects.get(friend__contains=u'\xe7'), fx) | ||||||
|  |  | ||||||
|  |         # We can also do the above query using UTF-8 strings. | ||||||
|  |         self.assertEquals(Foo.objects.get(friend__contains='\xc3\xa7'), fx) | ||||||
|  |  | ||||||
|  |     def test_queries_on_textfields(self): | ||||||
|  |         """ | ||||||
|  |         Regression tests for #5087 | ||||||
|  |  | ||||||
|  |         make sure we can perform queries on TextFields. | ||||||
|  |         """ | ||||||
|  |  | ||||||
|  |         a = Article(name='Test', text='The quick brown fox jumps over the lazy dog.') | ||||||
|  |         a.save() | ||||||
|  |         self.assertEquals(Article.objects.get(text__exact='The quick brown fox jumps over the lazy dog.'), a) | ||||||
|  |  | ||||||
|  |         self.assertEquals(Article.objects.get(text__contains='quick brown fox'), a) | ||||||
|  |  | ||||||
|  |     def test_ipaddress_on_postgresql(self): | ||||||
|  |         """ | ||||||
|  |         Regression test for #708 | ||||||
|  |  | ||||||
|  |         "like" queries on IP address fields require casting to text (on PostgreSQL). | ||||||
|  |         """ | ||||||
|  |         a = Article(name='IP test', text='The body', submitted_from='192.0.2.100') | ||||||
|  |         a.save() | ||||||
|  |         self.assertEquals(repr(Article.objects.filter(submitted_from__contains='192.0.2')), | ||||||
|  |             repr([a])) | ||||||
		Reference in New Issue
	
	Block a user