import { render, screen } from '@testing-library/react';
import { type Mock, describe, expect, it, vi } from 'vitest';
import { Message } from '../types';
import { SignatureIcon } from '../components/SignatureIcon';
import { useSignatureContext } from '../components/SignatureProvider';
vi.mock('../components/SignatureProvider', () => ({
useSignatureContext: vi.fn(),
}));
vi.mock('../../internal/svg/errorSvg', () => ({
ErrorSvg: vi.fn(() =>
ErrorSvg
),
}));
vi.mock('../../internal/svg/successSvg', () => ({
SuccessSvg: vi.fn(() => SuccessSvg
),
}));
vi.mock('../../internal/components/Spinner', () => ({
Spinner: vi.fn(() => Spinner
),
}));
describe('SignatureIcon', () => {
it('should render success icon', () => {
(useSignatureContext as Mock).mockReturnValue({
lifecycleStatus: {
statusName: 'success',
statusData: {
signature: '0x123',
type: Message.TYPED_DATA,
},
},
});
render();
expect(screen.getByText('SuccessSvg')).toBeInTheDocument();
});
it('should render error icon', () => {
(useSignatureContext as Mock).mockReturnValue({
lifecycleStatus: {
statusName: 'error',
statusData: {
signature: '0x123',
type: Message.TYPED_DATA,
},
},
});
render();
expect(screen.getByText('ErrorSvg')).toBeInTheDocument();
});
it('should render spinner icon', () => {
(useSignatureContext as Mock).mockReturnValue({
lifecycleStatus: {
statusName: 'pending',
statusData: {
signature: '0x123',
type: Message.TYPED_DATA,
},
},
});
render();
expect(screen.getByText('Spinner')).toBeInTheDocument();
});
it('should apply custom className', () => {
(useSignatureContext as Mock).mockReturnValue({
lifecycleStatus: {
statusName: 'success',
statusData: {
signature: '0x123',
type: Message.TYPED_DATA,
},
},
});
render();
expect(screen.getByText('SuccessSvg').parentElement).toHaveClass(
'custom-class',
);
});
it('should not render if no icon', () => {
(useSignatureContext as Mock).mockReturnValue({
lifecycleStatus: {
statusName: 'init',
statusData: null,
},
});
render();
expect(screen.queryByTestId('ockSignatureIcon')).not.toBeInTheDocument();
});
});