fixes for STT
This commit is contained in:
@@ -29,4 +29,42 @@ public sealed class FileTurnTelemetrySinkTests
|
||||
|
||||
sink.Verify(s => s.RecordTranscriptError(It.IsAny<Exception>(), It.IsAny<string>(), It.IsAny<CancellationToken>()), Times.Once());
|
||||
}
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task AutoFinalize_DoesNotFallbackImmediately_WhenSttThrows()
|
||||
{
|
||||
var sink = new Mock<ITurnTelemetrySink>();
|
||||
var sttStrategySelector = new Mock<ISttStrategySelector>();
|
||||
sttStrategySelector.Setup(s => s.SelectAsync(It.IsAny<TurnContext>(), It.IsAny<CancellationToken>()))
|
||||
.ThrowsAsync(new InvalidOperationException("ffmpeg failed"));
|
||||
|
||||
var turnService = new WebSocketTurnFinalizationService(
|
||||
new ProtocolToTurnContextMapper(),
|
||||
Mock.Of<IConversationBroker>(),
|
||||
new ResponsePlanToSocketMessagesMapper(),
|
||||
sttStrategySelector.Object,
|
||||
sink.Object
|
||||
);
|
||||
|
||||
var session = new CloudSession();
|
||||
session.TurnState.AwaitingTurnCompletion = true;
|
||||
session.TurnState.SawListen = true;
|
||||
session.TurnState.SawContext = true;
|
||||
session.TurnState.BufferedAudioBytes = 12000;
|
||||
session.TurnState.BufferedAudioChunkCount = 5;
|
||||
session.TurnState.FirstAudioReceivedUtc = DateTimeOffset.UtcNow - TimeSpan.FromSeconds(2);
|
||||
|
||||
var replies = await turnService.HandleContextAsync(
|
||||
session,
|
||||
new WebSocketMessageEnvelope { Text = """{"type":"CONTEXT","data":{"topic":"conversation"}}""" },
|
||||
CancellationToken.None);
|
||||
|
||||
Assert.Single(replies);
|
||||
using var payload = System.Text.Json.JsonDocument.Parse(replies[0].Text!);
|
||||
Assert.Equal("OPENJIBO_TURN_PENDING", payload.RootElement.GetProperty("type").GetString());
|
||||
Assert.Equal(12000, session.TurnState.BufferedAudioBytes);
|
||||
Assert.Equal("ffmpeg failed", session.TurnState.LastSttError);
|
||||
|
||||
sink.Verify(s => s.RecordTranscriptError(It.IsAny<Exception>(), It.IsAny<string>(), It.IsAny<CancellationToken>()), Times.Once());
|
||||
}
|
||||
}
|
||||
|
||||
@@ -135,6 +135,10 @@ public sealed class JiboWebSocketServiceTests
|
||||
Assert.Equal("OPENJIBO_AUDIO_RECEIVED", ReadReplyType(replies[0]));
|
||||
}
|
||||
|
||||
var session = _store.FindSessionByToken("hub-auto-finalize-token");
|
||||
Assert.NotNull(session);
|
||||
session.TurnState.FirstAudioReceivedUtc = DateTimeOffset.UtcNow - TimeSpan.FromSeconds(2);
|
||||
|
||||
replies = await _service.HandleMessageAsync(new WebSocketMessageEnvelope
|
||||
{
|
||||
HostName = "neo-hub.jibo.com",
|
||||
@@ -192,6 +196,10 @@ public sealed class JiboWebSocketServiceTests
|
||||
Assert.Equal("OPENJIBO_AUDIO_RECEIVED", ReadReplyType(replies[0]));
|
||||
}
|
||||
|
||||
var session = _store.FindSessionByToken("hub-auto-fallback-token");
|
||||
Assert.NotNull(session);
|
||||
session.TurnState.FirstAudioReceivedUtc = DateTimeOffset.UtcNow - TimeSpan.FromSeconds(2);
|
||||
|
||||
replies = await _service.HandleMessageAsync(new WebSocketMessageEnvelope
|
||||
{
|
||||
HostName = "neo-hub.jibo.com",
|
||||
|
||||
Reference in New Issue
Block a user