import { describe, expect, it } from
"vitest";
import { isLiveTestEnabled } from
"../../src/agents/live-test-helpers.js";
import {
runRealtimeSttLiveTest,
synthesizeElevenLabsLiveSpeech,
} from
"../../test/helpers/stt-live-audio.js";
import { transcribeDeepgramAudio } from
"./audio.js";
import { buildDeepgramRealtimeTranscriptionProvider } from
"./realtime-transcription-provider.js";
const DEEPGRAM_KEY = process.env.DEEPGRAM_API_KEY ??
"";
const ELEVENLABS_KEY = process.env.ELEVENLABS_API_KEY ??
"";
const DEEPGRAM_MODEL = process.env.DEEPGRAM_MODEL?.trim() ||
"nova-3";
const DEEPGRAM_BASE_URL = process.env.DEEPGRAM_BASE_URL?.trim();
const SAMPLE_URL =
process.env.DEEPGRAM_SAMPLE_URL?.trim() ||
"https://static.deepgram.com/examples/Bueller-Life-moves-pretty-fast.wav";
const LIVE = isLiveTestEnabled([
"DEEPGRAM_LIVE_TEST"]);
const describeLive = LIVE && DEEPGRAM_KEY ? describe : describe.skip;
async
function fetchSampleBuffer(url: string, timeoutMs: number): Promise<Buffer> {
const controller =
new AbortController();
const timer = setTimeout(() => controller.abort(), Math.max(
1, timeoutMs));
try {
const res = await fetch(url, { signal: controller.signal });
if (!res.ok) {
throw new Error(`Sample download failed (HTTP ${res.status})`);
}
const data = await res.arrayBuffer();
return Buffer.from(data);
}
finally {
clearTimeout(timer);
}
}
describeLive(
"deepgram live", () => {
it(
"transcribes sample audio", async () => {
const buffer = await fetchSampleBuffer(SAMPLE_URL,
15000);
const result = await transcribeDeepgramAudio({
buffer,
fileName:
"sample.wav",
mime:
"audio/wav",
apiKey: DEEPGRAM_KEY,
model: DEEPGRAM_MODEL,
baseUrl: DEEPGRAM_BASE_URL,
timeoutMs:
20000,
});
expect(result.text.trim().length).toBeGreaterThan(
0);
},
30000);
it(
"streams realtime STT through the registered transcription provider", async () => {
if (!ELEVENLABS_KEY) {
throw new Error(
"ELEVENLABS_API_KEY required to synthesize live realtime STT input");
}
const provider = buildDeepgramRealtimeTranscriptionProvider();
const phrase =
"Testing OpenClaw Deepgram realtime transcription integration OK.";
const speech = await synthesizeElevenLabsLiveSpeech({
text: phrase,
apiKey: ELEVENLABS_KEY,
outputFormat:
"ulaw_8000",
timeoutMs:
30_
000,
});
await runRealtimeSttLiveTest({
provider,
providerConfig: {
apiKey: DEEPGRAM_KEY,
language:
"en-US",
endpointingMs:
500,
},
audio: Buffer.concat([Buffer.alloc(
4000,
0xff), speech, Buffer.alloc(
8000,
0xff)]),
});
},
90_
000);
});