Opened 18 years ago
Closed 16 years ago
#2122 closed (fixed)
get_FIELDNAME_display() fails on instance returned by AddManipulator.save().
Reported by: | Owned by: | nobody | |
---|---|---|---|
Component: | Core (Other) | Version: | dev |
Severity: | normal | Keywords: | |
Cc: | Triage Stage: | Accepted | |
Has patch: | no | Needs documentation: | no |
Needs tests: | yes | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
Invoking get_FIELDNAME_display() on a model instance returned by MODELNAME.AddManipulator.save() does not produce the expected result. After working with malcolmt on #django we decided it might be a good idea to file a ticket.
Problem: the value returned by get_FIELDNAME_display() is the string representation of the field itself rather than the decoded field value. The database seems to be intact, so I'd guess the severity/priority to be normal. Possible work arounds include using the saved instance (after extracting it from the db) rather than the instance returned by MODELNAME.AddManipulator.save().
Here's a simple example. I've included an "Example" model rather than the actual model to simplify the description of the problem.
IFIELD_CHOICES = ( (0, 'foo'), (1, 'bar'), (2, 'baz'), ) DEFAULT_IFIELD_CHOICE = 1 class Example(models.Model): ifield = models.IntegerField(choices=IFIELD_CHOICES, default=DEFAULT_IFIELD_CHOICE, blank=False) another_field = models.CharField(maxlength=16, blank=False) def __str__(self): return '%s: %s' % (self.get_ifield_display(), self.another_field) class Admin: pass
Given this model, the following code redirects to '1' when an Example is successfully saved. I'd expect it to redirect to 'bar'.
def example_add_form(request): """Add an example to the db.""" manipulator = Example.AddManipulator() new_data = {} errors = {} if request.POST: new_data = request.POST.copy() # Need mutable POST data. errors = manipulator.get_validation_errors(new_data) if not errors: manipulator.do_html2python(new_data) # Note: isinstance(new_data['top_level'], str) # returns True here example = manipulator.save(new_data) return HttpResponse(example.get_ifield_display()) # Create the form and load it into the example Django HTML template. form = forms.FormWrapper(manipulator, new_data, errors) return render_to_response('example.dht', {'form': form}, context_instance=RequestContext(request))
I'm using Ubuntu v.6.06, Apache v.2.0.55, Mod_python v.3.1.4, Python v.2.4.3, Django Rev.3103 (SVN).
I hope this helps. Please contact me if you need further clarification.
Change History (7)
comment:1 by , 18 years ago
Type: | defect |
---|
comment:2 by , 18 years ago
Needs tests: | set |
---|---|
Triage Stage: | Unreviewed → Accepted |
comment:4 by , 18 years ago
Just to add, the object returned by the manipulator.save() method still has the ifield
as a string instead of an integer and this seems to be what is causing the problem.
comment:5 by , 16 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
Manipulators are gone, and the bug doesn't exist in ModelForms.
comment:6 by , 16 years ago
Resolution: | fixed |
---|---|
Status: | closed → reopened |
comment:7 by , 16 years ago
Resolution: | → fixed |
---|---|
Status: | reopened → closed |
I confirmed that this bug still exists, but I'm not sure that it's worth fixing for manipulators. I'm marking this as accepted to make sure newforms doesn't have the some problem. Could someone please try this with newforms and report back.