mirror of
https://github.com/immich-app/immich.git
synced 2025-01-16 16:56:46 +01:00
fix(web): use fallback image if shared asset isn't resized (#11704)
* fix(web): use fallback image if shared asset isn't resized * remove test-data index file
This commit is contained in:
parent
9ed04588b8
commit
30aa2c9b82
5 changed files with 21 additions and 22 deletions
|
@ -1,5 +1,5 @@
|
||||||
import { sdkMock } from '$lib/__mocks__/sdk.mock';
|
import { sdkMock } from '$lib/__mocks__/sdk.mock';
|
||||||
import { albumFactory } from '@test-data';
|
import { albumFactory } from '@test-data/factories/album-factory';
|
||||||
import '@testing-library/jest-dom';
|
import '@testing-library/jest-dom';
|
||||||
import { fireEvent, render, waitFor, type RenderResult } from '@testing-library/svelte';
|
import { fireEvent, render, waitFor, type RenderResult } from '@testing-library/svelte';
|
||||||
import { init, register, waitLocale } from 'svelte-i18n';
|
import { init, register, waitLocale } from 'svelte-i18n';
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import AlbumCover from '$lib/components/album-page/album-cover.svelte';
|
import AlbumCover from '$lib/components/album-page/album-cover.svelte';
|
||||||
import { getAssetThumbnailUrl } from '$lib/utils';
|
import { getAssetThumbnailUrl } from '$lib/utils';
|
||||||
import { albumFactory } from '@test-data';
|
import { albumFactory } from '@test-data/factories/album-factory';
|
||||||
import { render } from '@testing-library/svelte';
|
import { render } from '@testing-library/svelte';
|
||||||
|
|
||||||
vi.mock('$lib/utils');
|
vi.mock('$lib/utils');
|
||||||
|
|
|
@ -1,19 +1,16 @@
|
||||||
import ShareCover from '$lib/components/sharedlinks-page/covers/share-cover.svelte';
|
import ShareCover from '$lib/components/sharedlinks-page/covers/share-cover.svelte';
|
||||||
import { getAssetThumbnailUrl } from '$lib/utils';
|
import { getAssetThumbnailUrl } from '$lib/utils';
|
||||||
import type { SharedLinkResponseDto } from '@immich/sdk';
|
import { albumFactory } from '@test-data/factories/album-factory';
|
||||||
import { albumFactory } from '@test-data';
|
import { assetFactory } from '@test-data/factories/asset-factory';
|
||||||
import { render } from '@testing-library/svelte';
|
import { sharedLinkFactory } from '@test-data/factories/shared-link-factory';
|
||||||
|
import { render, screen } from '@testing-library/svelte';
|
||||||
|
|
||||||
vi.mock('$lib/utils');
|
vi.mock('$lib/utils');
|
||||||
|
|
||||||
describe('ShareCover component', () => {
|
describe('ShareCover component', () => {
|
||||||
it('renders an image when the shared link is an album', () => {
|
it('renders an image when the shared link is an album', () => {
|
||||||
const component = render(ShareCover, {
|
const component = render(ShareCover, {
|
||||||
link: {
|
link: sharedLinkFactory.build({ album: albumFactory.build({ albumName: '123' }) }),
|
||||||
album: albumFactory.build({
|
|
||||||
albumName: '123',
|
|
||||||
}),
|
|
||||||
} as SharedLinkResponseDto,
|
|
||||||
preload: false,
|
preload: false,
|
||||||
class: 'text',
|
class: 'text',
|
||||||
});
|
});
|
||||||
|
@ -26,13 +23,7 @@ describe('ShareCover component', () => {
|
||||||
it('renders an image when the shared link is an individual share', () => {
|
it('renders an image when the shared link is an individual share', () => {
|
||||||
vi.mocked(getAssetThumbnailUrl).mockReturnValue('/asdf');
|
vi.mocked(getAssetThumbnailUrl).mockReturnValue('/asdf');
|
||||||
const component = render(ShareCover, {
|
const component = render(ShareCover, {
|
||||||
link: {
|
link: sharedLinkFactory.build({ assets: [assetFactory.build({ id: 'someId' })] }),
|
||||||
assets: [
|
|
||||||
{
|
|
||||||
id: 'someId',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
} as SharedLinkResponseDto,
|
|
||||||
preload: false,
|
preload: false,
|
||||||
class: 'text',
|
class: 'text',
|
||||||
});
|
});
|
||||||
|
@ -46,9 +37,7 @@ describe('ShareCover component', () => {
|
||||||
|
|
||||||
it('renders an image when the shared link has no album or assets', () => {
|
it('renders an image when the shared link has no album or assets', () => {
|
||||||
const component = render(ShareCover, {
|
const component = render(ShareCover, {
|
||||||
link: {
|
link: sharedLinkFactory.build(),
|
||||||
assets: [],
|
|
||||||
} as unknown as SharedLinkResponseDto,
|
|
||||||
preload: false,
|
preload: false,
|
||||||
class: 'text',
|
class: 'text',
|
||||||
});
|
});
|
||||||
|
@ -57,4 +46,15 @@ describe('ShareCover component', () => {
|
||||||
expect(img.getAttribute('loading')).toBe('lazy');
|
expect(img.getAttribute('loading')).toBe('lazy');
|
||||||
expect(img.className).toBe('z-0 rounded-xl object-cover text');
|
expect(img.className).toBe('z-0 rounded-xl object-cover text');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('renders fallback image when asset is not resized', () => {
|
||||||
|
const link = sharedLinkFactory.build({ assets: [assetFactory.build({ resized: false })] });
|
||||||
|
render(ShareCover, {
|
||||||
|
link: link,
|
||||||
|
preload: false,
|
||||||
|
});
|
||||||
|
|
||||||
|
const img = screen.getByTestId<HTMLImageElement>('album-image');
|
||||||
|
expect(img.alt).toBe('unnamed_share');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
<div class="relative aspect-square shrink-0">
|
<div class="relative aspect-square shrink-0">
|
||||||
{#if link?.album}
|
{#if link?.album}
|
||||||
<AlbumCover album={link.album} class={className} {preload} />
|
<AlbumCover album={link.album} class={className} {preload} />
|
||||||
{:else if link.assets[0]}
|
{:else if link.assets[0]?.resized}
|
||||||
<AssetCover
|
<AssetCover
|
||||||
alt={$t('individual_share')}
|
alt={$t('individual_share')}
|
||||||
class={className}
|
class={className}
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
export * from './factories/album-factory';
|
|
Loading…
Reference in a new issue