From e44817d97f6f82e48c4b798a4cc39021a7d58bd5 Mon Sep 17 00:00:00 2001 From: Mark Wallace <127216156+markwallace-microsoft@users.noreply.github.com> Date: Tue, 10 Sep 2024 18:13:02 +0100 Subject: [PATCH] .Net: Switch from API keys to Azure Credentials when accessing Azure Cognitive Services (#8512) ### Motivation and Context Closes: #6966 --- .github/workflows/dotnet-build-and-test.yml | 11 ++++++ .../AzureOpenAIKernelBuilderExtensions.cs | 37 +++++++++++++++++++ .../Services/AzureOpenAITextToAudioService.cs | 33 +++++++++++++++++ .../Agents/ChatCompletionAgentTests.cs | 10 ++--- .../Agents/MixedAgentTests.cs | 9 +++-- .../Agents/OpenAIAssistantAgentTests.cs | 5 ++- .../AzureOpenAIAudioToTextTests.cs | 7 ++-- ...enAIChatCompletionFunctionCallingTests.cs} | 4 +- ...eOpenAIChatCompletionNonStreamingTests.cs} | 4 +- ...zureOpenAIChatCompletionStreamingTests.cs} | 4 +- .../AzureOpenAIChatCompletionTests.cs | 4 +- .../AzureOpenAITextEmbeddingTests.cs | 13 ++++--- .../AzureOpenAITextToAudioTests.cs | 7 ++-- .../AzureOpenAITextToImageTests.cs | 6 ++- .../Handlebars/HandlebarsPlannerTests.cs | 5 ++- dotnet/src/IntegrationTests/PromptTests.cs | 4 +- dotnet/src/IntegrationTests/README.md | 5 --- .../TestSettings/AzureOpenAIConfiguration.cs | 4 +- dotnet/src/IntegrationTests/testsettings.json | 19 ++++------ 19 files changed, 136 insertions(+), 55 deletions(-) rename dotnet/src/IntegrationTests/Connectors/AzureOpenAI/{AzureOpenAIChatCompletion_FunctionCallingTests.cs => AzureOpenAIChatCompletionFunctionCallingTests.cs} (99%) rename dotnet/src/IntegrationTests/Connectors/AzureOpenAI/{AzureOpenAIChatCompletion_NonStreamingTests.cs => AzureOpenAIChatCompletionNonStreamingTests.cs} (98%) rename dotnet/src/IntegrationTests/Connectors/AzureOpenAI/{AzureOpenAIChatCompletion_StreamingTests.cs => AzureOpenAIChatCompletionStreamingTests.cs} (98%) diff --git a/.github/workflows/dotnet-build-and-test.yml b/.github/workflows/dotnet-build-and-test.yml index f46adb441a41..034c959e6dde 100644 --- a/.github/workflows/dotnet-build-and-test.yml +++ b/.github/workflows/dotnet-build-and-test.yml @@ -21,6 +21,7 @@ concurrency: permissions: contents: read + id-token: "write" jobs: paths-filter: @@ -57,11 +58,13 @@ jobs: os: "ubuntu-latest", configuration: Release, integration-tests: true, + environment: "integration", } - { dotnet: "8.0", os: "windows-latest", configuration: Debug } - { dotnet: "8.0", os: "windows-latest", configuration: Release } runs-on: ${{ matrix.os }} + environment: ${{ matrix.environment }} steps: - uses: actions/checkout@v4 - name: Setup dotnet ${{ matrix.dotnet }} @@ -84,6 +87,14 @@ jobs: dotnet test -c ${{ matrix.configuration }} $project --no-build -v Normal --logger trx --collect:"XPlat Code Coverage" --results-directory:"TestResults/Coverage/" -- DataCollectionRunSettings.DataCollectors.DataCollector.Configuration.ExcludeByAttribute=GeneratedCodeAttribute,CompilerGeneratedAttribute,ExcludeFromCodeCoverageAttribute done + - name: Azure CLI Login + if: github.event_name != 'pull_request' && matrix.integration-tests + uses: azure/login@v2 + with: + client-id: ${{ secrets.AZURE_CLIENT_ID }} + tenant-id: ${{ secrets.AZURE_TENANT_ID }} + subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID }} + - name: Run Integration Tests shell: bash if: github.event_name != 'pull_request' && matrix.integration-tests diff --git a/dotnet/src/Connectors/Connectors.AzureOpenAI/Extensions/AzureOpenAIKernelBuilderExtensions.cs b/dotnet/src/Connectors/Connectors.AzureOpenAI/Extensions/AzureOpenAIKernelBuilderExtensions.cs index 86fbc7ac59df..5b42c6104373 100644 --- a/dotnet/src/Connectors/Connectors.AzureOpenAI/Extensions/AzureOpenAIKernelBuilderExtensions.cs +++ b/dotnet/src/Connectors/Connectors.AzureOpenAI/Extensions/AzureOpenAIKernelBuilderExtensions.cs @@ -249,6 +249,43 @@ public static IKernelBuilder AddAzureOpenAITextEmbeddingGeneration( return builder; } + /// + /// Adds the to the . + /// + /// The instance to augment. + /// Azure OpenAI deployment name, see https://learn.microsoft.com/azure/cognitive-services/openai/how-to/create-resource + /// Azure OpenAI deployment URL, see https://learn.microsoft.com/azure/cognitive-services/openai/quickstart + /// Token credentials, e.g. DefaultAzureCredential, ManagedIdentityCredential, EnvironmentCredential, etc. + /// A local identifier for the given AI service + /// Model identifier, see https://learn.microsoft.com/azure/cognitive-services/openai/quickstart + /// The HttpClient to use with this service. + /// The same instance as . + [Experimental("SKEXP0010")] + public static IKernelBuilder AddAzureOpenAITextToAudio( + this IKernelBuilder builder, + string deploymentName, + string endpoint, + TokenCredential credential, + string? serviceId = null, + string? modelId = null, + HttpClient? httpClient = null) + { + Verify.NotNull(builder); + Verify.NotNullOrWhiteSpace(endpoint); + Verify.NotNull(credential); + + builder.Services.AddKeyedSingleton(serviceId, (serviceProvider, _) => + new AzureOpenAITextToAudioService( + deploymentName, + endpoint, + credential, + modelId, + HttpClientProvider.GetHttpClient(httpClient, serviceProvider), + serviceProvider.GetService())); + + return builder; + } + #endregion #region Text-to-Audio diff --git a/dotnet/src/Connectors/Connectors.AzureOpenAI/Services/AzureOpenAITextToAudioService.cs b/dotnet/src/Connectors/Connectors.AzureOpenAI/Services/AzureOpenAITextToAudioService.cs index 0b9f98302a0b..0863d156a5b4 100644 --- a/dotnet/src/Connectors/Connectors.AzureOpenAI/Services/AzureOpenAITextToAudioService.cs +++ b/dotnet/src/Connectors/Connectors.AzureOpenAI/Services/AzureOpenAITextToAudioService.cs @@ -7,6 +7,7 @@ using System.Threading; using System.Threading.Tasks; using Azure.AI.OpenAI; +using Azure.Core; using Microsoft.Extensions.Logging; using Microsoft.SemanticKernel.Services; using Microsoft.SemanticKernel.TextToAudio; @@ -69,6 +70,38 @@ public AzureOpenAITextToAudioService( this._modelId = modelId; } + /// + /// Initializes a new instance of the class. + /// + /// Azure OpenAI deployment name, see https://learn.microsoft.com/azure/cognitive-services/openai/how-to/create-resource + /// Azure OpenAI deployment URL, see https://learn.microsoft.com/azure/cognitive-services/openai/quickstart + /// Token credentials, e.g. DefaultAzureCredential, ManagedIdentityCredential, EnvironmentCredential, etc. + /// Azure OpenAI model id, see https://learn.microsoft.com/azure/cognitive-services/openai/how-to/create-resource + /// Custom for HTTP requests. + /// The to use for logging. If null, no logging will be performed. + public AzureOpenAITextToAudioService( + string deploymentName, + string endpoint, + TokenCredential credential, + string? modelId = null, + HttpClient? httpClient = null, + ILoggerFactory? loggerFactory = null) + { + var url = !string.IsNullOrWhiteSpace(httpClient?.BaseAddress?.AbsoluteUri) ? httpClient!.BaseAddress!.AbsoluteUri : endpoint; + + var options = AzureClientCore.GetAzureOpenAIClientOptions( + httpClient, + AzureOpenAIClientOptions.ServiceVersion.V2024_05_01_Preview); // https://learn.microsoft.com/en-us/azure/ai-services/openai/reference#text-to-speech + + var azureOpenAIClient = new AzureOpenAIClient(new Uri(url), credential, options); + + this._client = new(deploymentName, azureOpenAIClient, loggerFactory?.CreateLogger(typeof(AzureOpenAITextToAudioService))); + + this._client.AddAttribute(AIServiceExtensions.ModelIdKey, modelId); + + this._modelId = modelId; + } + /// public Task> GetAudioContentsAsync( string text, diff --git a/dotnet/src/IntegrationTests/Agents/ChatCompletionAgentTests.cs b/dotnet/src/IntegrationTests/Agents/ChatCompletionAgentTests.cs index 008574d147de..98ff4a96d41f 100644 --- a/dotnet/src/IntegrationTests/Agents/ChatCompletionAgentTests.cs +++ b/dotnet/src/IntegrationTests/Agents/ChatCompletionAgentTests.cs @@ -4,12 +4,12 @@ using System.Linq; using System.Text; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.SemanticKernel; using Microsoft.SemanticKernel.Agents; using Microsoft.SemanticKernel.ChatCompletion; -using Microsoft.SemanticKernel.Connectors.AzureOpenAI; using Microsoft.SemanticKernel.Connectors.OpenAI; using SemanticKernel.IntegrationTests.TestSettings; using Xunit; @@ -43,9 +43,9 @@ public async Task AzureChatCompletionAgentAsync(string input, string expectedAns KernelPlugin plugin = KernelPluginFactory.CreateFromType(); this._kernelBuilder.AddAzureOpenAIChatCompletion( - configuration.ChatDeploymentName!, - configuration.Endpoint, - configuration.ApiKey); + deploymentName: configuration.ChatDeploymentName!, + endpoint: configuration.Endpoint, + credentials: new AzureCliCredential()); if (useAutoFunctionTermination) { @@ -107,7 +107,7 @@ public async Task AzureChatCompletionStreamingAsync() this._kernelBuilder.AddAzureOpenAIChatCompletion( configuration.ChatDeploymentName!, configuration.Endpoint, - configuration.ApiKey); + new AzureCliCredential()); this._kernelBuilder.Plugins.Add(plugin); diff --git a/dotnet/src/IntegrationTests/Agents/MixedAgentTests.cs b/dotnet/src/IntegrationTests/Agents/MixedAgentTests.cs index 35d68e550dd6..77f4f1f3bd5f 100644 --- a/dotnet/src/IntegrationTests/Agents/MixedAgentTests.cs +++ b/dotnet/src/IntegrationTests/Agents/MixedAgentTests.cs @@ -3,6 +3,7 @@ using System.ComponentModel; using System.Text; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.SemanticKernel; using Microsoft.SemanticKernel.Agents; @@ -55,7 +56,7 @@ public async Task AzureOpenAIMixedAgentAsync() // Arrange, Act & Assert await this.VerifyAgentExecutionAsync( this.CreateChatCompletionKernel(azureOpenAISettings), - OpenAIClientProvider.ForAzureOpenAI(azureOpenAISettings.ApiKey, new Uri(azureOpenAISettings.Endpoint)), + OpenAIClientProvider.ForAzureOpenAI(new AzureCliCredential(), new Uri(azureOpenAISettings.Endpoint)), azureOpenAISettings.ChatDeploymentName!); } @@ -120,9 +121,9 @@ private Kernel CreateChatCompletionKernel(AzureOpenAIConfiguration configuration IKernelBuilder kernelBuilder = Kernel.CreateBuilder(); kernelBuilder.AddAzureOpenAIChatCompletion( - configuration.ChatDeploymentName!, - configuration.Endpoint, - configuration.ApiKey); + deploymentName: configuration.ChatDeploymentName!, + endpoint: configuration.Endpoint, + credentials: new AzureCliCredential()); return kernelBuilder.Build(); } diff --git a/dotnet/src/IntegrationTests/Agents/OpenAIAssistantAgentTests.cs b/dotnet/src/IntegrationTests/Agents/OpenAIAssistantAgentTests.cs index 0e5756ff2fcd..62388488d483 100644 --- a/dotnet/src/IntegrationTests/Agents/OpenAIAssistantAgentTests.cs +++ b/dotnet/src/IntegrationTests/Agents/OpenAIAssistantAgentTests.cs @@ -4,6 +4,7 @@ using System.Linq; using System.Text; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.SemanticKernel; using Microsoft.SemanticKernel.Agents; @@ -55,7 +56,7 @@ public async Task AzureOpenAIAssistantAgentAsync(string input, string expectedAn Assert.NotNull(azureOpenAIConfiguration); await this.ExecuteAgentAsync( - OpenAIClientProvider.ForAzureOpenAI(azureOpenAIConfiguration.ApiKey, new Uri(azureOpenAIConfiguration.Endpoint)), + OpenAIClientProvider.ForAzureOpenAI(new AzureCliCredential(), new Uri(azureOpenAIConfiguration.Endpoint)), azureOpenAIConfiguration.ChatDeploymentName!, input, expectedAnswerContains); @@ -91,7 +92,7 @@ public async Task AzureOpenAIAssistantAgentStreamingAsync(string input, string e Assert.NotNull(azureOpenAIConfiguration); await this.ExecuteStreamingAgentAsync( - OpenAIClientProvider.ForAzureOpenAI(azureOpenAIConfiguration.ApiKey, new Uri(azureOpenAIConfiguration.Endpoint)), + OpenAIClientProvider.ForAzureOpenAI(new AzureCliCredential(), new Uri(azureOpenAIConfiguration.Endpoint)), azureOpenAIConfiguration.ChatDeploymentName!, input, expectedAnswerContains); diff --git a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIAudioToTextTests.cs b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIAudioToTextTests.cs index e155f6159c9a..13275f8b85bf 100644 --- a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIAudioToTextTests.cs +++ b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIAudioToTextTests.cs @@ -3,6 +3,7 @@ using System; using System.IO; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.SemanticKernel; using Microsoft.SemanticKernel.AudioToText; @@ -33,9 +34,9 @@ public async Task AzureOpenAIAudioToTextTestAsync() var kernel = Kernel.CreateBuilder() .AddAzureOpenAIAudioToText( - azureOpenAIConfiguration.DeploymentName, - azureOpenAIConfiguration.Endpoint, - azureOpenAIConfiguration.ApiKey) + deploymentName: azureOpenAIConfiguration.DeploymentName, + endpoint: azureOpenAIConfiguration.Endpoint, + credentials: new AzureCliCredential()) .Build(); var service = kernel.GetRequiredService(); diff --git a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_FunctionCallingTests.cs b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionFunctionCallingTests.cs similarity index 99% rename from dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_FunctionCallingTests.cs rename to dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionFunctionCallingTests.cs index aec7320867d2..9c9c0753d079 100644 --- a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_FunctionCallingTests.cs +++ b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionFunctionCallingTests.cs @@ -7,6 +7,7 @@ using System.Text; using System.Text.Json; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.SemanticKernel; using Microsoft.SemanticKernel.ChatCompletion; @@ -865,7 +866,6 @@ private Kernel CreateAndInitializeKernel(bool importHelperPlugin = false) var azureOpenAIConfiguration = this._configuration.GetSection("AzureOpenAI").Get(); Assert.NotNull(azureOpenAIConfiguration); Assert.NotNull(azureOpenAIConfiguration.ChatDeploymentName); - Assert.NotNull(azureOpenAIConfiguration.ApiKey); Assert.NotNull(azureOpenAIConfiguration.Endpoint); var kernelBuilder = base.CreateKernelBuilder(); @@ -874,7 +874,7 @@ private Kernel CreateAndInitializeKernel(bool importHelperPlugin = false) deploymentName: azureOpenAIConfiguration.ChatDeploymentName, modelId: azureOpenAIConfiguration.ChatModelId, endpoint: azureOpenAIConfiguration.Endpoint, - apiKey: azureOpenAIConfiguration.ApiKey); + credentials: new AzureCliCredential()); var kernel = kernelBuilder.Build(); diff --git a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_NonStreamingTests.cs b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionNonStreamingTests.cs similarity index 98% rename from dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_NonStreamingTests.cs rename to dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionNonStreamingTests.cs index a463410765f5..808227a40a11 100644 --- a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_NonStreamingTests.cs +++ b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionNonStreamingTests.cs @@ -3,6 +3,7 @@ using System.Collections.Generic; using System.Text.Json; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.SemanticKernel; @@ -147,7 +148,6 @@ private Kernel CreateAndInitializeKernel() var azureOpenAIConfiguration = this._configuration.GetSection("AzureOpenAI").Get(); Assert.NotNull(azureOpenAIConfiguration); Assert.NotNull(azureOpenAIConfiguration.ChatDeploymentName); - Assert.NotNull(azureOpenAIConfiguration.ApiKey); Assert.NotNull(azureOpenAIConfiguration.Endpoint); var kernelBuilder = base.CreateKernelBuilder(); @@ -156,7 +156,7 @@ private Kernel CreateAndInitializeKernel() deploymentName: azureOpenAIConfiguration.ChatDeploymentName, modelId: azureOpenAIConfiguration.ChatModelId, endpoint: azureOpenAIConfiguration.Endpoint, - apiKey: azureOpenAIConfiguration.ApiKey); + credentials: new AzureCliCredential()); return kernelBuilder.Build(); } diff --git a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_StreamingTests.cs b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionStreamingTests.cs similarity index 98% rename from dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_StreamingTests.cs rename to dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionStreamingTests.cs index 5fc0e7e0cad7..85d8785e829a 100644 --- a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletion_StreamingTests.cs +++ b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionStreamingTests.cs @@ -3,6 +3,7 @@ using System.Collections.Generic; using System.Text; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.SemanticKernel; @@ -148,7 +149,6 @@ private Kernel CreateAndInitializeKernel() var azureOpenAIConfiguration = this._configuration.GetSection("AzureOpenAI").Get(); Assert.NotNull(azureOpenAIConfiguration); Assert.NotNull(azureOpenAIConfiguration.ChatDeploymentName); - Assert.NotNull(azureOpenAIConfiguration.ApiKey); Assert.NotNull(azureOpenAIConfiguration.Endpoint); var kernelBuilder = base.CreateKernelBuilder(); @@ -157,7 +157,7 @@ private Kernel CreateAndInitializeKernel() deploymentName: azureOpenAIConfiguration.ChatDeploymentName, modelId: azureOpenAIConfiguration.ChatModelId, endpoint: azureOpenAIConfiguration.Endpoint, - apiKey: azureOpenAIConfiguration.ApiKey); + credentials: new AzureCliCredential()); return kernelBuilder.Build(); } diff --git a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionTests.cs b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionTests.cs index 7d47ee0f45e0..2f0dd43e8b88 100644 --- a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionTests.cs +++ b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAIChatCompletionTests.cs @@ -8,6 +8,7 @@ using System.Text.Json; using System.Threading; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Http.Resilience; @@ -232,7 +233,6 @@ private Kernel CreateAndInitializeKernel(HttpClient? httpClient = null) var azureOpenAIConfiguration = this._configuration.GetSection("AzureOpenAI").Get(); Assert.NotNull(azureOpenAIConfiguration); Assert.NotNull(azureOpenAIConfiguration.ChatDeploymentName); - Assert.NotNull(azureOpenAIConfiguration.ApiKey); Assert.NotNull(azureOpenAIConfiguration.Endpoint); Assert.NotNull(azureOpenAIConfiguration.ServiceId); @@ -242,7 +242,7 @@ private Kernel CreateAndInitializeKernel(HttpClient? httpClient = null) deploymentName: azureOpenAIConfiguration.ChatDeploymentName, modelId: azureOpenAIConfiguration.ChatModelId, endpoint: azureOpenAIConfiguration.Endpoint, - apiKey: azureOpenAIConfiguration.ApiKey, + credentials: new AzureCliCredential(), serviceId: azureOpenAIConfiguration.ServiceId, httpClient: httpClient); diff --git a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextEmbeddingTests.cs b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextEmbeddingTests.cs index 20f9851a5ad7..3e459e6917c5 100644 --- a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextEmbeddingTests.cs +++ b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextEmbeddingTests.cs @@ -1,6 +1,7 @@ // Copyright (c) Microsoft. All rights reserved. using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.SemanticKernel.Connectors.AzureOpenAI; using Microsoft.SemanticKernel.Embeddings; @@ -24,9 +25,9 @@ public async Task AzureOpenAITestAsync(string testInputString) { // Arrange var embeddingGenerator = new AzureOpenAITextEmbeddingGenerationService( - this._azureOpenAIConfiguration.DeploymentName, - this._azureOpenAIConfiguration.Endpoint, - this._azureOpenAIConfiguration.ApiKey); + deploymentName: this._azureOpenAIConfiguration.DeploymentName, + endpoint: this._azureOpenAIConfiguration.Endpoint, + credential: new AzureCliCredential()); // Act var singleResult = await embeddingGenerator.GenerateEmbeddingAsync(testInputString); @@ -46,9 +47,9 @@ public async Task AzureOpenAIWithDimensionsAsync(int? dimensions, int expectedVe const string TestInputString = "test sentence"; var embeddingGenerator = new AzureOpenAITextEmbeddingGenerationService( - "text-embedding-3-large", - this._azureOpenAIConfiguration.Endpoint, - this._azureOpenAIConfiguration.ApiKey, + deploymentName: "text-embedding-3-large", + endpoint: this._azureOpenAIConfiguration.Endpoint, + credential: new AzureCliCredential(), dimensions: dimensions); // Act diff --git a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextToAudioTests.cs b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextToAudioTests.cs index c50ce2478001..881daf5fe3ba 100644 --- a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextToAudioTests.cs +++ b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextToAudioTests.cs @@ -1,6 +1,7 @@ // Copyright (c) Microsoft. All rights reserved. using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.SemanticKernel; using Microsoft.SemanticKernel.TextToAudio; @@ -27,9 +28,9 @@ public async Task AzureOpenAITextToAudioTestAsync() var kernel = Kernel.CreateBuilder() .AddAzureOpenAITextToAudio( - azureOpenAIConfiguration.DeploymentName, - azureOpenAIConfiguration.Endpoint, - azureOpenAIConfiguration.ApiKey) + deploymentName: azureOpenAIConfiguration.DeploymentName, + endpoint: azureOpenAIConfiguration.Endpoint, + credential: new AzureCliCredential()) .Build(); var service = kernel.GetRequiredService(); diff --git a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextToImageTests.cs b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextToImageTests.cs index 1374ed860f2f..4b2b65dd5417 100644 --- a/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextToImageTests.cs +++ b/dotnet/src/IntegrationTests/Connectors/AzureOpenAI/AzureOpenAITextToImageTests.cs @@ -1,6 +1,7 @@ // Copyright (c) Microsoft. All rights reserved. using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.SemanticKernel; using Microsoft.SemanticKernel.TextToImage; @@ -26,7 +27,10 @@ public async Task ItCanReturnImageUrlAsync() Assert.NotNull(configuration); var kernel = Kernel.CreateBuilder() - .AddAzureOpenAITextToImage(configuration.DeploymentName, configuration.Endpoint, configuration.ApiKey) + .AddAzureOpenAITextToImage( + deploymentName: configuration.DeploymentName, + endpoint: configuration.Endpoint, + credentials: new AzureCliCredential()) .Build(); var service = kernel.GetRequiredService(); diff --git a/dotnet/src/IntegrationTests/Planners/Handlebars/HandlebarsPlannerTests.cs b/dotnet/src/IntegrationTests/Planners/Handlebars/HandlebarsPlannerTests.cs index bae2d4b98742..b7859de35937 100644 --- a/dotnet/src/IntegrationTests/Planners/Handlebars/HandlebarsPlannerTests.cs +++ b/dotnet/src/IntegrationTests/Planners/Handlebars/HandlebarsPlannerTests.cs @@ -3,6 +3,7 @@ using System; using System.ComponentModel; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.SemanticKernel; using Microsoft.SemanticKernel.Connectors.OpenAI; @@ -117,7 +118,7 @@ private Kernel InitializeKernel(bool useEmbeddings = false) deploymentName: azureOpenAIConfiguration.ChatDeploymentName!, modelId: azureOpenAIConfiguration.ChatModelId, endpoint: azureOpenAIConfiguration.Endpoint, - apiKey: azureOpenAIConfiguration.ApiKey); + credentials: new AzureCliCredential()); if (useEmbeddings) { @@ -125,7 +126,7 @@ private Kernel InitializeKernel(bool useEmbeddings = false) deploymentName: azureOpenAIEmbeddingsConfiguration.DeploymentName, modelId: azureOpenAIEmbeddingsConfiguration.EmbeddingModelId, endpoint: azureOpenAIEmbeddingsConfiguration.Endpoint, - apiKey: azureOpenAIEmbeddingsConfiguration.ApiKey); + credential: new AzureCliCredential()); } return builder.Build(); diff --git a/dotnet/src/IntegrationTests/PromptTests.cs b/dotnet/src/IntegrationTests/PromptTests.cs index 4649b7b47fcd..4435fa9a0133 100644 --- a/dotnet/src/IntegrationTests/PromptTests.cs +++ b/dotnet/src/IntegrationTests/PromptTests.cs @@ -4,6 +4,7 @@ using System.IO; using System.Reflection; using System.Threading.Tasks; +using Azure.Identity; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; @@ -77,13 +78,12 @@ private void ConfigureAzureOpenAI(IKernelBuilder kernelBuilder) Assert.NotNull(azureOpenAIConfiguration); Assert.NotNull(azureOpenAIConfiguration.ChatDeploymentName); Assert.NotNull(azureOpenAIConfiguration.Endpoint); - Assert.NotNull(azureOpenAIConfiguration.ApiKey); Assert.NotNull(azureOpenAIConfiguration.ServiceId); kernelBuilder.AddAzureOpenAIChatCompletion( deploymentName: azureOpenAIConfiguration.ChatDeploymentName, endpoint: azureOpenAIConfiguration.Endpoint, - apiKey: azureOpenAIConfiguration.ApiKey, + credentials: new AzureCliCredential(), serviceId: azureOpenAIConfiguration.ServiceId); } #endregion diff --git a/dotnet/src/IntegrationTests/README.md b/dotnet/src/IntegrationTests/README.md index 85a997bbea9a..09a04af158e7 100644 --- a/dotnet/src/IntegrationTests/README.md +++ b/dotnet/src/IntegrationTests/README.md @@ -46,27 +46,22 @@ dotnet user-secrets set "AzureOpenAI:ServiceId" "azure-gpt-35-turbo-instruct" dotnet user-secrets set "AzureOpenAI:DeploymentName" "gpt-35-turbo-instruct" dotnet user-secrets set "AzureOpenAI:ChatDeploymentName" "gpt-4" dotnet user-secrets set "AzureOpenAI:Endpoint" "https://contoso.openai.azure.com/" -dotnet user-secrets set "AzureOpenAI:ApiKey" "..." dotnet user-secrets set "AzureOpenAIEmbeddings:ServiceId" "azure-text-embedding-ada-002" dotnet user-secrets set "AzureOpenAIEmbeddings:DeploymentName" "text-embedding-ada-002" dotnet user-secrets set "AzureOpenAIEmbeddings:Endpoint" "https://contoso.openai.azure.com/" -dotnet user-secrets set "AzureOpenAIEmbeddings:ApiKey" "..." dotnet user-secrets set "AzureOpenAIAudioToText:ServiceId" "azure-audio-to-text" dotnet user-secrets set "AzureOpenAIAudioToText:DeploymentName" "whisper-1" dotnet user-secrets set "AzureOpenAIAudioToText:Endpoint" "https://contoso.openai.azure.com/" -dotnet user-secrets set "AzureOpenAIAudioToText:ApiKey" "..." dotnet user-secrets set "AzureOpenAITextToAudio:ServiceId" "azure-text-to-audio" dotnet user-secrets set "AzureOpenAITextToAudio:DeploymentName" "tts-1" dotnet user-secrets set "AzureOpenAITextToAudio:Endpoint" "https://contoso.openai.azure.com/" -dotnet user-secrets set "AzureOpenAITextToAudio:ApiKey" "..." dotnet user-secrets set "AzureOpenAITextToImage:ServiceId" "azure-text-to-image" dotnet user-secrets set "AzureOpenAITextToImage:DeploymentName" "dall-e-3" dotnet user-secrets set "AzureOpenAITextToImage:Endpoint" "https://contoso.openai.azure.com/" -dotnet user-secrets set "AzureOpenAITextToImage:ApiKey" "..." dotnet user-secrets set "MistralAI:ChatModel" "mistral-large-latest" dotnet user-secrets set "MistralAI:EmbeddingModel" "mistral-embed" diff --git a/dotnet/src/IntegrationTests/TestSettings/AzureOpenAIConfiguration.cs b/dotnet/src/IntegrationTests/TestSettings/AzureOpenAIConfiguration.cs index e530110f9322..21e76b25ebdb 100644 --- a/dotnet/src/IntegrationTests/TestSettings/AzureOpenAIConfiguration.cs +++ b/dotnet/src/IntegrationTests/TestSettings/AzureOpenAIConfiguration.cs @@ -6,7 +6,7 @@ namespace SemanticKernel.IntegrationTests.TestSettings; [SuppressMessage("Performance", "CA1812:Internal class that is apparently never instantiated", Justification = "Configuration classes are instantiated through IConfiguration.")] -internal sealed class AzureOpenAIConfiguration(string serviceId, string deploymentName, string endpoint, string apiKey, string? chatDeploymentName = null, string? modelId = null, string? chatModelId = null, string? embeddingModelId = null) +internal sealed class AzureOpenAIConfiguration(string serviceId, string deploymentName, string endpoint, string? apiKey = null, string? chatDeploymentName = null, string? modelId = null, string? chatModelId = null, string? embeddingModelId = null) { public string ServiceId { get; set; } = serviceId; @@ -22,5 +22,5 @@ internal sealed class AzureOpenAIConfiguration(string serviceId, string deployme public string Endpoint { get; set; } = endpoint; - public string ApiKey { get; set; } = apiKey; + public string? ApiKey { get; set; } = apiKey; } diff --git a/dotnet/src/IntegrationTests/testsettings.json b/dotnet/src/IntegrationTests/testsettings.json index 95c4fd2d7f3e..e4bd00c302b6 100644 --- a/dotnet/src/IntegrationTests/testsettings.json +++ b/dotnet/src/IntegrationTests/testsettings.json @@ -11,11 +11,10 @@ "ApiKey": "" }, "AzureOpenAI": { - "ServiceId": "azure-gpt-35-turbo-instruct", + "ServiceId": "azure-gpt", "DeploymentName": "gpt-35-turbo-instruct", "ChatDeploymentName": "gpt-4o", - "Endpoint": "", - "ApiKey": "" + "Endpoint": "" }, "OpenAIEmbeddings": { "ServiceId": "text-embedding-ada-002", @@ -25,8 +24,7 @@ "AzureOpenAIEmbeddings": { "ServiceId": "azure-text-embedding-ada-002", "DeploymentName": "ada-002", - "Endpoint": "", - "ApiKey": "" + "Endpoint": "" }, "OpenAITextToAudio": { "ServiceId": "tts-1", @@ -36,8 +34,7 @@ "AzureOpenAITextToAudio": { "ServiceId": "azure-tts", "DeploymentName": "tts", - "Endpoint": "", - "ApiKey": "" + "Endpoint": "" }, "OpenAIAudioToText": { "ServiceId": "whisper-1", @@ -47,8 +44,7 @@ "AzureOpenAIAudioToText": { "ServiceId": "azure-whisper", "DeploymentName": "whisper", - "Endpoint": "", - "ApiKey": "" + "Endpoint": "" }, "OpenAITextToImage": { "ServiceId": "dall-e-2", @@ -57,9 +53,8 @@ }, "AzureOpenAITextToImage": { "ServiceId": "azure-dalle3", - "DeploymentName": "dall-e-3", - "Endpoint": "", - "ApiKey": "" + "DeploymentName": "Dalle3", + "Endpoint": "" }, "HuggingFace": { "ApiKey": ""