mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #10785 -- Corrected a case for foreign key lookup where the related object is a custom primary key. Thanks to Alex Gaynor for the patch.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10952 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		
							
								
								
									
										54
									
								
								tests/modeltests/custom_pk/fields.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								tests/modeltests/custom_pk/fields.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| import random | ||||
| import string | ||||
|  | ||||
| from django.db import models | ||||
|  | ||||
| class MyWrapper(object): | ||||
|     def __init__(self, value): | ||||
|         self.value = value | ||||
|  | ||||
|     def __repr__(self): | ||||
|         return "<%s: %s>" % (self.__class__.__name__, self.value) | ||||
|  | ||||
|     def __unicode__(self): | ||||
|         return self.value | ||||
|  | ||||
|     def __eq__(self, other): | ||||
|         if isinstance(other, self.__class__): | ||||
|             return self.value == other.value | ||||
|         return self.value == other | ||||
|  | ||||
| class MyAutoField(models.CharField): | ||||
|     __metaclass__ = models.SubfieldBase | ||||
|  | ||||
|     def __init__(self, *args, **kwargs): | ||||
|         kwargs['max_length'] = 10 | ||||
|         super(MyAutoField, self).__init__(*args, **kwargs) | ||||
|  | ||||
|     def pre_save(self, instance, add): | ||||
|         value = getattr(instance, self.attname, None) | ||||
|         if not value: | ||||
|             value = MyWrapper(''.join(random.sample(string.lowercase, 10))) | ||||
|             setattr(instance, self.attname, value) | ||||
|         return value | ||||
|  | ||||
|     def to_python(self, value): | ||||
|         if not value: | ||||
|             return | ||||
|         if not isinstance(value, MyWrapper): | ||||
|             value = MyWrapper(value) | ||||
|         return value | ||||
|  | ||||
|     def get_db_prep_save(self, value): | ||||
|         if not value: | ||||
|             return | ||||
|         if isinstance(value, MyWrapper): | ||||
|             return unicode(value) | ||||
|         return value | ||||
|  | ||||
|     def get_db_prep_value(self, value): | ||||
|         if not value: | ||||
|             return | ||||
|         if isinstance(value, MyWrapper): | ||||
|             return unicode(value) | ||||
|         return value | ||||
		Reference in New Issue
	
	Block a user