Commit bbc73e6a authored by Roger Hu's avatar Roger Hu Committed by Baptiste Mispelon
Browse files

Fixed #21566 -- Fixed AttributeError when using bulk_create with ForeignObject.

parent 38e24d68
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -389,7 +389,7 @@ class QuerySet(object):
            return objs
        self._for_write = True
        connection = connections[self.db]
        fields = self.model._meta.local_fields
        fields = self.model._meta.local_concrete_fields
        with transaction.commit_on_success_unless_managed(using=self.db):
            if (connection.features.can_combine_inserts_with_and_without_auto_increment_pk
                    and self.model._meta.has_auto_field):
+7 −1
Original line number Diff line number Diff line
@@ -4,7 +4,7 @@ from operator import attrgetter
from .models import (
    Country, Person, Group, Membership, Friendship, Article,
    ArticleTranslation, ArticleTag, ArticleIdea, NewsArticle)
from django.test import TestCase
from django.test import TestCase, skipUnlessDBFeature
from django.utils.translation import activate
from django.core.exceptions import FieldError
from django import forms
@@ -380,6 +380,12 @@ class MultiColumnFKTests(TestCase):
                    'active_translation')[0].active_translation.title,
                "foo")

    @skipUnlessDBFeature('has_bulk_insert')
    def test_batch_create_foreign_object(self):
        """ See: https://code.djangoproject.com/ticket/21566 """
        objs = [Person(name="abcd_%s" % i, person_country=self.usa) for i in range(0, 5)]
        Person.objects.bulk_create(objs, 10)


class FormsTests(TestCase):
    # ForeignObjects should not have any form fields, currently the user needs