Skip to content

Commit

Permalink
Fixed #9029 -- Allow use of fieldname_id with get_or_create. Thanks t…
Browse files Browse the repository at this point in the history
…o aaron and mrmachine.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@15156 bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information
andrewgodwin committed Jan 8, 2011
1 parent 32a344d commit 81e05a4
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 3 deletions.
8 changes: 6 additions & 2 deletions django/db/models/query.py
Original file line number Diff line number Diff line change
Expand Up @@ -369,9 +369,13 @@ def get_or_create(self, **kwargs):
assert kwargs, \
'get_or_create() must be passed at least one keyword argument'
defaults = kwargs.pop('defaults', {})
lookup = kwargs.copy()
for f in self.model._meta.fields:
if f.column in lookup:
lookup[f.name] = lookup.pop(f.column)
try:
self._for_write = True
return self.get(**kwargs), False
return self.get(**lookup), False
except self.model.DoesNotExist:
try:
params = dict([(k, v) for k, v in kwargs.items() if '__' not in k])
Expand All @@ -384,7 +388,7 @@ def get_or_create(self, **kwargs):
except IntegrityError, e:
transaction.savepoint_rollback(sid, using=self.db)
try:
return self.get(**kwargs), False
return self.get(**lookup), False
except self.model.DoesNotExist:
raise e

Expand Down
11 changes: 10 additions & 1 deletion tests/regressiontests/get_or_create_regress/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ def test_related(self):
# Add an author to the book.
ed, created = book.authors.get_or_create(name="Ed")
self.assertTrue(created)
# Book should have one author.
# The book should have one author.
self.assertEqual(book.authors.count(), 1)

# Try get_or_create again, this time nothing should be created.
Expand Down Expand Up @@ -51,3 +51,12 @@ def test_related(self):
# Now Ed has two Books, Fred just one.
self.assertEqual(ed.books.count(), 2)
self.assertEqual(fred.books.count(), 1)

# Use the publisher's primary key value instead of a model instance.
_, created = ed.books.get_or_create(name='The Great Book of Ed', publisher_id=p.id)
self.assertTrue(created)
# Try get_or_create again, this time nothing should be created.
_, created = ed.books.get_or_create(name='The Great Book of Ed', publisher_id=p.id)
self.assertFalse(created)
# The publisher should have three books.
self.assertEqual(p.books.count(), 3)

0 comments on commit 81e05a4

Please sign in to comment.