mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-29 19:49:31 +00:00
Merged via squash.
Prepared head SHA: bd24da3f3b
Co-authored-by: ngutman <1540134+ngutman@users.noreply.github.com>
Co-authored-by: ngutman <1540134+ngutman@users.noreply.github.com>
Reviewed-by: @ngutman
214 lines
7.5 KiB
Swift
214 lines
7.5 KiB
Swift
import Foundation
|
|
import Testing
|
|
@testable import OpenClaw
|
|
|
|
@MainActor
|
|
@Suite struct TalkModeManagerTests {
|
|
@Test func parsesOpenAIRealtimeProviderModelAndVoice() {
|
|
let config: [String: Any] = [
|
|
"talk": [
|
|
"provider": "elevenlabs",
|
|
"providers": [
|
|
"elevenlabs": [
|
|
"modelId": "eleven_v3",
|
|
"voiceId": "eleven-voice",
|
|
],
|
|
],
|
|
"resolved": [
|
|
"provider": "elevenlabs",
|
|
"config": [
|
|
"modelId": "eleven_v3",
|
|
"voiceId": "eleven-voice",
|
|
],
|
|
],
|
|
"realtime": [
|
|
"provider": " openai ",
|
|
"model": " gpt-realtime-2 ",
|
|
"voice": " marin ",
|
|
"mode": "realtime",
|
|
"transport": "gateway-relay",
|
|
"brain": "agent-consult",
|
|
],
|
|
],
|
|
]
|
|
|
|
let parsed = TalkModeGatewayConfigParser.parse(
|
|
config: config,
|
|
defaultProvider: "elevenlabs",
|
|
defaultModelIdFallback: "eleven_v3",
|
|
defaultRealtimeModelIdFallback: "gpt-realtime-2",
|
|
defaultSilenceTimeoutMs: 900)
|
|
|
|
#expect(parsed.activeProvider == "elevenlabs")
|
|
#expect(parsed.executionMode == .realtimeRelay)
|
|
#expect(parsed.defaultModelId == "eleven_v3")
|
|
#expect(parsed.defaultVoiceId == "eleven-voice")
|
|
#expect(parsed.realtimeProvider == "openai")
|
|
#expect(parsed.realtimeModelId == "gpt-realtime-2")
|
|
#expect(parsed.realtimeVoiceId == "marin")
|
|
}
|
|
|
|
@Test func infersRealtimeProviderWhenProviderMapHasSingleEntry() {
|
|
let config: [String: Any] = [
|
|
"talk": [
|
|
"realtime": [
|
|
"mode": "realtime",
|
|
"transport": "webrtc",
|
|
"providers": [
|
|
"openai": [
|
|
"model": "gpt-realtime-2",
|
|
],
|
|
],
|
|
],
|
|
],
|
|
]
|
|
|
|
let parsed = TalkModeGatewayConfigParser.parse(
|
|
config: config,
|
|
defaultProvider: "elevenlabs",
|
|
defaultModelIdFallback: "eleven_v3",
|
|
defaultRealtimeModelIdFallback: "gpt-realtime-2",
|
|
defaultSilenceTimeoutMs: 900)
|
|
|
|
#expect(parsed.executionMode == .realtimeClient)
|
|
#expect(parsed.realtimeProvider == "openai")
|
|
#expect(parsed.realtimeModelId == "gpt-realtime-2")
|
|
}
|
|
|
|
@Test func formatsGenericRealtimeVoiceModeWithoutNativeProviderFallback() {
|
|
let descriptor = TalkVoiceModeDescriptorBuilder.build(
|
|
providerId: "realtime",
|
|
providerLabel: "Realtime Voice",
|
|
modelId: "gpt-realtime-2",
|
|
voiceId: nil,
|
|
transport: "webrtc",
|
|
isRealtime: true)
|
|
|
|
#expect(descriptor.title == "Realtime Voice")
|
|
#expect(descriptor.subtitle == "Native WebRTC • gpt-realtime-2")
|
|
}
|
|
|
|
@Test func defaultsOpenAIRealtimeModelWhenProviderOmitsModel() {
|
|
let config: [String: Any] = [
|
|
"talk": [
|
|
"realtime": [
|
|
"provider": "openai",
|
|
"mode": "realtime",
|
|
"transport": "gateway-relay",
|
|
],
|
|
],
|
|
]
|
|
|
|
let parsed = TalkModeGatewayConfigParser.parse(
|
|
config: config,
|
|
defaultProvider: "elevenlabs",
|
|
defaultModelIdFallback: "eleven_v3",
|
|
defaultRealtimeModelIdFallback: "gpt-realtime-2",
|
|
defaultSilenceTimeoutMs: 900)
|
|
|
|
#expect(parsed.executionMode == .realtimeRelay)
|
|
#expect(parsed.defaultModelId == "eleven_v3")
|
|
#expect(parsed.realtimeModelId == "gpt-realtime-2")
|
|
#expect(parsed.realtimeVoiceId == nil)
|
|
}
|
|
|
|
@Test func resolvesRealtimeVoicePickerOverrides() {
|
|
#expect(TalkModeRealtimeVoiceSelection.resolvedOverride(nil) == nil)
|
|
#expect(TalkModeRealtimeVoiceSelection.resolvedOverride("") == nil)
|
|
#expect(TalkModeRealtimeVoiceSelection.resolvedOverride(" Cedar ") == "cedar")
|
|
#expect(TalkModeRealtimeVoiceSelection.resolvedOverride("unknown") == nil)
|
|
}
|
|
|
|
@Test func formatsOpenAIRealtimeVoiceMode() {
|
|
let descriptor = TalkVoiceModeDescriptorBuilder.build(
|
|
providerId: "openai",
|
|
providerLabel: "OpenAI",
|
|
modelId: "gpt-realtime-2",
|
|
voiceId: "marin",
|
|
transport: "webrtc",
|
|
isRealtime: true)
|
|
|
|
#expect(descriptor.title == "GPT Realtime 2.0")
|
|
#expect(descriptor.subtitle == "Native WebRTC • Marin")
|
|
#expect(descriptor.accessibilityValue == "GPT Realtime 2.0, Native WebRTC • Marin")
|
|
}
|
|
|
|
@Test func formatsGatewayRelayRealtimeVoiceMode() {
|
|
let descriptor = TalkVoiceModeDescriptorBuilder.build(
|
|
providerId: "google",
|
|
providerLabel: "Google Live Voice",
|
|
modelId: "gemini-live-2.5-flash-preview",
|
|
voiceId: nil,
|
|
transport: "gateway-relay",
|
|
isRealtime: true)
|
|
|
|
#expect(descriptor.title == "Google Live Voice")
|
|
#expect(descriptor.subtitle == "Gateway Relay • gemini-live-2.5-flash-preview")
|
|
}
|
|
|
|
@Test func formatsElevenLabsVoiceMode() {
|
|
let descriptor = TalkVoiceModeDescriptorBuilder.build(
|
|
providerId: "elevenlabs",
|
|
providerLabel: "ElevenLabs",
|
|
modelId: "eleven_v3",
|
|
voiceId: "voice-id",
|
|
transport: "native",
|
|
isRealtime: false)
|
|
|
|
#expect(descriptor.title == "ElevenLabs")
|
|
#expect(descriptor.subtitle == "Native • eleven_v3 • voice-id")
|
|
}
|
|
|
|
@Test func formatsSystemVoiceFallbackMode() {
|
|
let descriptor = TalkVoiceModeDescriptorBuilder.build(
|
|
providerId: "system",
|
|
providerLabel: "iOS System Voice",
|
|
modelId: nil,
|
|
voiceId: "en-US",
|
|
transport: "native",
|
|
isRealtime: false)
|
|
|
|
#expect(descriptor.title == "iOS System Voice")
|
|
#expect(descriptor.subtitle == "Native • en-US")
|
|
}
|
|
|
|
@Test func usesRealtimeClientModeForWebRTCTransport() {
|
|
let config: [String: Any] = [
|
|
"talk": [
|
|
"realtime": [
|
|
"provider": "openai",
|
|
"mode": "realtime",
|
|
"transport": "webrtc",
|
|
],
|
|
],
|
|
]
|
|
|
|
let parsed = TalkModeGatewayConfigParser.parse(
|
|
config: config,
|
|
defaultProvider: "elevenlabs",
|
|
defaultModelIdFallback: "eleven_v3",
|
|
defaultRealtimeModelIdFallback: "gpt-realtime-2",
|
|
defaultSilenceTimeoutMs: 900)
|
|
|
|
#expect(parsed.executionMode == .realtimeClient)
|
|
}
|
|
|
|
@Test func detectsPCMFormatRejectionFromElevenLabsError() {
|
|
let error = NSError(
|
|
domain: "ElevenLabsTTS",
|
|
code: 403,
|
|
userInfo: [
|
|
NSLocalizedDescriptionKey: "ElevenLabs failed: 403 subscription_required output_format=pcm_44100",
|
|
])
|
|
#expect(TalkModeManager._test_isPCMFormatRejectedByAPI(error))
|
|
}
|
|
|
|
@Test func ignoresGenericPlaybackFailuresForPCMFormatRejection() {
|
|
let error = NSError(
|
|
domain: "StreamingAudio",
|
|
code: -1,
|
|
userInfo: [NSLocalizedDescriptionKey: "queue enqueue failed"])
|
|
#expect(TalkModeManager._test_isPCMFormatRejectedByAPI(error) == false)
|
|
}
|
|
}
|