Skip to main content
Glama

Azure MCP Server

Official
MIT License
1,161
  • Linux
  • Apple
TableSchemaCommandTests.cs6.2 kB
// Copyright (c) Microsoft Corporation. // Licensed under the MIT License. using System.CommandLine.Parsing; using System.Text.Json.Serialization; using AzureMcp.Core.Models; using AzureMcp.Core.Models.Command; using AzureMcp.Core.Options; using AzureMcp.Kusto.Commands; using AzureMcp.Kusto.Services; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; using NSubstitute; using NSubstitute.ExceptionExtensions; using Xunit; namespace AzureMcp.Kusto.UnitTests; public sealed class TableSchemaCommandTests { private readonly IServiceProvider _serviceProvider; private readonly IKustoService _kusto; private readonly ILogger<TableSchemaCommand> _logger; public TableSchemaCommandTests() { _kusto = Substitute.For<IKustoService>(); _logger = Substitute.For<ILogger<TableSchemaCommand>>(); var collection = new ServiceCollection(); collection.AddSingleton(_kusto); _serviceProvider = collection.BuildServiceProvider(); } public static IEnumerable<object[]> TableSchemaArgumentMatrix() { yield return new object[] { "--subscription sub1 --cluster mycluster --database db1 --table table1", false }; yield return new object[] { "--cluster-uri https://mycluster.kusto.windows.net --database db1 --table table1", true }; } [Theory] [MemberData(nameof(TableSchemaArgumentMatrix))] public async Task ExecuteAsync_ReturnsSchema(string cliArgs, bool useClusterUri) { var expectedSchema = "col1:datetime,col2:string"; if (useClusterUri) { _kusto.GetTableSchema( "https://mycluster.kusto.windows.net", "db1", "table1", Arg.Any<string>(), Arg.Any<AuthMethod?>(), Arg.Any<RetryPolicyOptions>()) .Returns(expectedSchema); } else { _kusto.GetTableSchema( "sub1", "mycluster", "db1", "table1", Arg.Any<string>(), Arg.Any<AuthMethod?>(), Arg.Any<RetryPolicyOptions>()) .Returns(expectedSchema); } var command = new TableSchemaCommand(_logger); var parser = new Parser(command.GetCommand()); var args = parser.Parse(cliArgs); var context = new CommandContext(_serviceProvider); var response = await command.ExecuteAsync(context, args); Assert.NotNull(response); Assert.NotNull(response.Results); var json = System.Text.Json.JsonSerializer.Serialize(response.Results); var result = System.Text.Json.JsonSerializer.Deserialize<TableSchemaResult>(json); Assert.NotNull(result); Assert.NotNull(result.Schema); Assert.Equal(expectedSchema, result.Schema); } [Theory] [MemberData(nameof(TableSchemaArgumentMatrix))] public async Task ExecuteAsync_ReturnsNull_WhenNoSchema(string cliArgs, bool useClusterUri) { // Arrange var expectedError = "Test error. To mitigate this issue, please refer to the troubleshooting guidelines here at https://aka.ms/azmcp/troubleshooting."; if (useClusterUri) { _kusto.GetTableSchema( "https://mycluster.kusto.windows.net", "db1", "table1", Arg.Any<string>(), Arg.Any<AuthMethod?>(), Arg.Any<RetryPolicyOptions>()) .ThrowsAsync(new Exception("Test error")); } else { _kusto.GetTableSchema( "sub1", "mycluster", "db1", "table1", Arg.Any<string>(), Arg.Any<AuthMethod?>(), Arg.Any<RetryPolicyOptions>()) .ThrowsAsync(new Exception("Test error")); } var command = new TableSchemaCommand(_logger); var parser = new Parser(command.GetCommand()); var args = parser.Parse(cliArgs); var context = new CommandContext(_serviceProvider); var response = await command.ExecuteAsync(context, args); // Assert Assert.NotNull(response); Assert.Equal(500, response.Status); Assert.Equal(expectedError, response.Message); } [Theory] [MemberData(nameof(TableSchemaArgumentMatrix))] public async Task ExecuteAsync_HandlesException_AndSetsException(string cliArgs, bool useClusterUri) { var expectedError = "Test error. To mitigate this issue, please refer to the troubleshooting guidelines here at https://aka.ms/azmcp/troubleshooting."; if (useClusterUri) { _kusto.GetTableSchema( "https://mycluster.kusto.windows.net", "db1", "table1", Arg.Any<string>(), Arg.Any<AuthMethod?>(), Arg.Any<RetryPolicyOptions>()) .Returns(Task.FromException<string>(new Exception("Test error"))); } else { _kusto.GetTableSchema( "sub1", "mycluster", "db1", "table1", Arg.Any<string>(), Arg.Any<AuthMethod?>(), Arg.Any<RetryPolicyOptions>()) .Returns(Task.FromException<string>(new Exception("Test error"))); } var command = new TableSchemaCommand(_logger); var parser = new Parser(command.GetCommand()); var args = parser.Parse(cliArgs); var context = new CommandContext(_serviceProvider); var response = await command.ExecuteAsync(context, args); Assert.NotNull(response); Assert.Equal(500, response.Status); Assert.Equal(expectedError, response.Message); } [Fact] public async Task ExecuteAsync_ReturnsBadRequest_WhenMissingRequiredOptions() { var command = new TableSchemaCommand(_logger); var parser = new Parser(command.GetCommand()); var args = parser.Parse(""); var context = new CommandContext(_serviceProvider); var response = await command.ExecuteAsync(context, args); Assert.NotNull(response); Assert.Equal(400, response.Status); } private sealed class TableSchemaResult { [JsonPropertyName("schema")] public string Schema { get; set; } = string.Empty; } }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Azure/azure-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server