Browse Source

fix: added tests to branch

pull/494/head
Dan Ditomaso 1 year ago
parent
commit
97f2abb582
  1. 88
      src/components/Dialog/UnsafeRolesDialog/UnsafeRolesDialog.test.tsx
  2. 102
      src/components/Dialog/UnsafeRolesDialog/useUnsafeRoles.test.ts
  3. 120
      src/components/UI/Checkbox/Checkbox.test.tsx

88
src/components/Dialog/UnsafeRolesDialog/UnsafeRolesDialog.test.tsx

@ -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");
});
});

102
src/components/Dialog/UnsafeRolesDialog/useUnsafeRoles.test.ts

@ -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);
});
});

120
src/components/UI/Checkbox/Checkbox.test.tsx

@ -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…
Cancel
Save