Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release: Prerelease 8.0.0-alpha.5 #25271

Merged
merged 154 commits into from
Dec 24, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
154 commits
Select commit Hold shift + click to select a range
8c7f376
add vitest to the monorepo - WIP
ndelangen Sep 14, 2023
be2bf24
remove storyshots some more and delete jest configs
ndelangen Sep 14, 2023
b911c4d
migrate first 2 stories by hand
ndelangen Sep 14, 2023
ed23b2e
run tests only once
ndelangen Sep 14, 2023
aacc4ac
migrate some things by hand
ndelangen Sep 14, 2023
93db551
more manual migrations
ndelangen Sep 14, 2023
fd0386f
making progress on migrating to vitest
ndelangen Sep 14, 2023
1dfe687
migrate all jest references to vitest
yannbf Sep 14, 2023
799b7c7
update snapshots
yannbf Sep 14, 2023
d91a91e
more fixes
yannbf Sep 14, 2023
604a442
progress on fixes
ndelangen Sep 14, 2023
4eace09
Merge branch 'norbert/vitest-for-monorepo' of github.com:storybookjs/…
ndelangen Sep 14, 2023
c9f36de
fixing tests in scripts
ndelangen Sep 14, 2023
90d5409
remove jest-specific-snapshot and update snapshots
yannbf Sep 14, 2023
d1966b1
fix imports
yannbf Sep 14, 2023
cb9ffb1
more test fixes
yannbf Sep 15, 2023
c43385b
fix more tests
yannbf Sep 15, 2023
6c272c9
more fixes
yannbf Sep 15, 2023
6250ef3
fix codemods test
ndelangen Sep 15, 2023
ab77c3e
improve test
ndelangen Sep 15, 2023
2ae51af
fix a test
ndelangen Sep 15, 2023
70beaf7
remove jest-os-detection
yannbf Sep 18, 2023
5d73a0a
Merge branch 'next' into norbert/vitest-for-monorepo
yannbf Oct 9, 2023
9a2f8f6
upgrade to vitest 1.0.0-beta.4 and fix many more tests
yannbf Oct 9, 2023
b76d42c
Merge branch 'next' into norbert/vitest-for-monorepo
yannbf Oct 9, 2023
75e7d00
Add/configure jest-dom
IanVS Oct 10, 2023
db243e1
Cleanup after rendering
IanVS Oct 10, 2023
ccff556
Only use vite 4
IanVS Oct 10, 2023
5fe8e5b
Get renderers/vue tests passing
IanVS Oct 10, 2023
2ca45f5
Get renderers/vue3 tests passing
IanVS Oct 10, 2023
ca0394d
Get renderers/svelte tests passing
IanVS Oct 10, 2023
00b0f0e
Fix cli helpers test
IanVS Oct 10, 2023
238f254
Recreate throwMessage helpers from jest into vitest setup
IanVS Oct 10, 2023
5652c32
Fix type error
IanVS Oct 10, 2023
8abefdb
Avoid empty mockImplementation
IanVS Oct 10, 2023
af7e7e4
A bit cleaner way to deal with fsExtra.__setMockFiles
IanVS Oct 10, 2023
a53cf8d
Avoid console warning error
IanVS Oct 10, 2023
7634e80
Fix lib/codemod test
IanVS Oct 10, 2023
397cafe
Use `import()` for presets instead of `interopRequireDefault`
IanVS Oct 10, 2023
f70813d
Get lib/core-common tests passing
IanVS Oct 10, 2023
fd15923
Get lib/theming tests passing
IanVS Oct 10, 2023
d2f4af1
Update snapshot format
IanVS Oct 11, 2023
6d35099
Avoid infinite loop in find-up
IanVS Oct 11, 2023
375fe3d
Be consistent about named vs default imports
IanVS Oct 11, 2023
2373a09
Use default actual import from debounce
IanVS Oct 11, 2023
29d3e7c
Use vi.waitFor() instead of timing hacks
IanVS Oct 11, 2023
ae00f52
[HACK] add import condition for @storybook/preview/globals
IanVS Oct 11, 2023
3c2479f
Use arg of mock factory to clean up types
IanVS Oct 11, 2023
4ddebe8
Use vi.mocked() instead of casting to Mock
IanVS Oct 11, 2023
1da8527
Remove some unused code
IanVS Oct 11, 2023
3f5e0f3
fix StoryIndexGenerator.test
JReinhold Oct 11, 2023
aab2798
fix StoryIndexGenerator.deprecated.test
JReinhold Oct 11, 2023
1e8adfd
add ignore
ndelangen Nov 4, 2023
99ad313
Merge branch 'release-8-0' into norbert/vitest-for-monorepo
ndelangen Nov 4, 2023
360d02d
ts fixes
ndelangen Nov 4, 2023
bfe4397
upgrade @testing-library/jest-dom
ndelangen Nov 4, 2023
458227a
update snapshots && fixes
ndelangen Nov 4, 2023
4572eeb
fixes
ndelangen Nov 4, 2023
e65f677
upgrade vitest to beta.3 & fixes
ndelangen Nov 7, 2023
1c9050a
fix linting
ndelangen Nov 8, 2023
44944d4
fix check
ndelangen Nov 8, 2023
a5d5e8e
fix check of scripts
ndelangen Nov 8, 2023
e3de0b5
remove invalid flags
ndelangen Nov 8, 2023
3a2986e
remove --ci flags
ndelangen Nov 8, 2023
6f53f7a
add @vitest/coverage-v8 - npm
ndelangen Nov 8, 2023
9adfc24
add package
ndelangen Nov 9, 2023
0452176
remove --runInBand test flag
JReinhold Nov 9, 2023
b64d62b
set vi globals to silent emotion warnings
JReinhold Nov 9, 2023
8e533c2
Merge remote-tracking branch 'origin/next' into norbert/vitest-for-mo…
IanVS Nov 20, 2023
3710197
Update snapshot
IanVS Nov 20, 2023
39f3e42
Update globals
IanVS Nov 20, 2023
ee0953d
fix more tests
yannbf Nov 24, 2023
360ba46
Merge remote-tracking branch 'origin/next' into norbert/vitest-for-mo…
IanVS Dec 5, 2023
3e2f4be
Skip tests that are failing due to emotion theme
IanVS Dec 5, 2023
7ddbde1
Convert new tests from jest to vitest
IanVS Dec 5, 2023
513a02f
Fix eslint test
IanVS Dec 5, 2023
dcabfe6
Update exports
IanVS Dec 5, 2023
5a6b178
Fix lockfile
IanVS Dec 5, 2023
6ce478c
Fix lint errors
IanVS Dec 5, 2023
0845820
Update vitest to 1.0.1
IanVS Dec 5, 2023
56c0710
Fix scripts tests
IanVS Dec 5, 2023
f368ac4
Update snapshots
IanVS Dec 5, 2023
20ccf0b
Unpin vite
IanVS Dec 5, 2023
3fbe517
Fix type errors
IanVS Dec 5, 2023
7df71d3
Merge branch 'next' into norbert/vitest-for-monorepo
IanVS Dec 5, 2023
ee78f8e
Merge branch 'next' of github.com:storybookjs/storybook into norbert/…
JReinhold Dec 6, 2023
6dfcad5
re-add interopRequireDefault, use mock-require in unit tests
JReinhold Dec 6, 2023
7d671ee
revert wrong export statements
JReinhold Dec 6, 2023
239a67d
increase test timeouts, add @types/mock-require
JReinhold Dec 6, 2023
e95b906
increase timeout
JReinhold Dec 6, 2023
019a19f
Fix changelog test
kasperpeulen Dec 7, 2023
5b383c0
Merge branch 'next' into norbert/vitest-for-monorepo
ndelangen Dec 11, 2023
c16c125
Merge branch 'next' into norbert/vitest-for-monorepo
valentinpalkovic Dec 12, 2023
205a339
Fix Angular tests
valentinpalkovic Dec 12, 2023
eed6f38
Fix eslint
valentinpalkovic Dec 12, 2023
2eaeb1f
Fix Svelte tests
valentinpalkovic Dec 12, 2023
ac864a8
Fix test for Windows
valentinpalkovic Dec 14, 2023
a87e909
Docs: Documentation updates for known limitations
jonniebigodes Dec 15, 2023
a0b12e1
Merge branch 'next' into docs_fix_doc_blocks_apis
jonniebigodes Dec 15, 2023
3b63adb
Merge branch 'next' into docs_fix_doc_blocks_apis
jonniebigodes Dec 18, 2023
6633f68
Merge branch 'next' into docs_fix_doc_blocks_apis
jonniebigodes Dec 18, 2023
93ed75b
Merge branch 'next' into docs_fix_doc_blocks_apis
jonniebigodes Dec 18, 2023
4f1931d
fix types in compodoc tests
yannbf Dec 18, 2023
27047ab
remove unnecessary directories
yannbf Dec 18, 2023
8acf97a
remove jest leftovers
yannbf Dec 18, 2023
5a20d19
temporarily debug windows test
yannbf Dec 18, 2023
3d61dc5
undo function calls
yannbf Dec 18, 2023
51ead4f
temporarily skip type checks on public-types.test.ts
yannbf Dec 18, 2023
9b0ad0b
Merge branch 'next' into docs_fix_doc_blocks_apis
jonniebigodes Dec 18, 2023
93339af
Merge branch 'next' into norbert/vitest-for-monorepo
yannbf Dec 19, 2023
62488ec
add uniqueness to cacheDir
ndelangen Dec 19, 2023
0d3c71e
print relative paths and only print static dirs when they matter
ndelangen Dec 19, 2023
a59a2d8
Merge branch 'next' into norbert/no-conflicting-cache-dir-in-builders
ndelangen Dec 19, 2023
ad9aee8
Next.js: Clean up RSC and mock server-only
shilman Dec 19, 2023
3b94da1
force builder-manager to output to 'namespaced' directory correctly
ndelangen Dec 19, 2023
8bf26a0
cleanup
ndelangen Dec 19, 2023
795fb55
fix helper tests on windows
yannbf Dec 19, 2023
7844a6e
migrate tests from jest to vitest
yannbf Dec 19, 2023
f62613c
remove unnecessary ts ignore comment
yannbf Dec 19, 2023
94f4361
remove the -s flag from build & dev
ndelangen Dec 19, 2023
10c614e
increase test timeout
yannbf Dec 19, 2023
6b61f37
temporarily skip some ci checks
yannbf Dec 19, 2023
4a32582
undo debugging checks
yannbf Dec 19, 2023
62df129
update misc code
yannbf Dec 19, 2023
62348c0
undo svelte component changes
yannbf Dec 19, 2023
ec52e79
Fix bad export map
shilman Dec 19, 2023
05e7aaa
Update CHANGELOG.md for v7.6.6 [skip ci]
storybook-bot Dec 19, 2023
f07f64e
fix types in normalize-stories
yannbf Dec 19, 2023
4169cd5
Merge pull request #25263 from storybookjs/shilman/nextjs-mock-server…
shilman Dec 19, 2023
469f49c
final cleanup
yannbf Dec 19, 2023
9508756
update contribution guide
yannbf Dec 19, 2023
2b1258a
fix typo
yannbf Dec 19, 2023
da1d221
Docs: Test Coverage troubleshoot optimized builds
jonniebigodes Dec 19, 2023
4495fa9
Merge pull request #25278 from storybookjs/docs_add_test_troubleshooting
jonniebigodes Dec 19, 2023
bf498ea
Merge pull request #24415 from storybookjs/norbert/vitest-for-monorepo
ndelangen Dec 20, 2023
ae976da
fixes semver deps
ndelangen Dec 20, 2023
5c3a3db
Skip check for no framework given when ignorePreview is true
ndelangen Dec 20, 2023
1ccd125
Docs: Remove static dir flag remval
jonniebigodes Dec 20, 2023
9b344fd
Merge branch 'next' into docs_remove_static_assets_flag
jonniebigodes Dec 20, 2023
851d9c2
disable INCOMPATIBLE_PEER_DEPENDENCY error for SvelteKit sandboxes
JReinhold Dec 21, 2023
f8f8552
Merge branch 'next' into norbert/skip-framework-check-react-native
ndelangen Dec 21, 2023
2ea84ae
Merge pull request #25286 from storybookjs/norbert/skip-framework-che…
ndelangen Dec 21, 2023
0c6020e
Merge branch 'next' into norbert/bundle-semver
ndelangen Dec 21, 2023
1fbac12
Merge pull request #25266 from storybookjs/norbert/remove-deprecated-…
ndelangen Dec 21, 2023
25ee4ce
Merge branch 'next' into norbert/no-conflicting-cache-dir-in-builders
ndelangen Dec 21, 2023
3f09b13
Merge pull request #25291 from storybookjs/docs_remove_static_assets_…
ndelangen Dec 21, 2023
c92a672
Merge pull request #25283 from storybookjs/norbert/bundle-semver
shilman Dec 21, 2023
0c0cada
Merge branch 'next' into norbert/no-conflicting-cache-dir-in-builders
ndelangen Dec 21, 2023
977570c
improvements
ndelangen Dec 21, 2023
aa37ebd
Merge pull request #25264 from storybookjs/norbert/no-conflicting-cac…
ndelangen Dec 21, 2023
ec290ea
Fix links
jonniebigodes Dec 22, 2023
d92b6aa
Merge branch 'next' into docs_fix_doc_blocks_apis
jonniebigodes Dec 22, 2023
76340fc
Merge pull request #25248 from storybookjs/docs_fix_doc_blocks_apis
jonniebigodes Dec 22, 2023
5423ff4
Write changelog for 8.0.0-alpha.5 [skip ci]
storybook-bot Dec 22, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
4 changes: 2 additions & 2 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -204,7 +204,7 @@ jobs:
name: Run tests
command: |
cd scripts
yarn test --coverage --ci
yarn test --coverage
- store_test_results:
path: scripts/junit.xml
- report-workflow-on-failure
Expand All @@ -222,7 +222,7 @@ jobs:
name: Test
command: |
cd code
yarn test --coverage --ci --maxWorkers=6
yarn test --coverage
- store_test_results:
path: code/junit.xml
- persist_to_workspace:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/tests-unit.yml
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,4 @@ jobs:
- name: install and compile
run: yarn task --task compile --start-from=auto --no-link
- name: test
run: yarn test --runInBand --ci
run: yarn test
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -51,4 +51,5 @@ code/playwright-report/
code/playwright/.cache/
code/bench-results/

/packs
/packs
code/.nx/cache
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
## 7.6.6

- SvelteKit: Support 2.0 modules with mocks - [#25244](https://github.com/storybookjs/storybook/pull/25244), thanks [@paoloricciuti](https://github.com/paoloricciuti)!

## 7.6.5

- Angular: Update Angular cli templates - [#25152](https://github.com/storybookjs/storybook/pull/25152), thanks [@Marklb](https://github.com/Marklb)!
Expand Down
8 changes: 8 additions & 0 deletions CHANGELOG.prerelease.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,11 @@
## 8.0.0-alpha.5

- Core: Remove the `-s` flag from build & dev - [#25266](https://github.com/storybookjs/storybook/pull/25266), thanks [@ndelangen](https://github.com/ndelangen)!
- Core: Skip no-framework error when ignorePreview=true - [#25286](https://github.com/storybookjs/storybook/pull/25286), thanks [@ndelangen](https://github.com/ndelangen)!
- Core: Unique outputDir/cacheDir for each configDir - [#25264](https://github.com/storybookjs/storybook/pull/25264), thanks [@ndelangen](https://github.com/ndelangen)!
- Dependencies: Semver dependency fixes - [#25283](https://github.com/storybookjs/storybook/pull/25283), thanks [@ndelangen](https://github.com/ndelangen)!
- NextJS: Mock out `server-only` package for RSC - [#25263](https://github.com/storybookjs/storybook/pull/25263), thanks [@shilman](https://github.com/shilman)!

## 8.0.0-alpha.4

- API: Remove stories.json support - [#25236](https://github.com/storybookjs/storybook/pull/25236), thanks [@shilman](https://github.com/shilman)!
Expand Down
1 change: 0 additions & 1 deletion code/.eslintignore
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,5 @@ ember-output
!.babelrc.js
!.eslintrc.js
!.eslintrc-markdown.js
!.jest.config.js
!.storybook

23 changes: 7 additions & 16 deletions code/.eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,15 @@ module.exports = {
},
plugins: ['local-rules'],
rules: {
// remove as shared eslint has jest rules removed
'jest/no-standalone-expect': 'off',
'jest/no-done-callback': 'off',
'jest/no-deprecated-functions': 'off',

'eslint-comments/disable-enable-pair': ['error', { allowWholeFile: true }],
'eslint-comments/no-unused-disable': 'error',
'react-hooks/rules-of-hooks': 'off',
'import/extensions': 'off', // for mjs, we sometimes need extensions
'jest/no-done-callback': 'off',
'jsx-a11y/control-has-associated-label': 'off',
'@typescript-eslint/dot-notation': [
'error',
Expand All @@ -53,15 +57,7 @@ module.exports = {
},
},
{
files: [
'*.js',
'*.jsx',
'*.json',
'*.html',
'**/.storybook/*.ts',
'**/.storybook/*.tsx',
'setup-jest.ts',
],
files: ['*.js', '*.jsx', '*.json', '*.html', '**/.storybook/*.ts', '**/.storybook/*.tsx'],
parserOptions: {
project: null,
},
Expand Down Expand Up @@ -197,12 +193,6 @@ module.exports = {
'spaced-comment': 'off',
},
},
{
files: ['**/e2e-tests/**/*'],
rules: {
'jest/no-test-callback': 'off', // These aren't jest tests
},
},
{
files: ['**/builder-vite/input/iframe.html'],
rules: {
Expand All @@ -218,6 +208,7 @@ module.exports = {
},
{
files: ['**/*.ts', '!**/*.test.*', '!**/*.spec.*'],
excludedFiles: ['**/*.test.*', '**/*.mockdata.*'],
rules: {
'local-rules/no-uncategorized-errors': 'warn',
},
Expand Down
37 changes: 0 additions & 37 deletions code/__mocks__/fs-extra.js

This file was deleted.

40 changes: 40 additions & 0 deletions code/__mocks__/fs-extra.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
import { vi } from 'vitest';

// This is a custom function that our tests can use during setup to specify
// what the files on the "mock" filesystem should look like when any of the
// `fs` APIs are used.
let mockFiles = Object.create(null);

// eslint-disable-next-line no-underscore-dangle, @typescript-eslint/naming-convention
export function __setMockFiles(newMockFiles: Record<string, string | null>) {
mockFiles = newMockFiles;
}

// A custom version of `readdirSync` that reads from the special mocked out
// file list set via __setMockFiles
export const writeFile = vi.fn(async (filePath: string, content: string) => {
mockFiles[filePath] = content;
});
export const readFile = vi.fn(async (filePath: string) => mockFiles[filePath]);
export const readFileSync = vi.fn((filePath = '') => mockFiles[filePath]);
export const existsSync = vi.fn((filePath: string) => !!mockFiles[filePath]);
export const readJson = vi.fn((filePath = '') => JSON.parse(mockFiles[filePath]));
export const readJsonSync = vi.fn((filePath = '') => JSON.parse(mockFiles[filePath]));
export const lstatSync = vi.fn((filePath: string) => ({
isFile: () => !!mockFiles[filePath],
}));
export const writeJson = vi.fn((filePath, json, { spaces } = {}) => {
mockFiles[filePath] = JSON.stringify(json, null, spaces);
});

export default {
__setMockFiles,
writeFile,
readFile,
readFileSync,
existsSync,
readJson,
readJsonSync,
lstatSync,
writeJson,
};
4 changes: 3 additions & 1 deletion code/__mocks__/fs.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
const fs = jest.createMockFromModule('fs');
import { vi } from 'vitest';

const fs = vi.createMockFromModule('fs');

// This is a custom function that our tests can use during setup to specify
// what the files on the "mock" filesystem should look like when any of the
Expand Down
7 changes: 0 additions & 7 deletions code/addons/a11y/jest.config.js

This file was deleted.

15 changes: 8 additions & 7 deletions code/addons/a11y/src/a11yRunner.test.ts
Original file line number Diff line number Diff line change
@@ -1,22 +1,23 @@
import type { Mock } from 'vitest';
import { describe, beforeEach, it, expect, vi } from 'vitest';
import { addons } from '@storybook/preview-api';
import { EVENTS } from './constants';

jest.mock('@storybook/preview-api');
const mockedAddons = addons as jest.Mocked<typeof addons>;
vi.mock('@storybook/preview-api');
const mockedAddons = vi.mocked(addons);

describe('a11yRunner', () => {
let mockChannel: { on: jest.Mock; emit?: jest.Mock };
let mockChannel: { on: Mock; emit?: Mock };

beforeEach(() => {
mockedAddons.getChannel.mockReset();

mockChannel = { on: jest.fn(), emit: jest.fn() };
mockChannel = { on: vi.fn(), emit: vi.fn() };
mockedAddons.getChannel.mockReturnValue(mockChannel as any);
});

it('should listen to events', () => {
// eslint-disable-next-line global-require
require('./a11yRunner');
it('should listen to events', async () => {
await import('./a11yRunner');

expect(mockedAddons.getChannel).toHaveBeenCalled();
expect(mockChannel.on).toHaveBeenCalledWith(EVENTS.REQUEST, expect.any(Function));
Expand Down
41 changes: 24 additions & 17 deletions code/addons/a11y/src/components/A11YPanel.test.tsx
Original file line number Diff line number Diff line change
@@ -1,17 +1,18 @@
import { describe, beforeEach, afterEach, it, expect, vi } from 'vitest';
import React from 'react';
import { render, waitFor, fireEvent, act } from '@testing-library/react';
import { render, waitFor, fireEvent, act, cleanup } from '@testing-library/react';

import { ThemeProvider, themes, convert } from '@storybook/theming';
import * as api from '@storybook/manager-api';

import { A11YPanel } from './A11YPanel';
import { EVENTS } from '../constants';

jest.mock('@storybook/manager-api');
vi.mock('@storybook/manager-api');

global.ResizeObserver = require('resize-observer-polyfill');

const mockedApi = api as jest.Mocked<typeof api>;
const mockedApi = vi.mocked(api);

const axeResult = {
incomplete: [
Expand Down Expand Up @@ -67,14 +68,18 @@ describe('A11YPanel', () => {
mockedApi.useAddonState.mockReset();

mockedApi.useAddonState.mockImplementation((_, defaultState) => React.useState(defaultState));
mockedApi.useChannel.mockReturnValue(jest.fn());
mockedApi.useChannel.mockReturnValue(vi.fn());
mockedApi.useParameter.mockReturnValue({ manual: false });
const state: Partial<api.State> = { storyId: 'jest' };
// Lazy to mock entire state
mockedApi.useStorybookState.mockReturnValue(state as any);
mockedApi.useAddonState.mockImplementation(React.useState);
});

afterEach(() => {
cleanup();
});

it('should render', () => {
const { container } = render(<A11YPanel />);
expect(container.firstChild).toBeTruthy();
Expand All @@ -95,16 +100,27 @@ describe('A11YPanel', () => {
expect(getByText(/Initializing/)).toBeTruthy();
});

it('should handle "manual" status', async () => {
it('should set running status on event', async () => {
const { getByText } = render(<ThemedA11YPanel />);
const useChannelArgs = mockedApi.useChannel.mock.calls[0][0];
act(() => useChannelArgs[EVENTS.RUNNING]());
await waitFor(() => {
expect(getByText(/Please wait while the accessibility scan is running/)).toBeTruthy();
});
});

// TODO: The tests below are skipped because of unknown issues with ThemeProvider
// which cause errors like TypeError: Cannot read properties of undefined (reading 'defaultText')
it.skip('should handle "manual" status', async () => {
mockedApi.useParameter.mockReturnValue({ manual: true });
const { getByText } = render(<ThemedA11YPanel />);
await waitFor(() => {
expect(getByText(/Manually run the accessibility scan/)).toBeTruthy();
});
});

it('should handle "running" status', async () => {
const emit = jest.fn();
it.skip('should handle "running" status', async () => {
const emit = vi.fn();
mockedApi.useChannel.mockReturnValue(emit);
mockedApi.useParameter.mockReturnValue({ manual: true });
const { getByRole, getByText } = render(<ThemedA11YPanel />);
Expand All @@ -118,16 +134,7 @@ describe('A11YPanel', () => {
});
});

it('should set running status on event', async () => {
const { getByText } = render(<ThemedA11YPanel />);
const useChannelArgs = mockedApi.useChannel.mock.calls[0][0];
act(() => useChannelArgs[EVENTS.RUNNING]());
await waitFor(() => {
expect(getByText(/Please wait while the accessibility scan is running/)).toBeTruthy();
});
});

it('should handle "ran" status', async () => {
it.skip('should handle "ran" status', async () => {
const { getByText } = render(<ThemedA11YPanel />);
const useChannelArgs = mockedApi.useChannel.mock.calls[0][0];
act(() => useChannelArgs[EVENTS.RESULT](axeResult));
Expand Down
21 changes: 13 additions & 8 deletions code/addons/a11y/src/components/A11yContext.test.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,16 @@
import { describe, beforeEach, afterEach, it, expect, vi } from 'vitest';
import * as React from 'react';
import type { AxeResults } from 'axe-core';
import { render, act } from '@testing-library/react';
import { render, act, cleanup } from '@testing-library/react';
import * as api from '@storybook/manager-api';
import { STORY_CHANGED } from '@storybook/core-events';
import { HIGHLIGHT } from '@storybook/addon-highlight';

import { A11yContextProvider, useA11yContext } from './A11yContext';
import { EVENTS } from '../constants';

jest.mock('@storybook/manager-api');
const mockedApi = api as jest.Mocked<typeof api>;
vi.mock('@storybook/manager-api');
const mockedApi = vi.mocked(api);

const storyId = 'jest';
const axeResult: Partial<AxeResults> = {
Expand Down Expand Up @@ -51,14 +52,18 @@ const axeResult: Partial<AxeResults> = {
};

describe('A11YPanel', () => {
const getCurrentStoryData = jest.fn();
afterEach(() => {
cleanup();
});

const getCurrentStoryData = vi.fn();
beforeEach(() => {
mockedApi.useChannel.mockReset();
mockedApi.useStorybookApi.mockReset();
mockedApi.useAddonState.mockReset();

mockedApi.useAddonState.mockImplementation((_, defaultState) => React.useState(defaultState));
mockedApi.useChannel.mockReturnValue(jest.fn());
mockedApi.useChannel.mockReturnValue(vi.fn());
getCurrentStoryData.mockReset().mockReturnValue({ id: storyId, type: 'story' });
mockedApi.useStorybookApi.mockReturnValue({ getCurrentStoryData } as any);
});
Expand All @@ -73,7 +78,7 @@ describe('A11YPanel', () => {
});

it('should not render when inactive', () => {
const emit = jest.fn();
const emit = vi.fn();
mockedApi.useChannel.mockReturnValue(emit);
const { queryByTestId } = render(
<A11yContextProvider active={false}>
Expand All @@ -85,15 +90,15 @@ describe('A11YPanel', () => {
});

it('should emit request when moving from inactive to active', () => {
const emit = jest.fn();
const emit = vi.fn();
mockedApi.useChannel.mockReturnValue(emit);
const { rerender } = render(<A11yContextProvider active={false} />);
rerender(<A11yContextProvider active />);
expect(emit).toHaveBeenLastCalledWith(EVENTS.REQUEST, storyId);
});

it('should emit highlight with no values when inactive', () => {
const emit = jest.fn();
const emit = vi.fn();
mockedApi.useChannel.mockReturnValue(emit);
const { rerender } = render(<A11yContextProvider active />);
rerender(<A11yContextProvider active={false} />);
Expand Down
Loading