mirror of
https://github.com/immich-app/immich.git
synced 2025-06-05 06:35:07 -04:00
chore: svelte 5 Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com> Co-authored-by: Ben McCann <322311+benmccann@users.noreply.github.com>
60 lines
1.8 KiB
TypeScript
60 lines
1.8 KiB
TypeScript
import { resetSavedUser, user as userStore } from '$lib/stores/user.store';
|
|
import { assetFactory } from '@test-data/factories/asset-factory';
|
|
import { userAdminFactory } from '@test-data/factories/user-factory';
|
|
import '@testing-library/jest-dom';
|
|
import { render } from '@testing-library/svelte';
|
|
import AssetViewerNavBar from './asset-viewer-nav-bar.svelte';
|
|
|
|
describe('AssetViewerNavBar component', () => {
|
|
const additionalProps = {
|
|
showCopyButton: false,
|
|
showZoomButton: false,
|
|
showDetailButton: false,
|
|
showDownloadButton: false,
|
|
showMotionPlayButton: false,
|
|
showShareButton: false,
|
|
onZoomImage: () => {},
|
|
onCopyImage: () => {},
|
|
onAction: () => {},
|
|
onRunJob: () => {},
|
|
onPlaySlideshow: () => {},
|
|
onShowDetail: () => {},
|
|
onClose: () => {},
|
|
};
|
|
|
|
beforeAll(() => {
|
|
Element.prototype.animate = vi.fn().mockImplementation(() => ({
|
|
cancel: () => {},
|
|
}));
|
|
vi.stubGlobal(
|
|
'ResizeObserver',
|
|
vi.fn(() => ({ observe: vi.fn(), unobserve: vi.fn(), disconnect: vi.fn() })),
|
|
);
|
|
});
|
|
|
|
afterEach(() => {
|
|
resetSavedUser();
|
|
});
|
|
|
|
afterAll(() => {
|
|
vi.restoreAllMocks();
|
|
});
|
|
|
|
it('shows back button', () => {
|
|
const asset = assetFactory.build({ isTrashed: false });
|
|
const { getByTitle } = render(AssetViewerNavBar, { asset, ...additionalProps });
|
|
expect(getByTitle('go_back')).toBeInTheDocument();
|
|
});
|
|
|
|
describe('if the current user owns the asset', () => {
|
|
it('shows delete button', () => {
|
|
const ownerId = 'id-of-the-user';
|
|
const user = userAdminFactory.build({ id: ownerId });
|
|
const asset = assetFactory.build({ ownerId, isTrashed: false });
|
|
userStore.set(user);
|
|
const { getByTitle } = render(AssetViewerNavBar, { asset, ...additionalProps });
|
|
expect(getByTitle('delete')).toBeInTheDocument();
|
|
});
|
|
});
|
|
});
|