mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
77404d165c
* Notes * Readme typo * Update readme * Checkpoint * Namespace fix * Fix ID and namespace * Checkpoint * Verified * Comments * Isolate "Kit" * Address note: static * Checkpoint * Checkpoint "Executor<>" * Prefix and internal executors * Test passing * Cleanup * Rename "session" concept * Revert workflow debug * Fix template base / pragma * Tune system scope * Update dotnet/src/Microsoft.Agents.Workflows.Declarative/CodeGen/ResetVariableTemplate.tt Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Fix empty template * Add validation for codegen ut * Fix test * Codegen baselines * Constant * Prep * Mark TODO * Fix * Namespace * One more * Update baselines * Checkpoint * Checkpoint * Checkpoint * fme * Checkpoint * Another step * Fixed up * Roslyn * Fix * More cleaning * Async * Fix * Enum checkpoint * Refine enum * Checkpoint * Sync templates * Checkpoint * Streamline * Pre-merge analyzer updates * Foreach * Placeholders * Checkpoint * Clean-up * Sample path resolution * Checkpoint * Checkpoint - Workflow Code Building * Validation * Test cleanup * Update test basline * Update test baseline * Fix DefaultTemplate usage * Validation checkpoint * Fix break/continue edges * Verify generated code builds * Fix merge * Fix build validation * Update template handling of literal string values. * Test for metadata case * Update baselines * Fix merge * Checkpoint * Checkpoint: Conditions * Invoke Agent Checkpoint * Namespace * Address code-analysis issues * Cross platform test support * Invoke agent checkpoint * Clean sample * Checkpoint: Agent Invoke Input Messages * Checkpoint - Passing * Checkpoint * Regenerate all template + port conversation fix * Checkpoint: Tests good * Fix test for unbuntu * Fix build command * Checkpoint - E2E * Test fix * Update integration tests * Fix merge * Update * Checkpoint !!! * Baby steps * Checkpoint * Checkpoint E2E !!! * So close... * Integrate test validation * Fix merge * Rebase tests * Namespace * Namespace * Test cleanup * Sample comment cleanup * Checkpoint: List conversion * Include these * CheckPoint: ParseValue * Namespace * Fix sampel * More namspace * Comments * Test updates * Test fix * Better build * Shared code * Sort solution * Fix build * Prune solution * One more * Conversion matrix * Final table conversion --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
72 lines
2.3 KiB
C#
72 lines
2.3 KiB
C#
// Copyright (c) Microsoft. All rights reserved.
|
|
|
|
using Microsoft.Agents.AI.Workflows.Declarative.Interpreter;
|
|
using Xunit.Abstractions;
|
|
|
|
namespace Microsoft.Agents.AI.Workflows.Declarative.UnitTests.Interpreter;
|
|
|
|
/// <summary>
|
|
/// Tests execution of workflow created by <see cref="WorkflowModel{TCondition}"/>.
|
|
/// </summary>
|
|
public sealed class DeclarativeWorkflowModelTest(ITestOutputHelper output) : WorkflowTest(output)
|
|
{
|
|
[Fact]
|
|
public void GetDepthForDefault()
|
|
{
|
|
WorkflowModel<string> model = new(new TestExecutor("root"));
|
|
Assert.Equal(0, model.GetDepth(null));
|
|
}
|
|
|
|
[Fact]
|
|
public void GetDepthForMissingNode()
|
|
{
|
|
WorkflowModel<string> model = new(new TestExecutor("root"));
|
|
Assert.Throws<DeclarativeModelException>(() => model.GetDepth("missing"));
|
|
}
|
|
|
|
[Fact]
|
|
public void ConnectMissingNode()
|
|
{
|
|
TestExecutor rootExecutor = new("root");
|
|
WorkflowModel<string> model = new(rootExecutor);
|
|
model.AddLink("root", "missing");
|
|
TestWorkflowBuilder modelBuilder = new();
|
|
Assert.Throws<DeclarativeModelException>(() => model.Build(modelBuilder));
|
|
}
|
|
|
|
[Fact]
|
|
public void AddToMissingParent()
|
|
{
|
|
WorkflowModel<string> model = new(new TestExecutor("root"));
|
|
Assert.Throws<DeclarativeModelException>(() => model.AddNode(new TestExecutor("next"), "missing"));
|
|
}
|
|
|
|
[Fact]
|
|
public void LinkFromMissingSource()
|
|
{
|
|
WorkflowModel<string> model = new(new TestExecutor("root"));
|
|
Assert.Throws<DeclarativeModelException>(() => model.AddLink("missing", "anything"));
|
|
}
|
|
|
|
[Fact]
|
|
public void LocateMissingParent()
|
|
{
|
|
WorkflowModel<string> model = new(new TestExecutor("root"));
|
|
Assert.Null(model.LocateParent<TestExecutor>(null));
|
|
Assert.Throws<DeclarativeModelException>(() => model.LocateParent<TestExecutor>("missing"));
|
|
}
|
|
|
|
internal sealed class TestExecutor(string actionId) : IModeledAction
|
|
{
|
|
public string Id { get; } = actionId;
|
|
}
|
|
|
|
internal sealed class TestWorkflowBuilder : IModelBuilder<string>
|
|
{
|
|
public void Connect(IModeledAction source, IModeledAction target, string? condition = null)
|
|
{
|
|
Assert.Fail(); // Not expected to be called in this test.
|
|
}
|
|
}
|
|
}
|