mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
731e3a7633
* Initial plan * Add test classes for extension methods Co-authored-by: crickman <66376200+crickman@users.noreply.github.com> * Fix test issues and document bug in ExpandoObjectExtensions Co-authored-by: crickman <66376200+crickman@users.noreply.github.com> * Address code review feedback - shorten Skip messages and add explanatory comments Co-authored-by: crickman <66376200+crickman@users.noreply.github.com> * Replace Fields.ToDictionary with GetField calls and fix ExpandoObjectExtensions bug Co-authored-by: crickman <66376200+crickman@users.noreply.github.com> * Update dotnet/tests/Microsoft.Agents.AI.Workflows.Declarative.UnitTests/Extensions/DataValueExtensionsTests.cs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update dotnet/tests/Microsoft.Agents.AI.Workflows.Declarative.UnitTests/Extensions/DataValueExtensionsTests.cs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Remove unused using statement from DialogBaseExtensionsTests Co-authored-by: crickman <66376200+crickman@users.noreply.github.com> * Add proper WrapWithBot tests using AdaptiveDialog and OnActivity Co-authored-by: crickman <66376200+crickman@users.noreply.github.com> * Cleanup * Better * Better * One more test * Checkpoint * Checkpoint * Finally --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
142 lines
4.2 KiB
C#
142 lines
4.2 KiB
C#
// Copyright (c) Microsoft. All rights reserved.
|
|
|
|
using System.Threading.Tasks;
|
|
using Microsoft.Agents.AI.Workflows.Declarative.ObjectModel;
|
|
using Microsoft.Bot.ObjectModel;
|
|
using Microsoft.PowerFx.Types;
|
|
using Xunit.Abstractions;
|
|
|
|
namespace Microsoft.Agents.AI.Workflows.Declarative.UnitTests.ObjectModel;
|
|
|
|
/// <summary>
|
|
/// Tests for <see cref="ParseValueExecutor"/>.
|
|
/// </summary>
|
|
public sealed class ParseValueExecutorTest(ITestOutputHelper output) : WorkflowActionExecutorTest(output)
|
|
{
|
|
[Fact]
|
|
public async Task ParseRecordAsync()
|
|
{
|
|
// Arrange
|
|
RecordDataType.Builder recordBuilder =
|
|
new()
|
|
{
|
|
Properties =
|
|
{
|
|
{"key1", new PropertyInfo.Builder() { Type = DataType.String } },
|
|
}
|
|
};
|
|
ParseValue model =
|
|
this.CreateModel(
|
|
this.FormatDisplayName(nameof(ParseRecordAsync)),
|
|
recordBuilder,
|
|
@"{ ""key1"": ""val1"" }");
|
|
|
|
// Act
|
|
ParseValueExecutor action = new(model, this.State);
|
|
await this.ExecuteAsync(action);
|
|
|
|
// Assert
|
|
VerifyModel(model, action);
|
|
this.VerifyState("Target", FormulaValue.NewRecordFromFields(new NamedValue("key1", FormulaValue.New("val1"))));
|
|
}
|
|
|
|
[Fact]
|
|
public async Task ParseTableAsync()
|
|
{
|
|
// Arrange
|
|
RecordDataType.Builder recordBuilder =
|
|
new()
|
|
{
|
|
Properties =
|
|
{
|
|
{"key1", new PropertyInfo.Builder() { Type = DataType.String } },
|
|
}
|
|
};
|
|
ParseValue model =
|
|
this.CreateModel(
|
|
this.FormatDisplayName(nameof(ParseTableAsync)),
|
|
DataType.EmptyTable,
|
|
@"[""apple"",""banana"",""cat""]");
|
|
|
|
// Act
|
|
ParseValueExecutor action = new(model, this.State);
|
|
await this.ExecuteAsync(action);
|
|
|
|
// Assert
|
|
VerifyModel(model, action);
|
|
this.VerifyState("Target", FormulaValue.NewSingleColumnTable(FormulaValue.New("apple"), FormulaValue.New("banana"), FormulaValue.New("cat")));
|
|
}
|
|
|
|
[Fact]
|
|
public async Task ParseBooleanAsync()
|
|
{
|
|
// Arrange
|
|
ParseValue model =
|
|
this.CreateModel(
|
|
this.FormatDisplayName(nameof(ParseTableAsync)),
|
|
new BooleanDataType.Builder(),
|
|
"True");
|
|
|
|
// Act
|
|
ParseValueExecutor action = new(model, this.State);
|
|
await this.ExecuteAsync(action);
|
|
|
|
// Assert
|
|
VerifyModel(model, action);
|
|
this.VerifyState("Target", FormulaValue.New(true));
|
|
}
|
|
|
|
[Fact]
|
|
public async Task ParseNumberAsync()
|
|
{
|
|
// Arrange
|
|
ParseValue model =
|
|
this.CreateModel(
|
|
this.FormatDisplayName(nameof(ParseNumberAsync)),
|
|
new NumberDataType.Builder(),
|
|
"42");
|
|
|
|
// Act
|
|
ParseValueExecutor action = new(model, this.State);
|
|
await this.ExecuteAsync(action);
|
|
|
|
// Assert
|
|
VerifyModel(model, action);
|
|
this.VerifyState("Target", FormulaValue.New(42));
|
|
}
|
|
|
|
[Fact]
|
|
public async Task ParseStringAsync()
|
|
{
|
|
// Arrange
|
|
ParseValue model =
|
|
this.CreateModel(
|
|
this.FormatDisplayName(nameof(ParseStringAsync)),
|
|
new StringDataType.Builder(),
|
|
"Hello, World!");
|
|
|
|
// Act
|
|
ParseValueExecutor action = new(model, this.State);
|
|
await this.ExecuteAsync(action);
|
|
|
|
// Assert
|
|
VerifyModel(model, action);
|
|
this.VerifyState("Target", FormulaValue.New("Hello, World!"));
|
|
}
|
|
|
|
private ParseValue CreateModel(string displayName, DataType.Builder typeBuilder, string sourceText)
|
|
{
|
|
ParseValue.Builder actionBuilder =
|
|
new()
|
|
{
|
|
Id = this.CreateActionId(),
|
|
DisplayName = this.FormatDisplayName(displayName),
|
|
ValueType = typeBuilder,
|
|
Variable = PropertyPath.TopicVariable("Target"),
|
|
Value = new ValueExpression.Builder(ValueExpression.Literal(StringDataValue.Create(sourceText))),
|
|
};
|
|
|
|
return AssignParent<ParseValue>(actionBuilder);
|
|
}
|
|
}
|