mirror of
https://github.com/immich-app/immich.git
synced 2025-01-07 00:50:23 -05:00
64636c0618
* duplicate detection job, entity, config * queueing * job panel, update api * use embedding in db instead of fetching * disable concurrency * only queue visible assets * handle multiple duplicateIds * update concurrent queue check * add provider * add web placeholder, server endpoint, migration, various fixes * update sql * select embedding by default * rename variable * simplify * remove separate entity, handle re-running with different threshold, set default back to 0.02 * fix tests * add tests * add index to entity * formatting * update asset mock * fix `upsertJobStatus` signature * update sql * formatting * default to 0.03 * optimize clustering * use asset's `duplicateId` if present * update sql * update tests * expose admin setting * refactor * formatting * skip if ml is disabled * debug trash e2e * remove from web * remove from sidebar * test if ml is disabled * update sql * separate duplicate detection from clip in config, disable by default for now * fix doc * lower minimum `maxDistance` * update api * Add and Use Duplicate Detection Feature Flag (#9364) * Add Duplicate Detection Flag * Use Duplicate Detection Flag * Attempt Fixes for Failing Checks * lower minimum `maxDistance` * fix tests --------- Co-authored-by: mertalev <101130780+mertalev@users.noreply.github.com> * chore: fixes and additions after rebase * chore: update api (remove new Role enum) * fix: left join smart search so getAll works without machine learning * test: trash e2e go back to checking length of assets is zero * chore: regen api after rebase * test: fix tests after rebase * redundant join --------- Co-authored-by: Nicholas Flamy <30300649+NicholasFlamy@users.noreply.github.com> Co-authored-by: Zack Pollard <zackpollard@ymail.com> Co-authored-by: Zack Pollard <zack@futo.org>
44 lines
1.5 KiB
TypeScript
44 lines
1.5 KiB
TypeScript
import { IAssetRepository } from 'src/interfaces/asset.interface';
|
|
import { Mocked, vitest } from 'vitest';
|
|
|
|
export const newAssetRepositoryMock = (): Mocked<IAssetRepository> => {
|
|
return {
|
|
create: vitest.fn(),
|
|
upsertExif: vitest.fn(),
|
|
upsertJobStatus: vitest.fn(),
|
|
getByDayOfYear: vitest.fn(),
|
|
getByIds: vitest.fn().mockResolvedValue([]),
|
|
getByIdsWithAllRelations: vitest.fn().mockResolvedValue([]),
|
|
getByAlbumId: vitest.fn(),
|
|
getByUserId: vitest.fn(),
|
|
getById: vitest.fn(),
|
|
getWithout: vitest.fn(),
|
|
getByChecksum: vitest.fn(),
|
|
getUploadAssetIdByChecksum: vitest.fn(),
|
|
getWith: vitest.fn(),
|
|
getRandom: vitest.fn(),
|
|
getFirstAssetForAlbumId: vitest.fn(),
|
|
getLastUpdatedAssetForAlbumId: vitest.fn(),
|
|
getAll: vitest.fn().mockResolvedValue({ items: [], hasNextPage: false }),
|
|
getAllByDeviceId: vitest.fn(),
|
|
updateAll: vitest.fn(),
|
|
updateDuplicates: vitest.fn(),
|
|
getExternalLibraryAssetPaths: vitest.fn(),
|
|
getByLibraryIdAndOriginalPath: vitest.fn(),
|
|
deleteAll: vitest.fn(),
|
|
update: vitest.fn(),
|
|
remove: vitest.fn(),
|
|
findLivePhotoMatch: vitest.fn(),
|
|
getMapMarkers: vitest.fn(),
|
|
getStatistics: vitest.fn(),
|
|
getTimeBucket: vitest.fn(),
|
|
getTimeBuckets: vitest.fn(),
|
|
restoreAll: vitest.fn(),
|
|
softDeleteAll: vitest.fn(),
|
|
getAssetIdByCity: vitest.fn(),
|
|
getAssetIdByTag: vitest.fn(),
|
|
getAllForUserFullSync: vitest.fn(),
|
|
getChangedDeltaSync: vitest.fn(),
|
|
getDuplicates: vitest.fn(),
|
|
};
|
|
};
|