mirror of
https://github.com/ksyasuda/SubMiner.git
synced 2026-03-27 06:12:05 -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.8 KiB
TypeScript
49 lines
1.8 KiB
TypeScript
import assert from 'node:assert/strict';
|
|
import test from 'node:test';
|
|
import { createBuildMpvCommandFromIpcRuntimeMainDepsHandler } from './ipc-mpv-command-main-deps';
|
|
|
|
test('ipc mpv command main deps builder maps callbacks', () => {
|
|
const calls: string[] = [];
|
|
const deps = createBuildMpvCommandFromIpcRuntimeMainDepsHandler({
|
|
triggerSubsyncFromConfig: () => calls.push('subsync'),
|
|
openRuntimeOptionsPalette: () => calls.push('palette'),
|
|
openYoutubeTrackPicker: () => {
|
|
calls.push('youtube-picker');
|
|
},
|
|
cycleRuntimeOption: () => ({ ok: false as const, error: 'x' }),
|
|
showMpvOsd: (text) => calls.push(`osd:${text}`),
|
|
replayCurrentSubtitle: () => calls.push('replay'),
|
|
playNextSubtitle: () => calls.push('next'),
|
|
shiftSubDelayToAdjacentSubtitle: async (direction) => {
|
|
calls.push(`shift:${direction}`);
|
|
},
|
|
sendMpvCommand: (command) => calls.push(`cmd:${command.join(':')}`),
|
|
getMpvClient: () => ({ connected: true, requestProperty: async () => null }),
|
|
isMpvConnected: () => true,
|
|
hasRuntimeOptionsManager: () => false,
|
|
})();
|
|
|
|
deps.triggerSubsyncFromConfig();
|
|
deps.openRuntimeOptionsPalette();
|
|
void deps.openYoutubeTrackPicker();
|
|
assert.deepEqual(deps.cycleRuntimeOption('anki.nPlusOneMatchMode', 1), { ok: false, error: 'x' });
|
|
deps.showMpvOsd('hello');
|
|
deps.replayCurrentSubtitle();
|
|
deps.playNextSubtitle();
|
|
void deps.shiftSubDelayToAdjacentSubtitle('next');
|
|
deps.sendMpvCommand(['show-text', 'ok']);
|
|
assert.equal(typeof deps.getMpvClient()?.requestProperty, 'function');
|
|
assert.equal(deps.isMpvConnected(), true);
|
|
assert.equal(deps.hasRuntimeOptionsManager(), false);
|
|
assert.deepEqual(calls, [
|
|
'subsync',
|
|
'palette',
|
|
'youtube-picker',
|
|
'osd:hello',
|
|
'replay',
|
|
'next',
|
|
'shift:next',
|
|
'cmd:show-text:ok',
|
|
]);
|
|
});
|