3 changed files with 310 additions and 0 deletions
@ -0,0 +1,88 @@ |
|||
import { describe, it, expect, vi, beforeEach } from 'vitest'; |
|||
import { render, screen, fireEvent } from '@testing-library/react'; |
|||
import { UnsafeRolesDialog } from '@components/Dialog/UnsafeRolesDialog/UnsafeRolesDialog.tsx'; |
|||
import { useUnsafeRoles } from '@components/Dialog/UnsafeRolesDialog/useUnsafeRoles.ts'; |
|||
|
|||
vi.mock('@components/Dialog/UnsafeRolesDialog/useUnsafeRoles', () => ({ |
|||
useUnsafeRoles: vi.fn() |
|||
})); |
|||
|
|||
describe('UnsafeRolesDialog', () => { |
|||
const getConfirmStateMock = vi.fn(); |
|||
const toggleConfirmStateMock = vi.fn(); |
|||
const handleCloseDialogMock = vi.fn(); |
|||
const onOpenChangeMock = vi.fn(); |
|||
|
|||
beforeEach(() => { |
|||
vi.resetAllMocks(); |
|||
|
|||
getConfirmStateMock.mockReturnValue(false); |
|||
|
|||
(useUnsafeRoles as any).mockReturnValue({ |
|||
getConfirmState: getConfirmStateMock, |
|||
toggleConfirmState: toggleConfirmStateMock, |
|||
handleCloseDialog: handleCloseDialogMock |
|||
}); |
|||
}); |
|||
|
|||
it('should not render when open is false', () => { |
|||
render(<UnsafeRolesDialog open={false} onOpenChange={onOpenChangeMock} />); |
|||
|
|||
expect(screen.queryByTestId('dialog')).not.toBeInTheDocument(); |
|||
}); |
|||
|
|||
it('should render when open is true', () => { |
|||
render(<UnsafeRolesDialog open={true} onOpenChange={onOpenChangeMock} />); |
|||
|
|||
expect(screen.getByRole('dialog')).toBeInTheDocument(); |
|||
expect(screen.getByRole('heading')).toBeInTheDocument(); |
|||
expect(screen.getByText('Are you sure?')).toBeInTheDocument(); |
|||
expect(screen.getAllByRole('link')).length(2); |
|||
expect(screen.getByRole('checkbox')).toBeInTheDocument(); |
|||
expect(screen.getByText('Yes, I know what I\'m doing')).toBeInTheDocument(); |
|||
expect(screen.getByRole('button', { name: /dismiss/i })).toBeInTheDocument(); |
|||
expect(screen.getByRole('button', { name: /confirm/i })).toBeInTheDocument(); |
|||
}); |
|||
|
|||
it('should have disabled confirm button when checkbox is unchecked', () => { |
|||
getConfirmStateMock.mockReturnValue(false); |
|||
|
|||
render(<UnsafeRolesDialog open={true} onOpenChange={onOpenChangeMock} />); |
|||
|
|||
expect(screen.getByRole('button', { name: /confirm/i })).toBeDisabled(); |
|||
}); |
|||
|
|||
it('should have enabled confirm button when checkbox is checked', () => { |
|||
getConfirmStateMock.mockReturnValue(true); |
|||
|
|||
render(<UnsafeRolesDialog open={true} onOpenChange={onOpenChangeMock} />); |
|||
|
|||
expect(screen.getByRole('button', { name: /confirm/i })).not.toBeDisabled(); |
|||
}); |
|||
|
|||
it('should call toggleConfirmState when checkbox is clicked', () => { |
|||
render(<UnsafeRolesDialog open={true} onOpenChange={onOpenChangeMock} />); |
|||
|
|||
fireEvent.click(screen.getByRole('checkbox')); |
|||
|
|||
expect(toggleConfirmStateMock).toHaveBeenCalledTimes(1); |
|||
}); |
|||
|
|||
it('should call handleCloseDialog with "dismiss" when dismiss button is clicked', () => { |
|||
render(<UnsafeRolesDialog open={true} onOpenChange={onOpenChangeMock} />); |
|||
|
|||
fireEvent.click(screen.getByRole('button', { name: /dismiss/i })); |
|||
|
|||
expect(handleCloseDialogMock).toHaveBeenCalledWith('dismiss'); |
|||
}); |
|||
|
|||
it('should call handleCloseDialog with "confirm" when confirm button is clicked', () => { |
|||
getConfirmStateMock.mockReturnValue(true); |
|||
|
|||
render(<UnsafeRolesDialog open={true} onOpenChange={onOpenChangeMock} />); |
|||
|
|||
fireEvent.click(screen.getByRole('button', { name: /confirm/i })); |
|||
|
|||
expect(handleCloseDialogMock).toHaveBeenCalledWith("confirm"); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,102 @@ |
|||
import { describe, it, expect, vi, beforeEach } from 'vitest'; |
|||
import { renderHook, act } from '@testing-library/react'; |
|||
import { useUnsafeRoles } from './useUnsafeRoles.ts'; |
|||
import { useDevice } from '@core/stores/deviceStore.ts'; |
|||
import useLocalStorage from '@core/hooks/useLocalStorage.ts'; |
|||
|
|||
vi.mock('@core/stores/deviceStore', () => ({ |
|||
useDevice: vi.fn() |
|||
})); |
|||
|
|||
vi.mock('@core/hooks/useLocalStorage', () => { |
|||
return { |
|||
default: vi.fn() |
|||
}; |
|||
}); |
|||
|
|||
describe('useUnsafeRoles', () => { |
|||
const setDialogOpenMock = vi.fn(); |
|||
const setAgreedToUnsafeRolesMock = vi.fn(); |
|||
|
|||
beforeEach(() => { |
|||
vi.resetAllMocks(); |
|||
|
|||
(useDevice as any).mockReturnValue({ |
|||
setDialogOpen: setDialogOpenMock |
|||
}); |
|||
|
|||
(useLocalStorage as any).mockReturnValue([ |
|||
false, |
|||
setAgreedToUnsafeRolesMock |
|||
]); |
|||
}); |
|||
|
|||
it('should initialize with correct default values', () => { |
|||
const { result } = renderHook(() => useUnsafeRoles()); |
|||
|
|||
expect(result.current.agreedToUnSafeRoles).toBe(false); |
|||
expect(result.current.getConfirmState()).toBe(false); |
|||
}); |
|||
|
|||
it('should toggle confirm state correctly', () => { |
|||
const { result } = renderHook(() => useUnsafeRoles()); |
|||
|
|||
act(() => { |
|||
result.current.toggleConfirmState(); |
|||
}); |
|||
|
|||
expect(result.current.getConfirmState()).toBe(true); |
|||
|
|||
act(() => { |
|||
result.current.toggleConfirmState(); |
|||
}); |
|||
|
|||
expect(result.current.getConfirmState()).toBe(false); |
|||
}); |
|||
|
|||
it('should handle dialog close with dismiss state', () => { |
|||
const { result } = renderHook(() => useUnsafeRoles()); |
|||
|
|||
act(() => { |
|||
result.current.handleCloseDialog('dismiss'); |
|||
}); |
|||
|
|||
expect(setAgreedToUnsafeRolesMock).toHaveBeenCalledWith(false); |
|||
expect(setDialogOpenMock).toHaveBeenCalledWith('unsafeRoles', false); |
|||
}); |
|||
|
|||
it('should handle dialog close with confirm state', () => { |
|||
const { result } = renderHook(() => useUnsafeRoles()); |
|||
|
|||
act(() => { |
|||
result.current.handleCloseDialog('confirm'); |
|||
}); |
|||
|
|||
expect(setAgreedToUnsafeRolesMock).toHaveBeenCalledWith(true); |
|||
expect(setDialogOpenMock).toHaveBeenCalledWith('unsafeRoles', false); |
|||
}); |
|||
|
|||
it('should maintain state consistency across multiple operations', () => { |
|||
const { result } = renderHook(() => useUnsafeRoles()); |
|||
|
|||
act(() => { |
|||
result.current.toggleConfirmState(); |
|||
}); |
|||
expect(result.current.getConfirmState()).toBe(true); |
|||
|
|||
act(() => { |
|||
result.current.handleCloseDialog('confirm'); |
|||
}); |
|||
|
|||
expect(result.current.getConfirmState()).toBe(false); |
|||
expect(setAgreedToUnsafeRolesMock).toHaveBeenCalledWith(true); |
|||
|
|||
(useLocalStorage as any).mockReturnValue([ |
|||
true, |
|||
setAgreedToUnsafeRolesMock |
|||
]); |
|||
|
|||
const { result: newResult } = renderHook(() => useUnsafeRoles()); |
|||
expect(newResult.current.agreedToUnSafeRoles).toBe(true); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,120 @@ |
|||
import { describe, it, expect, vi, beforeEach } from 'vitest'; |
|||
import { render, screen, fireEvent, cleanup } from '@testing-library/react'; |
|||
import { Checkbox } from '@components/UI/Checkbox/index.tsx'; |
|||
import React from "react"; |
|||
|
|||
vi.mock('@components/UI/Label.tsx', () => ({ |
|||
Label: ({ children, className, htmlFor, id }: { children: React.ReactNode; className: string; htmlFor: string; id: string }) => ( |
|||
<label data-testid="label-component" className={className} htmlFor={htmlFor} id={id}> |
|||
{children} |
|||
</label> |
|||
), |
|||
})); |
|||
|
|||
vi.mock('@core/utils/cn.ts', () => ({ |
|||
cn: (...args: any) => args.filter(Boolean).join(' '), |
|||
})); |
|||
|
|||
vi.mock('react', async () => { |
|||
const actual = await vi.importActual('react'); |
|||
return { |
|||
...actual, |
|||
useId: () => 'test-id', |
|||
}; |
|||
}); |
|||
|
|||
describe('Checkbox', () => { |
|||
beforeEach(cleanup); |
|||
|
|||
it('renders unchecked by default', () => { |
|||
render(<Checkbox />); |
|||
const checkbox = screen.getByRole('checkbox'); |
|||
expect(checkbox).not.toBeChecked(); |
|||
expect(screen.queryByText('Check')).not.toBeInTheDocument(); |
|||
}); |
|||
|
|||
it('renders checked when checked prop is true', () => { |
|||
render(<Checkbox checked={true} />); |
|||
expect(screen.getByRole('checkbox')).toBeChecked(); |
|||
expect(screen.getByRole('presentation')).toBeInTheDocument(); |
|||
}); |
|||
|
|||
it('calls onChange when clicked', () => { |
|||
const onChange = vi.fn(); |
|||
render(<Checkbox onChange={onChange} />); |
|||
|
|||
fireEvent.click(screen.getByRole('presentation')); |
|||
expect(onChange).toHaveBeenCalledWith(true); |
|||
|
|||
fireEvent.click(screen.getByRole('presentation')); |
|||
expect(onChange).toHaveBeenCalledWith(false); |
|||
}); |
|||
|
|||
it('uses provided id', () => { |
|||
render(<Checkbox id="custom-id" />); |
|||
expect(screen.getByRole('checkbox').id).toBe('custom-id'); |
|||
}); |
|||
|
|||
it('generates id when not provided', () => { |
|||
render(<Checkbox />); |
|||
expect(screen.getByRole('checkbox').id).toBe('test-id'); |
|||
}); |
|||
|
|||
it('renders children in Label component', () => { |
|||
render(<Checkbox>Test Label</Checkbox>); |
|||
expect(screen.getByTestId('label-component')).toHaveTextContent('Test Label'); |
|||
}); |
|||
|
|||
it('applies custom className', () => { |
|||
const { container } = render(<Checkbox className="custom-class" />); |
|||
expect(container.firstChild).toHaveClass('custom-class'); |
|||
}); |
|||
|
|||
it('applies labelClassName to Label', () => { |
|||
render(<Checkbox labelClassName="label-class">Test</Checkbox>); |
|||
expect(screen.getByTestId('label-component')).toHaveClass('label-class'); |
|||
}); |
|||
|
|||
it('disables checkbox when disabled prop is true', () => { |
|||
render(<Checkbox disabled />); |
|||
expect(screen.getByRole('checkbox')).toBeDisabled(); |
|||
expect(screen.getByRole('presentation')).toHaveClass('opacity-50'); |
|||
}); |
|||
|
|||
it('does not call onChange when disabled', () => { |
|||
const onChange = vi.fn(); |
|||
render(<Checkbox onChange={onChange} disabled />); |
|||
|
|||
fireEvent.click(screen.getByRole('presentation')); |
|||
expect(onChange).not.toHaveBeenCalled(); |
|||
}); |
|||
|
|||
it('sets required attribute when required prop is true', () => { |
|||
render(<Checkbox required />); |
|||
expect(screen.getByRole('checkbox')).toHaveAttribute('required'); |
|||
}); |
|||
|
|||
it('sets name attribute when name prop is provided', () => { |
|||
render(<Checkbox name="test-name" />); |
|||
expect(screen.getByRole('checkbox')).toHaveAttribute('name', 'test-name'); |
|||
}); |
|||
|
|||
it('passes through additional props', () => { |
|||
render(<Checkbox data-testid="extra-prop" />); |
|||
expect(screen.getByRole('checkbox')).toHaveAttribute('data-testid', 'extra-prop'); |
|||
}); |
|||
|
|||
it('toggles checked state correctly', () => { |
|||
render(<Checkbox />); |
|||
const checkbox = screen.getByRole('checkbox'); |
|||
const presentation = screen.getByRole('presentation'); |
|||
|
|||
expect(checkbox).not.toBeChecked(); |
|||
|
|||
fireEvent.click(presentation); |
|||
expect(checkbox).toBeChecked(); |
|||
|
|||
fireEvent.click(presentation); |
|||
expect(checkbox).not.toBeChecked(); |
|||
}); |
|||
}); |
|||
Loading…
Reference in new issue