mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
0086d38f58
* refactor: Normalize Run/RunStreaming with AIAgent * refactor: Clarify Session vs. Run -level concepts * Rename RunId to SessionId to better match Run/Session terminology in AIAgent * [BREAKING]: Will break existing checkpointed sessions in CosmosDb due to field rename * refactor: Rename and simplify interface around getting typed data out of ExternalRequest/Response * Also adds hints around using value types in PortableValue * refactor: Rename AddFanInEdge to AddFanInBarrierEdge This will prevent a breaking change later when we introduce a programmable FanIn edge, analogous to the FanOut edge's EdgeSelector. The goal, in the long run is to support a number of different FanIn scenarios, with naive FanIn (no barrier) by default, similar to FanOut. * refactor: AsAgent(this Workflow, ...) => AsAIAgent(...) * misc - part1: SwitchBuilder internal --------- Co-authored-by: Dmytro Struk <13853051+dmytrostruk@users.noreply.github.com>
44 lines
1.5 KiB
C#
44 lines
1.5 KiB
C#
// Copyright (c) Microsoft. All rights reserved.
|
|
|
|
using System.Collections.Generic;
|
|
using System.Text.Json;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.Agents.AI.Workflows.Checkpointing;
|
|
|
|
namespace Microsoft.Agents.AI.Workflows.UnitTests;
|
|
|
|
internal sealed class InMemoryJsonStore : JsonCheckpointStore
|
|
{
|
|
private readonly Dictionary<string, SessionCheckpointCache<JsonElement>> _store = [];
|
|
|
|
private SessionCheckpointCache<JsonElement> EnsureSessionStore(string sessionId)
|
|
{
|
|
if (!this._store.TryGetValue(sessionId, out SessionCheckpointCache<JsonElement>? runStore))
|
|
{
|
|
runStore = this._store[sessionId] = new();
|
|
}
|
|
|
|
return runStore;
|
|
}
|
|
|
|
public override ValueTask<CheckpointInfo> CreateCheckpointAsync(string sessionId, JsonElement value, CheckpointInfo? parent = null)
|
|
{
|
|
return new(this.EnsureSessionStore(sessionId).Add(sessionId, value));
|
|
}
|
|
|
|
public override ValueTask<JsonElement> RetrieveCheckpointAsync(string sessionId, CheckpointInfo key)
|
|
{
|
|
if (!this.EnsureSessionStore(sessionId).TryGet(key, out JsonElement result))
|
|
{
|
|
throw new KeyNotFoundException($"Could not retrieve checkpoint with id {key.CheckpointId} for session {sessionId}");
|
|
}
|
|
|
|
return new(result);
|
|
}
|
|
|
|
public override ValueTask<IEnumerable<CheckpointInfo>> RetrieveIndexAsync(string sessionId, CheckpointInfo? withParent = null)
|
|
{
|
|
return new(this.EnsureSessionStore(sessionId).Index);
|
|
}
|
|
}
|