mirror of
https://github.com/immich-app/immich.git
synced 2025-12-26 23:00:38 -05:00
* feat: plugins * feat: table definition * feat: type and migration * feat: add repositories * feat: validate manifest with class-validator and load manifest info to database * feat: workflow/plugin controller/service layer * feat: implement workflow logic * feat: make trigger static * feat: dynamical instantiate plugin instances * fix: access control and helper script * feat: it works * chore: simplify * refactor: refactor and use queue for workflow execution * refactor: remove unsused property in plugin-schema * build wasm in prod * feat: plugin loader in transaction * fix: docker build arm64 * generated files * shell check * fix tests * fix: waiting for migration to finish before loading plugin * remove context reassignment * feat: use mise to manage extism tools (#23760) * pr feedback * refactor: create workflow now including create filters and actions * feat: workflow medium tests * fix: broken medium test * feat: medium tests * chore: unify workflow job * sign user id with jwt * chore: query plugin with filters and action * chore: read manifest in repository * chore: load manifest from server configs * merge main * feat: endpoint documentation * pr feedback * load plugin from absolute path * refactor:handle trigger * throw error and return early * pr feedback * unify plugin services * fix: plugins code * clean up * remove triggerConfig * clean up * displayName and methodName --------- Co-authored-by: Jason Rasmussen <jason@rasm.me> Co-authored-by: bo0tzz <git@bo0tzz.me>
75 lines
2.2 KiB
TypeScript
75 lines
2.2 KiB
TypeScript
import { ChokidarOptions } from 'chokidar';
|
|
import { StorageCore } from 'src/cores/storage.core';
|
|
import { StorageRepository, WatchEvents } from 'src/repositories/storage.repository';
|
|
import { RepositoryInterface } from 'src/types';
|
|
import { Mocked, vitest } from 'vitest';
|
|
|
|
interface MockWatcherOptions {
|
|
items?: Array<{ event: 'change' | 'add' | 'unlink' | 'error'; value: string }>;
|
|
close?: () => Promise<void>;
|
|
}
|
|
|
|
export const makeMockWatcher =
|
|
({ items, close }: MockWatcherOptions) =>
|
|
(paths: string[], options: ChokidarOptions, events: Partial<WatchEvents>) => {
|
|
events.onReady?.();
|
|
for (const item of items || []) {
|
|
switch (item.event) {
|
|
case 'add': {
|
|
events.onAdd?.(item.value);
|
|
break;
|
|
}
|
|
case 'change': {
|
|
events.onChange?.(item.value);
|
|
break;
|
|
}
|
|
case 'unlink': {
|
|
events.onUnlink?.(item.value);
|
|
break;
|
|
}
|
|
case 'error': {
|
|
events.onError?.(new Error(item.value));
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (close) {
|
|
return () => close();
|
|
}
|
|
|
|
return () => Promise.resolve();
|
|
};
|
|
|
|
export const newStorageRepositoryMock = (): Mocked<RepositoryInterface<StorageRepository>> => {
|
|
StorageCore.reset();
|
|
StorageCore.setMediaLocation('/data');
|
|
|
|
return {
|
|
createZipStream: vitest.fn(),
|
|
createReadStream: vitest.fn(),
|
|
readFile: vitest.fn(),
|
|
readTextFile: vitest.fn(),
|
|
createFile: vitest.fn(),
|
|
createWriteStream: vitest.fn(),
|
|
createOrOverwriteFile: vitest.fn(),
|
|
existsSync: vitest.fn(),
|
|
overwriteFile: vitest.fn(),
|
|
unlink: vitest.fn(),
|
|
unlinkDir: vitest.fn().mockResolvedValue(true),
|
|
removeEmptyDirs: vitest.fn(),
|
|
checkFileExists: vitest.fn(),
|
|
mkdirSync: vitest.fn(),
|
|
checkDiskUsage: vitest.fn(),
|
|
readdir: vitest.fn(),
|
|
realpath: vitest.fn().mockImplementation((filepath: string) => Promise.resolve(filepath)),
|
|
stat: vitest.fn(),
|
|
crawl: vitest.fn(),
|
|
walk: vitest.fn().mockImplementation(async function* () {}),
|
|
rename: vitest.fn(),
|
|
copyFile: vitest.fn(),
|
|
utimes: vitest.fn(),
|
|
watch: vitest.fn().mockImplementation(makeMockWatcher({})),
|
|
};
|
|
};
|