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

Try: Storybook stories for blocks #39584

Closed
wants to merge 10 commits into from
Closed

Conversation

mikachan
Copy link
Member

What? / Why?

This PR is an attempt to address an idea from the discussion in #39266 about improving the accessibility testing process for blocks.

#39437 is also a good attempt to improve this testing process, without using Storybook.

How?

I've added some functionality to the existing full-content test suite, which generates story files for each block at the same time as the test fixture files are generated. The stories are saved in storybook/stories/blocks which means they then appear in Storybook here:

image

I think some blocks need to be excluded from Storybook, e.g. the template pattern block. I've started to handle this by creating an excludedBlocks array, but I haven't got any further with this yet.

I'm not 100% convinced this is a good solution, but I thought I'd try it out anyway and share early for feedback.

My original reasoning behind this was:

  • Storybook provides us with a single page where the front end of each block is output. This gives us the option of using the Storybook page in any automated tests (using tools like jest-axe) and allows us to use it in manual testing.
  • We're already using the Storybook a11y add-on, so we can take advantage of that on blocks as well.

Some of my concerns are:

  • The stories aren't in the context of a theme, which is probably the ideal context for testing the front end blocks (see Automated a11y tests for rendered blocks #39437 for an example of this)
  • Some of the blocks aren't serialized into HTML markup, and only save as HTML comments. My original thinking was to add a wrapper/utility function that is able to interpret the comments and return the block output. If this sounds viable within Storybook, I think this could work well. If not, I think testing within the context of a theme is a better idea.
  • I'm not sure if all the blocks can be automatically generated from the fixtures successfully, as some may only work in the context of others (sub-blocks). As it stands, these would have to be created manually.
  • Considering the above point, it might be best to manually create all the stories, rather than automatically generating them..

Testing Instructions

  1. Run npm run fixtures:regenerate. The story files should be recreated successfully.
  2. Run npm run storybook:dev
  3. Visit the Storybook page and the Blocks should appear in the bottom of the left navigation (only the Blocks that return HTML markup will show in Storybook, 'audio' is the first alphabetically)

@mikachan mikachan added [Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). Storybook Storybook and its stories for components labels Mar 18, 2022
@mikachan mikachan self-assigned this Mar 18, 2022
@github-actions
Copy link

github-actions bot commented Mar 18, 2022

Size Change: +660 B (0%)

Total Size: 1.21 MB

Filename Size Change
build/block-editor/index.min.js 146 kB +31 B (0%)
build/block-library/blocks/pullquote/style-rtl.css 370 B -19 B (-5%)
build/block-library/blocks/pullquote/style.css 370 B -18 B (-5%)
build/block-library/blocks/separator/editor-rtl.css 140 B +41 B (+41%) 🚨
build/block-library/blocks/separator/editor.css 140 B +41 B (+41%) 🚨
build/block-library/blocks/separator/theme-rtl.css 194 B +22 B (+13%) ⚠️
build/block-library/blocks/separator/theme.css 194 B +22 B (+13%) ⚠️
build/block-library/editor-rtl.css 9.98 kB +15 B (0%)
build/block-library/editor.css 9.98 kB +13 B (0%)
build/block-library/index.min.js 169 kB +324 B (0%)
build/block-library/style-rtl.css 11.2 kB -9 B (0%)
build/block-library/style.css 11.2 kB -7 B (0%)
build/block-library/theme-rtl.css 689 B +24 B (+4%)
build/block-library/theme.css 694 B +24 B (+4%)
build/components/index.min.js 218 kB +79 B (0%)
build/core-data/index.min.js 14.3 kB +14 B (0%)
build/edit-site/index.min.js 44.9 kB +63 B (0%)
ℹ️ View Unchanged
Filename Size
build/a11y/index.min.js 993 B
build/admin-manifest/index.min.js 1.24 kB
build/annotations/index.min.js 2.77 kB
build/api-fetch/index.min.js 2.27 kB
build/autop/index.min.js 2.15 kB
build/blob/index.min.js 487 B
build/block-directory/index.min.js 6.49 kB
build/block-directory/style-rtl.css 1.01 kB
build/block-directory/style.css 1.01 kB
build/block-editor/default-editor-styles-rtl.css 378 B
build/block-editor/default-editor-styles.css 378 B
build/block-editor/style-rtl.css 15.1 kB
build/block-editor/style.css 15.1 kB
build/block-library/blocks/archives/editor-rtl.css 61 B
build/block-library/blocks/archives/editor.css 60 B
build/block-library/blocks/archives/style-rtl.css 65 B
build/block-library/blocks/archives/style.css 65 B
build/block-library/blocks/audio/editor-rtl.css 150 B
build/block-library/blocks/audio/editor.css 150 B
build/block-library/blocks/audio/style-rtl.css 111 B
build/block-library/blocks/audio/style.css 111 B
build/block-library/blocks/audio/theme-rtl.css 125 B
build/block-library/blocks/audio/theme.css 125 B
build/block-library/blocks/block/editor-rtl.css 161 B
build/block-library/blocks/block/editor.css 161 B
build/block-library/blocks/button/editor-rtl.css 445 B
build/block-library/blocks/button/editor.css 445 B
build/block-library/blocks/button/style-rtl.css 560 B
build/block-library/blocks/button/style.css 560 B
build/block-library/blocks/buttons/editor-rtl.css 292 B
build/block-library/blocks/buttons/editor.css 292 B
build/block-library/blocks/buttons/style-rtl.css 275 B
build/block-library/blocks/buttons/style.css 275 B
build/block-library/blocks/calendar/style-rtl.css 207 B
build/block-library/blocks/calendar/style.css 207 B
build/block-library/blocks/categories/editor-rtl.css 84 B
build/block-library/blocks/categories/editor.css 83 B
build/block-library/blocks/categories/style-rtl.css 79 B
build/block-library/blocks/categories/style.css 79 B
build/block-library/blocks/code/style-rtl.css 103 B
build/block-library/blocks/code/style.css 103 B
build/block-library/blocks/code/theme-rtl.css 124 B
build/block-library/blocks/code/theme.css 124 B
build/block-library/blocks/columns/editor-rtl.css 108 B
build/block-library/blocks/columns/editor.css 108 B
build/block-library/blocks/columns/style-rtl.css 406 B
build/block-library/blocks/columns/style.css 406 B
build/block-library/blocks/comment-author-avatar/editor-rtl.css 125 B
build/block-library/blocks/comment-author-avatar/editor.css 125 B
build/block-library/blocks/comment-template/style-rtl.css 127 B
build/block-library/blocks/comment-template/style.css 127 B
build/block-library/blocks/comments-pagination-numbers/editor-rtl.css 123 B
build/block-library/blocks/comments-pagination-numbers/editor.css 121 B
build/block-library/blocks/comments-pagination/editor-rtl.css 222 B
build/block-library/blocks/comments-pagination/editor.css 209 B
build/block-library/blocks/comments-pagination/style-rtl.css 235 B
build/block-library/blocks/comments-pagination/style.css 231 B
build/block-library/blocks/comments-query-loop/editor-rtl.css 95 B
build/block-library/blocks/comments-query-loop/editor.css 95 B
build/block-library/blocks/cover/editor-rtl.css 546 B
build/block-library/blocks/cover/editor.css 547 B
build/block-library/blocks/cover/style-rtl.css 1.56 kB
build/block-library/blocks/cover/style.css 1.56 kB
build/block-library/blocks/embed/editor-rtl.css 293 B
build/block-library/blocks/embed/editor.css 293 B
build/block-library/blocks/embed/style-rtl.css 417 B
build/block-library/blocks/embed/style.css 417 B
build/block-library/blocks/embed/theme-rtl.css 124 B
build/block-library/blocks/embed/theme.css 124 B
build/block-library/blocks/file/editor-rtl.css 300 B
build/block-library/blocks/file/editor.css 300 B
build/block-library/blocks/file/style-rtl.css 255 B
build/block-library/blocks/file/style.css 255 B
build/block-library/blocks/file/view.min.js 353 B
build/block-library/blocks/freeform/editor-rtl.css 2.44 kB
build/block-library/blocks/freeform/editor.css 2.44 kB
build/block-library/blocks/gallery/editor-rtl.css 961 B
build/block-library/blocks/gallery/editor.css 964 B
build/block-library/blocks/gallery/style-rtl.css 1.51 kB
build/block-library/blocks/gallery/style.css 1.51 kB
build/block-library/blocks/gallery/theme-rtl.css 122 B
build/block-library/blocks/gallery/theme.css 122 B
build/block-library/blocks/group/editor-rtl.css 159 B
build/block-library/blocks/group/editor.css 159 B
build/block-library/blocks/group/style-rtl.css 57 B
build/block-library/blocks/group/style.css 57 B
build/block-library/blocks/group/theme-rtl.css 78 B
build/block-library/blocks/group/theme.css 78 B
build/block-library/blocks/heading/style-rtl.css 114 B
build/block-library/blocks/heading/style.css 114 B
build/block-library/blocks/html/editor-rtl.css 332 B
build/block-library/blocks/html/editor.css 333 B
build/block-library/blocks/image/editor-rtl.css 731 B
build/block-library/blocks/image/editor.css 730 B
build/block-library/blocks/image/style-rtl.css 529 B
build/block-library/blocks/image/style.css 535 B
build/block-library/blocks/image/theme-rtl.css 124 B
build/block-library/blocks/image/theme.css 124 B
build/block-library/blocks/latest-comments/style-rtl.css 284 B
build/block-library/blocks/latest-comments/style.css 284 B
build/block-library/blocks/latest-posts/editor-rtl.css 199 B
build/block-library/blocks/latest-posts/editor.css 198 B
build/block-library/blocks/latest-posts/style-rtl.css 447 B
build/block-library/blocks/latest-posts/style.css 446 B
build/block-library/blocks/list/style-rtl.css 94 B
build/block-library/blocks/list/style.css 94 B
build/block-library/blocks/media-text/editor-rtl.css 266 B
build/block-library/blocks/media-text/editor.css 263 B
build/block-library/blocks/media-text/style-rtl.css 493 B
build/block-library/blocks/media-text/style.css 490 B
build/block-library/blocks/more/editor-rtl.css 431 B
build/block-library/blocks/more/editor.css 431 B
build/block-library/blocks/navigation-link/editor-rtl.css 708 B
build/block-library/blocks/navigation-link/editor.css 706 B
build/block-library/blocks/navigation-link/style-rtl.css 94 B
build/block-library/blocks/navigation-link/style.css 94 B
build/block-library/blocks/navigation-submenu/editor-rtl.css 299 B
build/block-library/blocks/navigation-submenu/editor.css 299 B
build/block-library/blocks/navigation-submenu/view.min.js 375 B
build/block-library/blocks/navigation/editor-rtl.css 2.03 kB
build/block-library/blocks/navigation/editor.css 2.04 kB
build/block-library/blocks/navigation/style-rtl.css 1.89 kB
build/block-library/blocks/navigation/style.css 1.88 kB
build/block-library/blocks/navigation/view.min.js 2.85 kB
build/block-library/blocks/nextpage/editor-rtl.css 395 B
build/block-library/blocks/nextpage/editor.css 395 B
build/block-library/blocks/page-list/editor-rtl.css 363 B
build/block-library/blocks/page-list/editor.css 363 B
build/block-library/blocks/page-list/style-rtl.css 175 B
build/block-library/blocks/page-list/style.css 175 B
build/block-library/blocks/paragraph/editor-rtl.css 157 B
build/block-library/blocks/paragraph/editor.css 157 B
build/block-library/blocks/paragraph/style-rtl.css 273 B
build/block-library/blocks/paragraph/style.css 273 B
build/block-library/blocks/post-author/style-rtl.css 175 B
build/block-library/blocks/post-author/style.css 176 B
build/block-library/blocks/post-comments-form/style-rtl.css 446 B
build/block-library/blocks/post-comments-form/style.css 446 B
build/block-library/blocks/post-comments/style-rtl.css 521 B
build/block-library/blocks/post-comments/style.css 521 B
build/block-library/blocks/post-excerpt/editor-rtl.css 73 B
build/block-library/blocks/post-excerpt/editor.css 73 B
build/block-library/blocks/post-excerpt/style-rtl.css 69 B
build/block-library/blocks/post-excerpt/style.css 69 B
build/block-library/blocks/post-featured-image/editor-rtl.css 721 B
build/block-library/blocks/post-featured-image/editor.css 721 B
build/block-library/blocks/post-featured-image/style-rtl.css 153 B
build/block-library/blocks/post-featured-image/style.css 153 B
build/block-library/blocks/post-template/editor-rtl.css 99 B
build/block-library/blocks/post-template/editor.css 98 B
build/block-library/blocks/post-template/style-rtl.css 323 B
build/block-library/blocks/post-template/style.css 323 B
build/block-library/blocks/post-terms/style-rtl.css 73 B
build/block-library/blocks/post-terms/style.css 73 B
build/block-library/blocks/post-title/style-rtl.css 80 B
build/block-library/blocks/post-title/style.css 80 B
build/block-library/blocks/preformatted/style-rtl.css 103 B
build/block-library/blocks/preformatted/style.css 103 B
build/block-library/blocks/pullquote/editor-rtl.css 198 B
build/block-library/blocks/pullquote/editor.css 198 B
build/block-library/blocks/pullquote/theme-rtl.css 167 B
build/block-library/blocks/pullquote/theme.css 167 B
build/block-library/blocks/query-pagination-numbers/editor-rtl.css 122 B
build/block-library/blocks/query-pagination-numbers/editor.css 121 B
build/block-library/blocks/query-pagination/editor-rtl.css 221 B
build/block-library/blocks/query-pagination/editor.css 211 B
build/block-library/blocks/query-pagination/style-rtl.css 234 B
build/block-library/blocks/query-pagination/style.css 231 B
build/block-library/blocks/query/editor-rtl.css 131 B
build/block-library/blocks/query/editor.css 132 B
build/block-library/blocks/quote/style-rtl.css 201 B
build/block-library/blocks/quote/style.css 201 B
build/block-library/blocks/quote/theme-rtl.css 223 B
build/block-library/blocks/quote/theme.css 226 B
build/block-library/blocks/read-more/style-rtl.css 132 B
build/block-library/blocks/read-more/style.css 132 B
build/block-library/blocks/rss/editor-rtl.css 202 B
build/block-library/blocks/rss/editor.css 204 B
build/block-library/blocks/rss/style-rtl.css 289 B
build/block-library/blocks/rss/style.css 288 B
build/block-library/blocks/search/editor-rtl.css 165 B
build/block-library/blocks/search/editor.css 165 B
build/block-library/blocks/search/style-rtl.css 397 B
build/block-library/blocks/search/style.css 398 B
build/block-library/blocks/search/theme-rtl.css 64 B
build/block-library/blocks/search/theme.css 64 B
build/block-library/blocks/separator/style-rtl.css 233 B
build/block-library/blocks/separator/style.css 233 B
build/block-library/blocks/shortcode/editor-rtl.css 474 B
build/block-library/blocks/shortcode/editor.css 474 B
build/block-library/blocks/site-logo/editor-rtl.css 759 B
build/block-library/blocks/site-logo/editor.css 759 B
build/block-library/blocks/site-logo/style-rtl.css 181 B
build/block-library/blocks/site-logo/style.css 181 B
build/block-library/blocks/site-tagline/editor-rtl.css 86 B
build/block-library/blocks/site-tagline/editor.css 86 B
build/block-library/blocks/site-title/editor-rtl.css 84 B
build/block-library/blocks/site-title/editor.css 84 B
build/block-library/blocks/social-link/editor-rtl.css 177 B
build/block-library/blocks/social-link/editor.css 177 B
build/block-library/blocks/social-links/editor-rtl.css 674 B
build/block-library/blocks/social-links/editor.css 673 B
build/block-library/blocks/social-links/style-rtl.css 1.37 kB
build/block-library/blocks/social-links/style.css 1.36 kB
build/block-library/blocks/spacer/editor-rtl.css 332 B
build/block-library/blocks/spacer/editor.css 332 B
build/block-library/blocks/spacer/style-rtl.css 48 B
build/block-library/blocks/spacer/style.css 48 B
build/block-library/blocks/table/editor-rtl.css 471 B
build/block-library/blocks/table/editor.css 472 B
build/block-library/blocks/table/style-rtl.css 481 B
build/block-library/blocks/table/style.css 481 B
build/block-library/blocks/table/theme-rtl.css 188 B
build/block-library/blocks/table/theme.css 188 B
build/block-library/blocks/tag-cloud/style-rtl.css 226 B
build/block-library/blocks/tag-cloud/style.css 227 B
build/block-library/blocks/template-part/editor-rtl.css 235 B
build/block-library/blocks/template-part/editor.css 235 B
build/block-library/blocks/template-part/theme-rtl.css 101 B
build/block-library/blocks/template-part/theme.css 101 B
build/block-library/blocks/text-columns/editor-rtl.css 95 B
build/block-library/blocks/text-columns/editor.css 95 B
build/block-library/blocks/text-columns/style-rtl.css 166 B
build/block-library/blocks/text-columns/style.css 166 B
build/block-library/blocks/verse/style-rtl.css 87 B
build/block-library/blocks/verse/style.css 87 B
build/block-library/blocks/video/editor-rtl.css 571 B
build/block-library/blocks/video/editor.css 572 B
build/block-library/blocks/video/style-rtl.css 173 B
build/block-library/blocks/video/style.css 173 B
build/block-library/blocks/video/theme-rtl.css 124 B
build/block-library/blocks/video/theme.css 124 B
build/block-library/common-rtl.css 934 B
build/block-library/common.css 932 B
build/block-library/reset-rtl.css 474 B
build/block-library/reset.css 474 B
build/block-serialization-default-parser/index.min.js 1.12 kB
build/block-serialization-spec-parser/index.min.js 2.83 kB
build/blocks/index.min.js 46.8 kB
build/components/style-rtl.css 15.6 kB
build/components/style.css 15.6 kB
build/compose/index.min.js 11.2 kB
build/customize-widgets/index.min.js 11.2 kB
build/customize-widgets/style-rtl.css 1.39 kB
build/customize-widgets/style.css 1.39 kB
build/data-controls/index.min.js 663 B
build/data/index.min.js 8.19 kB
build/date/index.min.js 31.9 kB
build/deprecated/index.min.js 518 B
build/dom-ready/index.min.js 336 B
build/dom/index.min.js 4.53 kB
build/edit-navigation/index.min.js 16.1 kB
build/edit-navigation/style-rtl.css 4.04 kB
build/edit-navigation/style.css 4.05 kB
build/edit-post/classic-rtl.css 546 B
build/edit-post/classic.css 547 B
build/edit-post/index.min.js 29.8 kB
build/edit-post/style-rtl.css 7.07 kB
build/edit-post/style.css 7.07 kB
build/edit-site/style-rtl.css 7.44 kB
build/edit-site/style.css 7.42 kB
build/edit-widgets/index.min.js 16.5 kB
build/edit-widgets/style-rtl.css 4.39 kB
build/edit-widgets/style.css 4.39 kB
build/editor/index.min.js 38.4 kB
build/editor/style-rtl.css 3.71 kB
build/editor/style.css 3.71 kB
build/element/index.min.js 4.29 kB
build/escape-html/index.min.js 548 B
build/format-library/index.min.js 6.62 kB
build/format-library/style-rtl.css 571 B
build/format-library/style.css 571 B
build/hooks/index.min.js 1.66 kB
build/html-entities/index.min.js 454 B
build/i18n/index.min.js 3.79 kB
build/is-shallow-equal/index.min.js 535 B
build/keyboard-shortcuts/index.min.js 1.83 kB
build/keycodes/index.min.js 1.41 kB
build/list-reusable-blocks/index.min.js 1.75 kB
build/list-reusable-blocks/style-rtl.css 838 B
build/list-reusable-blocks/style.css 838 B
build/media-utils/index.min.js 2.94 kB
build/notices/index.min.js 957 B
build/nux/index.min.js 2.12 kB
build/nux/style-rtl.css 751 B
build/nux/style.css 749 B
build/plugins/index.min.js 1.98 kB
build/preferences/index.min.js 1.2 kB
build/primitives/index.min.js 949 B
build/priority-queue/index.min.js 611 B
build/react-i18n/index.min.js 704 B
build/react-refresh-entry/index.min.js 8.44 kB
build/react-refresh-runtime/index.min.js 7.31 kB
build/redux-routine/index.min.js 2.69 kB
build/reusable-blocks/index.min.js 2.24 kB
build/reusable-blocks/style-rtl.css 256 B
build/reusable-blocks/style.css 256 B
build/rich-text/index.min.js 11.1 kB
build/server-side-render/index.min.js 1.61 kB
build/shortcode/index.min.js 1.52 kB
build/token-list/index.min.js 668 B
build/url/index.min.js 1.99 kB
build/vendors/react-dom.min.js 38.5 kB
build/vendors/react.min.js 4.34 kB
build/viewport/index.min.js 1.08 kB
build/warning/index.min.js 280 B
build/widgets/index.min.js 7.21 kB
build/widgets/style-rtl.css 1.16 kB
build/widgets/style.css 1.16 kB
build/wordcount/index.min.js 1.07 kB

compressed-size-action

@mikachan
Copy link
Member Author

I've just heard about @youknowriad's BlockBook, which I think is basically what I was aiming for here!

@youknowriad
Copy link
Contributor

yes, It needs some polishing (and updating, it's now a bit outdated) but yeah I think it would be great to integrate it here. Here's an old issue where I propose to do that. #24152

@matiasbenedetto
Copy link
Contributor

matiasbenedetto commented Mar 18, 2022

👋 I like the use of Storybook here, I think could be a nice debugging tool for manual testing!

I'm not sure if I missing any steps but I'm getting errors when I want to run storybook locally.
I'm doing this:
git checkout try/storybook-for-blocks
npm install
npm run fixtures:regenerate
npm run storybook:dev

and I'm getting this:

[1] ModuleBuildError: Module build failed (from ./node_modules/babel-loader/lib/index.js):
[1] SyntaxError: /home/matias/dev/a8c-projects/gutenberg2/storybook/stories/blocks/core__gallery__deprecated-5.js: Unexpected token (10:30)
[1] 
[1]    8 | };
[1]    9 |
[1] > 10 | export const _default = () => return <div dangerouslySetInnerHTML={ { __html: core__gallery__deprecated_5 } }></div>;
[1]      |                               ^
[1]     at Object._raise (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:541:17)
[1]     at Object.raiseWithData (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:534:17)
[1]     at Object.raise (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:495:17)
[1]     at Object.unexpected (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:3560:16)
[1]     at Object.parseExprAtom (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:11980:22)
[1]     at Object.parseExprAtom (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:7463:20)
[1]     at Object.parseExprSubscripts (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:11541:23)
[1]     at Object.parseUpdate (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:11521:21)
[1]     at Object.parseMaybeUnary (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:11496:23)
[1]     at Object.parseMaybeUnaryOrPrivate (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:11310:61)
[1]     at Object.parseExprOps (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:11317:23)
[1]     at Object.parseMaybeConditional (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:11287:23)
[1]     at Object.parseMaybeAssign (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:11250:21)
[1]     at Object.parseMaybeAssign (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:6096:18)
[1]     at Object.parseFunctionBody (/home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:12721:24)
[1]     at /home/matias/dev/a8c-projects/gutenberg2/node_modules/@babel/parser/lib/index.js:5259:70
[1]     at processResult (/home/matias/dev/a8c-projects/gutenberg2/node_modules/webpack/lib/NormalModule.js:751:19)
[1]     at /home/matias/dev/a8c-projects/gutenberg2/node_modules/webpack/lib/NormalModule.js:853:5
[1]     at /home/matias/dev/a8c-projects/gutenberg2/node_modules/webpack/node_modules/loader-runner/lib/LoaderRunner.js:399:11
[1]     at /home/matias/dev/a8c-projects/gutenberg2/node_modules/webpack/node_modules/loader-runner/lib/LoaderRunner.js:251:18
[1]     at context.callback (/home/matias/dev/a8c-projects/gutenberg2/node_modules/webpack/node_modules/loader-runner/lib/LoaderRunner.js:124:13)
[1]     at /home/matias/dev/a8c-projects/gutenberg2/node_modules/babel-loader/lib/index.js:59:103
[1] WARN Broken build, fix the error above.
[1] WARN You may need to refresh the browser.
[1] start-storybook -c ./storybook -p 50240 exited with code 1

@mikachan
Copy link
Member Author

I'm not sure if I missing any steps but I'm getting errors when I want to run storybook locally.

Looks like I introduced an eslint error in the story files! Does it work for you with the last commit?

@matiasbenedetto
Copy link
Contributor

I'm not sure if I missing any steps but I'm getting errors when I want to run storybook locally.

Looks like I introduced an eslint error in the story files! Does it work for you with the last commit?

Yep! it's running fine now. 😺

As I said I think the use of storybook seems useful for manual testing but I think it doesn't seem to solve the automated report of a11y problems.

Apart from that, I think there is a bigger challenge related to getting the final render of the block, especially the ones that involve server-side rendering that I think is missing here. I explored that issue and I think there is no easy way to get that apart from spinning up WordPress and actually rendering the blocks as we are doing here.

@mikachan
Copy link
Member Author

As I said I think the use of storybook seems useful for manual testing but I think it doesn't seem to solve the automated report of a11y problems.

My thinking was that we could use the Storybook URL as the target for automated tests, using a tool like jest-axe.

Apart from that, I think there is a bigger challenge related to getting the final render of the block, especially the ones that involve server-side rendering that I think is missing here.

Yes, exactly! I think for the next steps I'd like to take a look at how BlockBook integrates themes (this already uses Twenty Nineteen and Twenty Twenty), and progress #24152 if possible.

@mikachan mikachan closed this Jan 6, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). Storybook Storybook and its stories for components
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants