|
| 1 | +// Copyright (C) 2025 Intel Corporation |
| 2 | +// SPDX-License-Identifier: Apache-2.0 |
| 3 | + |
| 4 | +import { render, screen, waitForElementToBeRemoved } from '@testing-library/react'; |
| 5 | +import { userEvent } from '@testing-library/user-event'; |
| 6 | +import { HttpResponse } from 'msw'; |
| 7 | +import { vi } from 'vitest'; |
| 8 | + |
| 9 | +import { http } from '../../../../api/utils'; |
| 10 | +import { server } from '../../../../msw-node-setup'; |
| 11 | +import { TestProviders } from '../../../../providers'; |
| 12 | +import { DeleteMediaItem } from './delete-media-item.component'; |
| 13 | + |
| 14 | +vi.mock('react-router', () => ({ |
| 15 | + useParams: vi.fn(() => ({ projectId: '123' })), |
| 16 | +})); |
| 17 | + |
| 18 | +describe('DeleteMediaItem', () => { |
| 19 | + it('deletes a media item and shows a success toast', async () => { |
| 20 | + const itemId = '123'; |
| 21 | + server.use( |
| 22 | + http.delete('/api/projects/{project_id}/dataset/items/{dataset_item_id}', () => { |
| 23 | + return HttpResponse.json(null, { status: 204 }); |
| 24 | + }) |
| 25 | + ); |
| 26 | + |
| 27 | + render( |
| 28 | + <TestProviders> |
| 29 | + <DeleteMediaItem itemId={itemId} /> |
| 30 | + </TestProviders> |
| 31 | + ); |
| 32 | + |
| 33 | + userEvent.click(screen.getByLabelText(/delete media item/i)); |
| 34 | + await screen.findByText(/Are you sure you want to delete the next items?/i); |
| 35 | + |
| 36 | + userEvent.click(screen.getByRole('button', { name: /confirm/i })); |
| 37 | + await waitForElementToBeRemoved(() => screen.queryByRole('button', { name: /confirm/i })); |
| 38 | + |
| 39 | + expect(screen.getByText(`Item "${itemId}" was deleted successfully`)).toBeVisible(); |
| 40 | + }); |
| 41 | + |
| 42 | + it('shows an error toast when deleting a media item fails', async () => { |
| 43 | + const itemId = '123'; |
| 44 | + const errorMessage = 'test error message'; |
| 45 | + server.use( |
| 46 | + http.delete('/api/projects/{project_id}/dataset/items/{dataset_item_id}', () => { |
| 47 | + // eslint-disable-next-line @typescript-eslint/ban-ts-comment |
| 48 | + // @ts-expect-error |
| 49 | + return HttpResponse.json({ detail: errorMessage }, { status: 500 }); |
| 50 | + }) |
| 51 | + ); |
| 52 | + |
| 53 | + render( |
| 54 | + <TestProviders> |
| 55 | + <DeleteMediaItem itemId={itemId} /> |
| 56 | + </TestProviders> |
| 57 | + ); |
| 58 | + |
| 59 | + userEvent.click(screen.getByLabelText(/delete media item/i)); |
| 60 | + await screen.findByText(/Are you sure you want to delete the next items?/i); |
| 61 | + |
| 62 | + userEvent.click(screen.getByRole('button', { name: /confirm/i })); |
| 63 | + await waitForElementToBeRemoved(() => screen.queryByRole('button', { name: /confirm/i })); |
| 64 | + |
| 65 | + expect(screen.getByText(`Failed to delete item: ${errorMessage}`)).toBeVisible(); |
| 66 | + }); |
| 67 | +}); |
0 commit comments