mirror of
https://github.com/ksyasuda/SubMiner.git
synced 2026-04-12 04:19:25 -07:00
* fix: harden preload argv parsing for popup windows * fix: align youtube playback with shared overlay startup * fix: unwrap mpv youtube streams for anki media mining * docs: update docs for youtube subtitle and mining flow * refactor: unify cli and runtime wiring for startup and youtube flow * feat: update subtitle sidebar overlay behavior * chore: add shared log-file source for diagnostics * fix(ci): add changelog fragment for immersion changes * fix: address CodeRabbit review feedback * fix: persist canonical title from youtube metadata * style: format stats library tab * fix: address latest review feedback * style: format stats library files * test: stub launcher youtube deps in CI * test: isolate launcher youtube flow deps * test: stub launcher youtube deps in failing case * test: force x11 backend in launcher ci harness * test: address latest review feedback * fix(launcher): preserve user YouTube ytdl raw options * docs(backlog): update task tracking notes * fix(immersion): special-case youtube media paths in runtime and tracking * feat(stats): improve YouTube media metadata and picker key handling * fix(ci): format stats media library hook * fix: address latest CodeRabbit review items * docs: update youtube release notes and docs * feat: auto-load youtube subtitles before manual picker * fix: restore app-owned youtube subtitle flow * docs: update youtube playback docs and config copy * refactor: remove legacy youtube launcher mode plumbing * fix: refine youtube subtitle startup binding * docs: clarify youtube subtitle startup behavior * fix: address PR #31 latest review follow-ups * fix: address PR #31 follow-up review comments * test: harden youtube picker test harness * udpate backlog * fix: add timeout to youtube metadata probe * docs: refresh youtube and stats docs * update backlog * update backlog * chore: release v0.9.0
49 lines
1.5 KiB
TypeScript
49 lines
1.5 KiB
TypeScript
import test from 'node:test';
|
|
import assert from 'node:assert/strict';
|
|
import {
|
|
createHandleMpvCommandFromIpcHandler,
|
|
createRunSubsyncManualFromIpcHandler,
|
|
} from './ipc-bridge-actions';
|
|
|
|
test('handle mpv command handler forwards command and built deps', () => {
|
|
const calls: string[] = [];
|
|
const deps = {
|
|
triggerSubsyncFromConfig: () => {},
|
|
openRuntimeOptionsPalette: () => {},
|
|
openYoutubeTrackPicker: () => {},
|
|
cycleRuntimeOption: () => ({ ok: false as const, error: 'x' }),
|
|
showMpvOsd: () => {},
|
|
replayCurrentSubtitle: () => {},
|
|
playNextSubtitle: () => {},
|
|
shiftSubDelayToAdjacentSubtitle: async () => {},
|
|
sendMpvCommand: () => {},
|
|
getMpvClient: () => null,
|
|
isMpvConnected: () => true,
|
|
hasRuntimeOptionsManager: () => true,
|
|
};
|
|
const handle = createHandleMpvCommandFromIpcHandler({
|
|
handleMpvCommandFromIpcRuntime: (command, nextDeps) => {
|
|
calls.push(`command:${command.join(':')}`);
|
|
assert.equal(nextDeps, deps);
|
|
},
|
|
buildMpvCommandDeps: () => deps,
|
|
});
|
|
|
|
handle(['show-text', 'hello']);
|
|
assert.deepEqual(calls, ['command:show-text:hello']);
|
|
});
|
|
|
|
test('run subsync manual handler forwards request and result', async () => {
|
|
const calls: string[] = [];
|
|
const run = createRunSubsyncManualFromIpcHandler({
|
|
runManualFromIpc: async (request: { id: string }) => {
|
|
calls.push(`request:${request.id}`);
|
|
return { ok: true as const };
|
|
},
|
|
});
|
|
|
|
const result = await run({ id: 'job-1' });
|
|
assert.deepEqual(result, { ok: true });
|
|
assert.deepEqual(calls, ['request:job-1']);
|
|
});
|