mirror of
https://github.com/immich-app/immich.git
synced 2025-06-01 20:54:22 -04:00
* feat(web): lighter timeline buckets * GalleryViewer * weird ssr * Remove generics from AssetInteraction * ensure keys on getAssetInfo, alt-text * empty - trigger ci * re-add alt-text * test fix * update tests * tests * missing import * fix: flappy e2e test * lint * revert settings * unneeded cast * fix after merge * missing import * lint * review * lint * avoid abbreviations * review comment - type safety in test * merge conflicts * lint * lint/abbreviations * fix: left-over migration --------- Co-authored-by: Alex <alex.tran1502@gmail.com>
61 lines
1.8 KiB
TypeScript
61 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,
|
|
preAction: () => {},
|
|
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();
|
|
});
|
|
});
|
|
});
|