mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-09-28 17:53:51 +02:00
72 lines
2.7 KiB
JavaScript
72 lines
2.7 KiB
JavaScript
import { h } from 'preact';
|
|
import * as AutoUpdatingCameraImage from '../../components/AutoUpdatingCameraImage';
|
|
import * as Context from '../../context';
|
|
import * as Mqtt from '../../api/mqtt';
|
|
import Camera from '../Camera';
|
|
import * as JSMpegPlayer from '../../components/JSMpegPlayer';
|
|
import { fireEvent, render, screen, waitForElementToBeRemoved } from 'testing-library';
|
|
|
|
describe('Camera Route', () => {
|
|
let mockUsePersistence, mockSetOptions;
|
|
|
|
beforeEach(() => {
|
|
mockSetOptions = jest.fn();
|
|
mockUsePersistence = jest.spyOn(Context, 'usePersistence').mockImplementation(() => [{}, mockSetOptions]);
|
|
jest.spyOn(AutoUpdatingCameraImage, 'default').mockImplementation(({ searchParams }) => {
|
|
return <div data-testid="mock-image">{searchParams.toString()}</div>;
|
|
});
|
|
jest.spyOn(JSMpegPlayer, 'default').mockImplementation(() => {
|
|
return <div data-testid="mock-jsmpeg" />;
|
|
});
|
|
jest.spyOn(Mqtt, 'MqttProvider').mockImplementation(({ children }) => children);
|
|
});
|
|
|
|
test('reads camera feed options from persistence', async () => {
|
|
mockUsePersistence.mockReturnValue([
|
|
{
|
|
bbox: true,
|
|
timestamp: false,
|
|
zones: true,
|
|
mask: false,
|
|
motion: true,
|
|
regions: false,
|
|
},
|
|
mockSetOptions,
|
|
]);
|
|
|
|
render(<Camera camera="front" />);
|
|
|
|
await waitForElementToBeRemoved(() => screen.queryByLabelText('Loading…'));
|
|
|
|
fireEvent.click(screen.queryByText('Debug'));
|
|
fireEvent.click(screen.queryByText('Show Options'));
|
|
expect(screen.queryByTestId('mock-image')).toHaveTextContent(
|
|
'bbox=1×tamp=0&zones=1&mask=0&motion=1®ions=0'
|
|
);
|
|
});
|
|
|
|
test('updates camera feed options to persistence', async () => {
|
|
mockUsePersistence
|
|
.mockReturnValueOnce([{}, mockSetOptions])
|
|
.mockReturnValueOnce([{}, mockSetOptions])
|
|
.mockReturnValueOnce([{}, mockSetOptions])
|
|
.mockReturnValueOnce([{ bbox: true }, mockSetOptions])
|
|
.mockReturnValueOnce([{ bbox: true, timestamp: true }, mockSetOptions]);
|
|
|
|
render(<Camera camera="front" />);
|
|
|
|
await waitForElementToBeRemoved(() => screen.queryByLabelText('Loading…'));
|
|
|
|
fireEvent.click(screen.queryByText('Debug'));
|
|
fireEvent.click(screen.queryByText('Show Options'));
|
|
fireEvent.change(screen.queryByTestId('bbox-input'), { target: { checked: true } });
|
|
fireEvent.change(screen.queryByTestId('timestamp-input'), { target: { checked: true } });
|
|
fireEvent.click(screen.queryByText('Hide Options'));
|
|
|
|
expect(mockUsePersistence).toHaveBeenCalledTimes(5);
|
|
expect(mockSetOptions).toHaveBeenCalledTimes(2);
|
|
expect(mockSetOptions).toHaveBeenCalledWith({ bbox: true, timestamp: true });
|
|
expect(screen.queryByTestId('mock-image')).toHaveTextContent('bbox=1×tamp=1');
|
|
});
|
|
});
|