Skip to content

Commit

Permalink
check connection string in StorageAccountDetails since its no longer …
Browse files Browse the repository at this point in the history
…assigned any value in StorageConnectionString
  • Loading branch information
HanChong77 committed Oct 1, 2024
1 parent 87d38a8 commit 32bb7ab
Show file tree
Hide file tree
Showing 3 changed files with 67 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -159,7 +159,7 @@ private AzureStorageDurabilityProvider GetAzureStorageStorageProvider(DurableCli
// Need to check this.defaultStorageProvider != null for external clients that call GetDurabilityProvider(attribute)
// which never initializes the defaultStorageProvider.
if (string.Equals(this.defaultSettings?.TaskHubName, settings.TaskHubName, StringComparison.OrdinalIgnoreCase) &&
string.Equals(this.defaultSettings?.StorageConnectionString, settings.StorageConnectionString, StringComparison.OrdinalIgnoreCase) &&
string.Equals(this.defaultSettings?.StorageAccountDetails?.ConnectionString, settings.StorageAccountDetails?.ConnectionString, StringComparison.OrdinalIgnoreCase) &&
this.defaultStorageProvider != null)
{
// It's important that clients use the same AzureStorageOrchestrationService instance
Expand Down
25 changes: 25 additions & 0 deletions test/Common/CustomTestStorageAccountProvider.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the MIT License. See LICENSE in the project root for license information.

using DurableTask.AzureStorage;
using Microsoft.WindowsAzure.Storage;

namespace Microsoft.Azure.WebJobs.Extensions.DurableTask.Tests
{
internal class CustomTestStorageAccountProvider : IStorageAccountProvider
{
private const string CustomConnectionString = "DefaultEndpointsProtocol=https;AccountName=test;AccountKey=dGVzdA==;EndpointSuffix=core.windows.net";
private readonly string customConnectionName;

public CustomTestStorageAccountProvider(string connectionName)
{
this.customConnectionName = connectionName;
}

public CloudStorageAccount GetCloudStorageAccount(string name) =>
CloudStorageAccount.Parse(name != this.customConnectionName ? TestHelpers.GetStorageConnectionString() : CustomConnectionString);

public StorageAccountDetails GetStorageAccountDetails(string name) =>
new StorageAccountDetails { ConnectionString = name != this.customConnectionName ? TestHelpers.GetStorageConnectionString() : CustomConnectionString };
}
}
41 changes: 41 additions & 0 deletions test/FunctionsV2/AzureStorageDurabilityProviderFactoryTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -154,5 +154,46 @@ public void EnvironmentIsVMSS_WorkerIdFromEnvironmentVariables()

Assert.Equal("waws-prod-euapbn1-003:dw0SmallDedicatedWebWorkerRole_hr0HostRole-3-VM-13", settings.WorkerId);
}

[Fact]
[Trait("Category", PlatformSpecificHelpers.TestCategory)]
public void CustomConnectionNameIsResolved()
{
var storageAccountProvider = new CustomTestStorageAccountProvider("CustomConnection");
var mockOptions = new OptionsWrapper<DurableTaskOptions>(new DurableTaskOptions());
var nameResolver = new Mock<INameResolver>().Object;

var factory = new AzureStorageDurabilityProviderFactory(
mockOptions,
storageAccountProvider,
nameResolver,
NullLoggerFactory.Instance,
TestHelpers.GetMockPlatformInformationService());

factory.GetDurabilityProvider(); // This will initialize the default connection string
var provider = factory.GetDurabilityProvider(new DurableClientAttribute() { ConnectionName = "CustomConnection", TaskHub = "TestHubName" });

Assert.Equal("CustomConnection", provider.ConnectionName);
}

[Fact]
[Trait("Category", PlatformSpecificHelpers.TestCategory)]
public void DefaultConnectionNameIsResolved()
{
var storageAccountProvider = new CustomTestStorageAccountProvider("CustomConnection");
var mockOptions = new OptionsWrapper<DurableTaskOptions>(new DurableTaskOptions());
var nameResolver = new Mock<INameResolver>().Object;

var factory = new AzureStorageDurabilityProviderFactory(
mockOptions,
storageAccountProvider,
nameResolver,
NullLoggerFactory.Instance,
TestHelpers.GetMockPlatformInformationService());

var provider = factory.GetDurabilityProvider();

Assert.Equal("Storage", provider.ConnectionName);
}
}
}

0 comments on commit 32bb7ab

Please sign in to comment.