mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-06 09:20:43 +00:00
75 lines
2.6 KiB
TypeScript
75 lines
2.6 KiB
TypeScript
import {
|
|
runRealtimeSttLiveTest,
|
|
synthesizeElevenLabsLiveSpeech,
|
|
} from "openclaw/plugin-sdk/provider-test-contracts";
|
|
import { isLiveTestEnabled } from "openclaw/plugin-sdk/test-env";
|
|
import { describe, expect, it } from "vitest";
|
|
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);
|
|
});
|