mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	[1.2.X] Migrated the custom_columns doctests to unit tests. Thanks to Alex Gaynor.
Backport of r13765 from trunk. git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.2.X@14071 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -38,68 +38,3 @@ class Article(models.Model): | |||||||
|     class Meta: |     class Meta: | ||||||
|         ordering = ('headline',) |         ordering = ('headline',) | ||||||
|  |  | ||||||
| __test__ = {'API_TESTS':""" |  | ||||||
| # Create a Author. |  | ||||||
| >>> a = Author(first_name='John', last_name='Smith') |  | ||||||
| >>> a.save() |  | ||||||
|  |  | ||||||
| >>> a.id |  | ||||||
| 1 |  | ||||||
|  |  | ||||||
| # Create another author |  | ||||||
| >>> a2 = Author(first_name='Peter', last_name='Jones') |  | ||||||
| >>> a2.save() |  | ||||||
|  |  | ||||||
| # Create an article |  | ||||||
| >>> art = Article(headline='Django lets you build web apps easily') |  | ||||||
| >>> art.save() |  | ||||||
| >>> art.authors = [a, a2] |  | ||||||
|  |  | ||||||
| # Although the table and column names on Author have been set to custom values, |  | ||||||
| # nothing about using the Author model has changed... |  | ||||||
|  |  | ||||||
| # Query the available authors |  | ||||||
| >>> Author.objects.all() |  | ||||||
| [<Author: Peter Jones>, <Author: John Smith>] |  | ||||||
|  |  | ||||||
| >>> Author.objects.filter(first_name__exact='John') |  | ||||||
| [<Author: John Smith>] |  | ||||||
|  |  | ||||||
| >>> Author.objects.get(first_name__exact='John') |  | ||||||
| <Author: John Smith> |  | ||||||
|  |  | ||||||
| >>> Author.objects.filter(firstname__exact='John') |  | ||||||
| Traceback (most recent call last): |  | ||||||
|     ... |  | ||||||
| FieldError: Cannot resolve keyword 'firstname' into field. Choices are: article, first_name, id, last_name |  | ||||||
|  |  | ||||||
| >>> a = Author.objects.get(last_name__exact='Smith') |  | ||||||
| >>> a.first_name |  | ||||||
| u'John' |  | ||||||
| >>> a.last_name |  | ||||||
| u'Smith' |  | ||||||
| >>> a.firstname |  | ||||||
| Traceback (most recent call last): |  | ||||||
|     ... |  | ||||||
| AttributeError: 'Author' object has no attribute 'firstname' |  | ||||||
| >>> a.last |  | ||||||
| Traceback (most recent call last): |  | ||||||
|     ... |  | ||||||
| AttributeError: 'Author' object has no attribute 'last' |  | ||||||
|  |  | ||||||
| # Although the Article table uses a custom m2m table, |  | ||||||
| # nothing about using the m2m relationship has changed... |  | ||||||
|  |  | ||||||
| # Get all the authors for an article |  | ||||||
| >>> art.authors.all() |  | ||||||
| [<Author: Peter Jones>, <Author: John Smith>] |  | ||||||
|  |  | ||||||
| # Get the articles for an author |  | ||||||
| >>> a.article_set.all() |  | ||||||
| [<Article: Django lets you build web apps easily>] |  | ||||||
|  |  | ||||||
| # Query the authors across the m2m relation |  | ||||||
| >>> art.authors.filter(last_name='Jones') |  | ||||||
| [<Author: Peter Jones>] |  | ||||||
|  |  | ||||||
| """} |  | ||||||
|   | |||||||
							
								
								
									
										71
									
								
								tests/modeltests/custom_columns/tests.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								tests/modeltests/custom_columns/tests.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | |||||||
|  | from django.core.exceptions import FieldError | ||||||
|  | from django.test import TestCase | ||||||
|  |  | ||||||
|  | from models import Author, Article | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class CustomColumnsTests(TestCase): | ||||||
|  |     def test_db_column(self): | ||||||
|  |         a1 = Author.objects.create(first_name="John", last_name="Smith") | ||||||
|  |         a2 = Author.objects.create(first_name="Peter", last_name="Jones") | ||||||
|  |  | ||||||
|  |         art = Article.objects.create(headline="Django lets you build web apps easily") | ||||||
|  |         art.authors = [a1, a2] | ||||||
|  |  | ||||||
|  |         # Although the table and column names on Author have been set to custom | ||||||
|  |         # values, nothing about using the Author model has changed... | ||||||
|  |  | ||||||
|  |         # Query the available authors | ||||||
|  |         self.assertQuerysetEqual( | ||||||
|  |             Author.objects.all(), [ | ||||||
|  |                 "Peter Jones", "John Smith", | ||||||
|  |             ], | ||||||
|  |             unicode | ||||||
|  |         ) | ||||||
|  |         self.assertQuerysetEqual( | ||||||
|  |             Author.objects.filter(first_name__exact="John"), [ | ||||||
|  |                 "John Smith", | ||||||
|  |             ], | ||||||
|  |             unicode | ||||||
|  |         ) | ||||||
|  |         self.assertEqual( | ||||||
|  |             Author.objects.get(first_name__exact="John"), | ||||||
|  |             a1, | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         self.assertRaises(FieldError, | ||||||
|  |             lambda: Author.objects.filter(firstname__exact="John") | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         a = Author.objects.get(last_name__exact="Smith") | ||||||
|  |         a.first_name = "John" | ||||||
|  |         a.last_name = "Smith" | ||||||
|  |  | ||||||
|  |         self.assertRaises(AttributeError, lambda: a.firstname) | ||||||
|  |         self.assertRaises(AttributeError, lambda: a.last) | ||||||
|  |  | ||||||
|  |         # Although the Article table uses a custom m2m table, | ||||||
|  |         # nothing about using the m2m relationship has changed... | ||||||
|  |  | ||||||
|  |         # Get all the authors for an article | ||||||
|  |         self.assertQuerysetEqual( | ||||||
|  |             art.authors.all(), [ | ||||||
|  |                 "Peter Jones", | ||||||
|  |                 "John Smith", | ||||||
|  |             ], | ||||||
|  |             unicode | ||||||
|  |         ) | ||||||
|  |         # Get the articles for an author | ||||||
|  |         self.assertQuerysetEqual( | ||||||
|  |             a.article_set.all(), [ | ||||||
|  |                 "Django lets you build web apps easily", | ||||||
|  |             ], | ||||||
|  |             lambda a: a.headline | ||||||
|  |         ) | ||||||
|  |         # Query the authors across the m2m relation | ||||||
|  |         self.assertQuerysetEqual( | ||||||
|  |             art.authors.filter(last_name='Jones'), [ | ||||||
|  |                 "Peter Jones" | ||||||
|  |             ], | ||||||
|  |             unicode | ||||||
|  |         ) | ||||||
		Reference in New Issue
	
	Block a user