From 8c06b21a45943d50364d278eefd3970a0aed9faa Mon Sep 17 00:00:00 2001 From: Andriy Svyryd Date: Mon, 7 Dec 2020 17:44:48 -0800 Subject: [PATCH] Add quirk mode for #23516 --- .../Internal/InternalForeignKeyBuilder.cs | 39 ++++++++++--------- 1 file changed, 21 insertions(+), 18 deletions(-) diff --git a/src/EFCore/Metadata/Internal/InternalForeignKeyBuilder.cs b/src/EFCore/Metadata/Internal/InternalForeignKeyBuilder.cs index e077506a851..63a2329f6d9 100644 --- a/src/EFCore/Metadata/Internal/InternalForeignKeyBuilder.cs +++ b/src/EFCore/Metadata/Internal/InternalForeignKeyBuilder.cs @@ -1742,26 +1742,29 @@ public virtual InternalForeignKeyBuilder HasForeignKey( [NotNull] EntityType dependentEntityType, ConfigurationSource configurationSource) { - using (var batch = Metadata.DeclaringEntityType.Model.ConventionDispatcher.DelayConventions()) + using var batch = AppContext.TryGetSwitch("Microsoft.EntityFrameworkCore.Issue23516", out var enabled) && enabled + ? null + : Metadata.DeclaringEntityType.Model.ConventionDispatcher.DelayConventions(); + + var relationship = HasForeignKey( + dependentEntityType.Builder.GetOrCreateProperties( + propertyNames, + configurationSource, + Metadata.PrincipalKey.Properties, + Metadata.GetIsRequiredConfigurationSource() != null && Metadata.IsRequired, + Metadata.GetPrincipalKeyConfigurationSource() == null + && Metadata.PrincipalEntityType.FindPrimaryKey() == null), + dependentEntityType, + configurationSource); + + if (relationship == null) { - var relationship = HasForeignKey( - dependentEntityType.Builder.GetOrCreateProperties( - propertyNames, - configurationSource, - Metadata.PrincipalKey.Properties, - Metadata.GetIsRequiredConfigurationSource() != null && Metadata.IsRequired, - Metadata.GetPrincipalKeyConfigurationSource() == null - && Metadata.PrincipalEntityType.FindPrimaryKey() == null), - dependentEntityType, - configurationSource); - - if (relationship == null) - { - return null; - } - - return (InternalForeignKeyBuilder)batch.Run(relationship.Metadata)?.Builder; + return null; } + + return batch == null + ? relationship + : (InternalForeignKeyBuilder)batch.Run(relationship.Metadata)?.Builder; } ///