Skip to content

Commit

Permalink
test: Fixes and adds tests for custom keyboard shortcuts
Browse files Browse the repository at this point in the history
  • Loading branch information
scottlovegrove committed Aug 6, 2023
1 parent 3d62c19 commit f2ff8de
Showing 1 changed file with 50 additions and 1 deletion.
51 changes: 50 additions & 1 deletion packages/Schedulely/__tests__/hooks/useKeyboardControls.spec.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { ActionProvider } from '../../src/providers';
import { RenderResult, fireEvent, render } from '@testing-library/react';
import { useKeyboardControls } from '@/hooks/useKeyboardControls';
import { vi } from 'vitest';
Expand All @@ -15,11 +16,24 @@ vi.mock('@/hooks/useCalendar', () => ({
})),
}));

const TestWrapper = () => {
const mockOnUpArrow = vi.fn();
const mockOnDownArrow = vi.fn();
const mockOnLeftArrow = vi.fn();
const mockOnRightArrow = vi.fn();

const Wrapper = () => {
useKeyboardControls();
return <div></div>;
};

const TestWrapper = () => {
return (
<ActionProvider>
<Wrapper />
</ActionProvider>
);
};

describe('useKeyboardControls', () => {
let testObject: RenderResult;

Expand All @@ -46,4 +60,39 @@ describe('useKeyboardControls', () => {
fireEvent.keyDown(testObject.container, { key: 'ArrowDown' });
expect(mockOnPrevYear).toHaveBeenCalledTimes(1);
});

describe('custom keyboard events', () => {
beforeEach(() => {
vi.mock('@/hooks/useActions', () => ({
useActions: vi.fn(() => ({
keyboardEvents: {
onUpArrow: mockOnUpArrow,
onDownArrow: mockOnDownArrow,
onLeftArrow: mockOnLeftArrow,
onRightArrow: mockOnRightArrow,
},
})),
}));
});

it('ArrowUp calls onUpArrow', () => {
fireEvent.keyDown(testObject.container, { key: 'ArrowUp' });
expect(mockOnUpArrow).toHaveBeenCalledTimes(1);
});

it('ArrowRight calls onRightArrow', () => {
fireEvent.keyDown(testObject.container, { key: 'ArrowRight' });
expect(mockOnRightArrow).toHaveBeenCalledTimes(1);
});

it('ArrowLeft calls onLeftArrow', () => {
fireEvent.keyDown(testObject.container, { key: 'ArrowLeft' });
expect(mockOnLeftArrow).toHaveBeenCalledTimes(1);
});

it('ArrowDown calls onDownArrow', () => {
fireEvent.keyDown(testObject.container, { key: 'ArrowDown' });
expect(mockOnDownArrow).toHaveBeenCalledTimes(1);
});
});
});

0 comments on commit f2ff8de

Please sign in to comment.