Przeglądaj źródła

test(web): routes/Cameras

Paul Armstrong 4 lat temu
rodzic
commit
d8b80f0fe9
1 zmienionych plików z 43 dodań i 0 usunięć
  1. 43 0
      web/src/routes/__tests__/Cameras.test.jsx

+ 43 - 0
web/src/routes/__tests__/Cameras.test.jsx

@@ -0,0 +1,43 @@
+import { h } from 'preact';
+import * as Api from '../../api';
+import Cameras from '../Cameras';
+import * as CameraImage from '../../components/CameraImage';
+import { render, screen } from '@testing-library/preact';
+
+jest.mock('../../api/baseUrl');
+
+describe('Cameras Route', () => {
+  let useConfigMock;
+
+  beforeEach(() => {
+    useConfigMock = jest.spyOn(Api, 'useConfig').mockImplementation(() => ({
+      data: {
+        cameras: {
+          front: { name: 'front', objects: { track: ['taco', 'cat', 'dog'] } },
+          side: { name: 'side', objects: { track: ['taco', 'cat', 'dog'] } },
+        },
+      },
+      status: 'loaded',
+    }));
+    jest.spyOn(Api, 'useApiHost').mockImplementation(() => 'http://base-url.local:5000');
+    jest.spyOn(CameraImage, 'default').mockImplementation(() => <div data-testid="camera-image" />);
+  });
+
+  test('shows an ActivityIndicator if not yet loaded', async () => {
+    useConfigMock.mockReturnValueOnce(() => ({ status: 'loading' }));
+    render(<Cameras />);
+    expect(screen.queryByLabelText('Loading…')).toBeInTheDocument();
+  });
+
+  test('shows cameras', async () => {
+    render(<Cameras />);
+
+    expect(screen.queryByLabelText('Loading…')).not.toBeInTheDocument();
+
+    expect(screen.queryByText('front')).toBeInTheDocument();
+    expect(screen.queryByText('front').closest('a')).toHaveAttribute('href', '/cameras/front');
+
+    expect(screen.queryByText('side')).toBeInTheDocument();
+    expect(screen.queryByText('side').closest('a')).toHaveAttribute('href', '/cameras/side');
+  });
+});