forked from Github/frigate
* Bump jest from 27.5.1 to 29.3.1 in /web Bumps [jest](https://github.com/facebook/jest/tree/HEAD/packages/jest) from 27.5.1 to 29.3.1. - [Release notes](https://github.com/facebook/jest/releases) - [Changelog](https://github.com/facebook/jest/blob/main/CHANGELOG.md) - [Commits](https://github.com/facebook/jest/commits/v29.3.1/packages/jest) --- updated-dependencies: - dependency-name: jest dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <support@github.com> * Bump msw from 0.38.2 to 0.48.0 in /web Bumps [msw](https://github.com/mswjs/msw) from 0.38.2 to 0.48.0. - [Release notes](https://github.com/mswjs/msw/releases) - [Changelog](https://github.com/mswjs/msw/blob/main/CHANGELOG.md) - [Commits](https://github.com/mswjs/msw/compare/v0.38.2...v0.48.0) --- updated-dependencies: - dependency-name: msw dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * Bump idb-keyval from 6.1.0 to 6.2.0 in /web Bumps [idb-keyval](https://github.com/jakearchibald/idb-keyval) from 6.1.0 to 6.2.0. - [Release notes](https://github.com/jakearchibald/idb-keyval/releases) - [Changelog](https://github.com/jakearchibald/idb-keyval/blob/main/CHANGELOG.md) - [Commits](https://github.com/jakearchibald/idb-keyval/compare/v6.1.0...v6.2.0) --- updated-dependencies: - dependency-name: idb-keyval dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * Bump @babel/preset-typescript from 7.16.7 to 7.18.6 in /web Bumps [@babel/preset-typescript](https://github.com/babel/babel/tree/HEAD/packages/babel-preset-typescript) from 7.16.7 to 7.18.6. - [Release notes](https://github.com/babel/babel/releases) - [Changelog](https://github.com/babel/babel/blob/main/CHANGELOG.md) - [Commits](https://github.com/babel/babel/commits/v7.18.6/packages/babel-preset-typescript) --- updated-dependencies: - dependency-name: "@babel/preset-typescript" dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * Bump typescript from 4.6.2 to 4.8.4 in /web Bumps [typescript](https://github.com/Microsoft/TypeScript) from 4.6.2 to 4.8.4. - [Release notes](https://github.com/Microsoft/TypeScript/releases) - [Commits](https://github.com/Microsoft/TypeScript/compare/v4.6.2...v4.8.4) --- updated-dependencies: - dependency-name: typescript dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * Bump @testing-library/user-event from 13.5.0 to 14.4.3 in /web Bumps [@testing-library/user-event](https://github.com/testing-library/user-event) from 13.5.0 to 14.4.3. - [Release notes](https://github.com/testing-library/user-event/releases) - [Changelog](https://github.com/testing-library/user-event/blob/main/CHANGELOG.md) - [Commits](https://github.com/testing-library/user-event/compare/v13.5.0...v14.4.3) --- updated-dependencies: - dependency-name: "@testing-library/user-event" dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <support@github.com> * Bump preact-router from 4.0.1 to 4.1.0 in /web Bumps [preact-router](https://github.com/preactjs/preact-router) from 4.0.1 to 4.1.0. - [Release notes](https://github.com/preactjs/preact-router/releases) - [Commits](https://github.com/preactjs/preact-router/compare/4.0.1...4.1.0) --- updated-dependencies: - dependency-name: preact-router dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * Bump axios from 0.26.0 to 1.1.3 in /web Bumps [axios](https://github.com/axios/axios) from 0.26.0 to 1.1.3. - [Release notes](https://github.com/axios/axios/releases) - [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md) - [Commits](https://github.com/axios/axios/compare/v0.26.0...v1.1.3) --- updated-dependencies: - dependency-name: axios dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <support@github.com> * Bump @preact/preset-vite from 2.1.7 to 2.4.0 in /web Bumps [@preact/preset-vite](https://github.com/preactjs/preset-vite) from 2.1.7 to 2.4.0. - [Release notes](https://github.com/preactjs/preset-vite/releases) - [Commits](https://github.com/preactjs/preset-vite/compare/v2.1.7...v2.4.0) --- updated-dependencies: - dependency-name: "@preact/preset-vite" dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * Bump @testing-library/jest-dom from 5.16.2 to 5.16.5 in /web Bumps [@testing-library/jest-dom](https://github.com/testing-library/jest-dom) from 5.16.2 to 5.16.5. - [Release notes](https://github.com/testing-library/jest-dom/releases) - [Changelog](https://github.com/testing-library/jest-dom/blob/main/CHANGELOG.md) - [Commits](https://github.com/testing-library/jest-dom/compare/v5.16.2...v5.16.5) --- updated-dependencies: - dependency-name: "@testing-library/jest-dom" dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> * revamp frontend * disable broken tests * disable a few more tests * update typescript * couple docs updates Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
198 lines
5.1 KiB
JavaScript
198 lines
5.1 KiB
JavaScript
import { h } from 'preact';
|
|
import { set as setData } from 'idb-keyval';
|
|
import { DarkModeProvider, useDarkMode, usePersistence } from '..';
|
|
import { fireEvent, render, screen } from 'testing-library';
|
|
import { useCallback } from 'preact/hooks';
|
|
import * as Mqtt from '../../api/mqtt';
|
|
|
|
function DarkModeChecker() {
|
|
const { currentMode } = useDarkMode();
|
|
return <div data-testid={currentMode}>{currentMode}</div>;
|
|
}
|
|
|
|
describe('DarkMode', () => {
|
|
beforeEach(() => {
|
|
vi.spyOn(Mqtt, 'MqttProvider').mockImplementation(({ children }) => children);
|
|
});
|
|
|
|
test('uses media by default', async () => {
|
|
render(
|
|
<DarkModeProvider>
|
|
<DarkModeChecker />
|
|
</DarkModeProvider>
|
|
);
|
|
const el = await screen.findByTestId('media');
|
|
expect(el).toBeInTheDocument();
|
|
});
|
|
|
|
test('uses the mode stored in idb - dark', async () => {
|
|
setData('darkmode', 'dark');
|
|
render(
|
|
<DarkModeProvider>
|
|
<DarkModeChecker />
|
|
</DarkModeProvider>
|
|
);
|
|
const el = await screen.findByTestId('dark');
|
|
expect(el).toBeInTheDocument();
|
|
expect(document.body.classList.contains('dark')).toBe(true);
|
|
});
|
|
|
|
test('uses the mode stored in idb - light', async () => {
|
|
setData('darkmode', 'light');
|
|
render(
|
|
<DarkModeProvider>
|
|
<DarkModeChecker />
|
|
</DarkModeProvider>
|
|
);
|
|
const el = await screen.findByTestId('light');
|
|
expect(el).toBeInTheDocument();
|
|
expect(document.body.classList.contains('dark')).toBe(false);
|
|
});
|
|
|
|
test('allows updating the mode', async () => {
|
|
setData('darkmode', 'dark');
|
|
|
|
function Updater() {
|
|
const { setDarkMode } = useDarkMode();
|
|
const handleClick = useCallback(() => {
|
|
setDarkMode('light');
|
|
}, [setDarkMode]);
|
|
return <div onClick={handleClick}>click me</div>;
|
|
}
|
|
|
|
render(
|
|
<DarkModeProvider>
|
|
<DarkModeChecker />
|
|
<Updater />
|
|
</DarkModeProvider>
|
|
);
|
|
|
|
const dark = await screen.findByTestId('dark');
|
|
expect(dark).toBeInTheDocument();
|
|
expect(document.body.classList.contains('dark')).toBe(true);
|
|
|
|
const button = await screen.findByText('click me');
|
|
fireEvent.click(button);
|
|
|
|
const light = await screen.findByTestId('light');
|
|
expect(light).toBeInTheDocument();
|
|
expect(document.body.classList.contains('dark')).toBe(false);
|
|
});
|
|
|
|
test('when using media, matches on preference', async () => {
|
|
setData('darkmode', 'media');
|
|
vi.spyOn(window, 'matchMedia').mockImplementation((query) => {
|
|
if (query === '(prefers-color-scheme: dark)') {
|
|
return { matches: true, addEventListener: vi.fn(), removeEventListener: vi.fn() };
|
|
}
|
|
|
|
throw new Error(`Unexpected query to matchMedia: ${query}`);
|
|
});
|
|
render(
|
|
<DarkModeProvider>
|
|
<DarkModeChecker />
|
|
</DarkModeProvider>
|
|
);
|
|
|
|
const el = await screen.findByTestId('dark');
|
|
expect(el).toBeInTheDocument();
|
|
expect(document.body.classList.contains('dark')).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe('usePersistence', () => {
|
|
|
|
test('returns a defaultValue initially', async () => {
|
|
|
|
function Component() {
|
|
const [value, , loaded] = usePersistence('tacos', 'my-default');
|
|
return (
|
|
<div>
|
|
<div data-testid="loaded">{loaded ? 'loaded' : 'not loaded'}</div>
|
|
<div data-testid="value">{value}</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
render(<Component />);
|
|
|
|
expect(screen.getByTestId('loaded')).toMatchInlineSnapshot(`
|
|
<div
|
|
data-testid="loaded"
|
|
>
|
|
not loaded
|
|
</div>
|
|
`);
|
|
expect(screen.getByTestId('value')).toMatchInlineSnapshot(`
|
|
<div
|
|
data-testid="value"
|
|
>
|
|
my-default
|
|
</div>
|
|
`);
|
|
});
|
|
|
|
test('updates with the previously-persisted value', async () => {
|
|
setData('tacos', 'are delicious');
|
|
|
|
function Component() {
|
|
const [value, , loaded] = usePersistence('tacos', 'my-default');
|
|
return (
|
|
<div>
|
|
<div data-testid="loaded">{loaded ? 'loaded' : 'not loaded'}</div>
|
|
<div data-testid="value">{value}</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
render(<Component />);
|
|
|
|
await screen.findByText('loaded');
|
|
|
|
expect(screen.getByTestId('loaded')).toMatchInlineSnapshot(`
|
|
<div
|
|
data-testid="loaded"
|
|
>
|
|
loaded
|
|
</div>
|
|
`);
|
|
expect(screen.getByTestId('value')).toMatchInlineSnapshot(`
|
|
<div
|
|
data-testid="value"
|
|
>
|
|
are delicious
|
|
</div>
|
|
`);
|
|
});
|
|
|
|
test('can be updated manually', async () => {
|
|
setData('darkmode', 'are delicious');
|
|
|
|
function Component() {
|
|
const [value, setValue] = usePersistence('tacos', 'my-default');
|
|
const handleClick = useCallback(() => {
|
|
setValue('super delicious');
|
|
}, [setValue]);
|
|
return (
|
|
<div>
|
|
<div onClick={handleClick}>click me</div>
|
|
<div data-testid="value">{value}</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
render(<Component />);
|
|
|
|
const button = await screen.findByText('click me');
|
|
fireEvent.click(button);
|
|
|
|
expect(screen.getByTestId('value')).toMatchInlineSnapshot(`
|
|
<div
|
|
data-testid="value"
|
|
>
|
|
super delicious
|
|
</div>
|
|
`);
|
|
});
|
|
});
|