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

Upgrade Ariakit #64066

Merged
merged 26 commits into from
Aug 1, 2024
Merged

Upgrade Ariakit #64066

merged 26 commits into from
Aug 1, 2024

Conversation

DaniGuardiola
Copy link
Contributor

@DaniGuardiola DaniGuardiola commented Jul 29, 2024

Continuation of #62947 (dependencies got messed up)

To do

Besides upgrading to the latest version and fixing all remaining failed tests, there are some other items to complete.

  • Smoke test.
  • Ensure that the animation change doesn't affect other components other than custom-select-control, custom-select-control-v2 and dropdown-menu-v2.
  • Add relevant changelog entries.
  • Tooltip aria-describedBy changes: add temporary compatibility fix and revert test changes.
  • Contribute render changes to upstream @ariakit/test (returning rerender from the output of the wrapped ReactTestingLibrary.render). See Output rerender from @ariakit/test's render. ariakit/ariakit#3981
  • Remove local temporary fork of @ariakit/test's render function.
  • Discuss idea: enforce @ariakit/test's render and user events in all components package tests? (e.g. noRestrictedImports)
    • Resolution: enforce in a follow-up PR.
  • Discuss: "aria-describedBy" in tooltip anchors (context)
    • Resolution: add a temporary compatibility fix for now, then in the future do a pass to check if any labels need to be added, and document in the changelog and potentially a dev note.

History by version (unit tests)

v0.3.x (from v0.3.13)

At v0.3.13, tests fail:

image

The reason is tests need to give some components a bit more time to render since Ariakit uses some timers under the hood. Fixed (e52022c) by replacing RTL's render with @ariakit/test's render - including the local temporary fork with rerender support (ffe7928).

After addressing, all tests pass in all v0.3.x versions.

image

0.4.x

image

This diff from the previous PR has information about all root causes for test failures.

Essentially, we're impacted by three Ariakit changes in v0.4.0:

After addressing, all tests pass between v0.4.0 and v0.4.5.

0.4.6 (287c22f, failing tests, fixed in 27218de)

In this version, there are 3-5 new test failures (2 seem to be flaky):

image

Similarly to the render wait issues, this is due to not properly waiting for some internal timers to complete. This can be remediated by replacing RTL's event triggers with ones from @ariakit/test.

After addressing (27218de), all tests pass in this version.

0.4.7 - latest (94deccd)

All tests pass and we're on latest now! 🎉

Follow-ups

These are tasks to be done after this PR lands. I'm adding stuff that seems to have some consensus here, and unless I hear different I plan to go through with them. Please speak up if you have any arguments against these decisions! For more context on some of these, look for "resolution" notes in the "To do" section.

Copy link

github-actions bot commented Jul 29, 2024

Size Change: +6.79 kB (+0.39%)

Total Size: 1.77 MB

Filename Size Change
build/block-editor/content-rtl.css 4.56 kB -35 B (-0.76%)
build/block-editor/content.css 4.56 kB -34 B (-0.74%)
build/block-editor/index.min.js 255 kB +1.03 kB (+0.41%)
build/block-editor/style-rtl.css 16.3 kB +132 B (+0.82%)
build/block-editor/style.css 16.3 kB +133 B (+0.82%)
build/block-library/blocks/group/editor-rtl.css 344 B -58 B (-14.43%) 👏
build/block-library/blocks/group/editor.css 344 B -58 B (-14.43%) 👏
build/block-library/blocks/image/editor-rtl.css 894 B +32 B (+3.71%)
build/block-library/blocks/image/editor.css 892 B +31 B (+3.6%)
build/block-library/blocks/navigation/editor-rtl.css 2.18 kB -21 B (-0.95%)
build/block-library/blocks/navigation/editor.css 2.19 kB -19 B (-0.86%)
build/block-library/blocks/post-excerpt/style-rtl.css 155 B +14 B (+9.93%) ⚠️
build/block-library/blocks/post-excerpt/style.css 155 B +14 B (+9.93%) ⚠️
build/block-library/blocks/site-title/style-rtl.css 90 B +19 B (+26.76%) 🚨
build/block-library/blocks/site-title/style.css 90 B +19 B (+26.76%) 🚨
build/block-library/editor-rtl.css 11.9 kB -15 B (-0.13%)
build/block-library/editor.css 11.9 kB -17 B (-0.14%)
build/block-library/index.min.js 217 kB +729 B (+0.34%)
build/block-library/style-rtl.css 14.7 kB +37 B (+0.25%)
build/block-library/style.css 14.7 kB +37 B (+0.25%)
build/blocks/index.min.js 52.3 kB +30 B (+0.06%)
build/components/index.min.js 224 kB +2 kB (+0.9%)
build/components/style-rtl.css 12.1 kB +105 B (+0.88%)
build/components/style.css 12.1 kB +108 B (+0.9%)
build/core-data/index.min.js 73.1 kB +8 B (+0.01%)
build/edit-site/index.min.js 215 kB +1.55 kB (+0.73%)
build/edit-site/posts-rtl.css 6.84 kB +47 B (+0.69%)
build/edit-site/posts.css 6.85 kB +47 B (+0.69%)
build/edit-site/style-rtl.css 12.2 kB +188 B (+1.57%)
build/edit-site/style.css 12.2 kB +190 B (+1.58%)
build/edit-widgets/index.min.js 17.7 kB +14 B (+0.08%)
build/editor/index.min.js 99.7 kB +145 B (+0.15%)
build/editor/style-rtl.css 9.34 kB +14 B (+0.15%)
build/editor/style.css 9.33 kB +13 B (+0.14%)
build/format-library/index.min.js 8.07 kB +3 B (+0.04%)
build/format-library/style-rtl.css 476 B -30 B (-5.93%)
build/format-library/style.css 476 B -29 B (-5.74%)
build/block-library/blocks/loginout/style-rtl.css 61 B +61 B (new file) 🆕
build/block-library/blocks/loginout/style.css 61 B +61 B (new file) 🆕
build/block-library/blocks/post-content/style-rtl.css 79 B +79 B (new file) 🆕
build/block-library/blocks/post-content/style.css 79 B +79 B (new file) 🆕
build/block-library/blocks/site-tagline/style-rtl.css 65 B +65 B (new file) 🆕
build/block-library/blocks/site-tagline/style.css 65 B +65 B (new file) 🆕
ℹ️ View Unchanged
Filename Size
build/a11y/index.min.js 951 B
build/annotations/index.min.js 2.26 kB
build/api-fetch/index.min.js 2.31 kB
build/autop/index.min.js 2.12 kB
build/blob/index.min.js 579 B
build/block-directory/index.min.js 7.29 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 394 B
build/block-editor/default-editor-styles.css 394 B
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 90 B
build/block-library/blocks/archives/style.css 90 B
build/block-library/blocks/audio/editor-rtl.css 149 B
build/block-library/blocks/audio/editor.css 151 B
build/block-library/blocks/audio/style-rtl.css 132 B
build/block-library/blocks/audio/style.css 132 B
build/block-library/blocks/audio/theme-rtl.css 134 B
build/block-library/blocks/audio/theme.css 134 B
build/block-library/blocks/avatar/editor-rtl.css 115 B
build/block-library/blocks/avatar/editor.css 115 B
build/block-library/blocks/avatar/style-rtl.css 104 B
build/block-library/blocks/avatar/style.css 104 B
build/block-library/blocks/button/editor-rtl.css 310 B
build/block-library/blocks/button/editor.css 310 B
build/block-library/blocks/button/style-rtl.css 538 B
build/block-library/blocks/button/style.css 538 B
build/block-library/blocks/buttons/editor-rtl.css 336 B
build/block-library/blocks/buttons/editor.css 336 B
build/block-library/blocks/buttons/style-rtl.css 328 B
build/block-library/blocks/buttons/style.css 328 B
build/block-library/blocks/calendar/style-rtl.css 240 B
build/block-library/blocks/calendar/style.css 240 B
build/block-library/blocks/categories/editor-rtl.css 132 B
build/block-library/blocks/categories/editor.css 131 B
build/block-library/blocks/categories/style-rtl.css 152 B
build/block-library/blocks/categories/style.css 152 B
build/block-library/blocks/code/editor-rtl.css 53 B
build/block-library/blocks/code/editor.css 53 B
build/block-library/blocks/code/style-rtl.css 121 B
build/block-library/blocks/code/style.css 121 B
build/block-library/blocks/code/theme-rtl.css 122 B
build/block-library/blocks/code/theme.css 122 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 420 B
build/block-library/blocks/columns/style.css 420 B
build/block-library/blocks/comment-author-avatar/editor-rtl.css 124 B
build/block-library/blocks/comment-author-avatar/editor.css 124 B
build/block-library/blocks/comment-content/style-rtl.css 90 B
build/block-library/blocks/comment-content/style.css 90 B
build/block-library/blocks/comment-template/style-rtl.css 200 B
build/block-library/blocks/comment-template/style.css 199 B
build/block-library/blocks/comments-pagination-numbers/editor-rtl.css 122 B
build/block-library/blocks/comments-pagination-numbers/editor.css 121 B
build/block-library/blocks/comments-pagination/editor-rtl.css 221 B
build/block-library/blocks/comments-pagination/editor.css 211 B
build/block-library/blocks/comments-pagination/style-rtl.css 234 B
build/block-library/blocks/comments-pagination/style.css 231 B
build/block-library/blocks/comments-title/editor-rtl.css 75 B
build/block-library/blocks/comments-title/editor.css 75 B
build/block-library/blocks/comments/editor-rtl.css 832 B
build/block-library/blocks/comments/editor.css 832 B
build/block-library/blocks/comments/style-rtl.css 632 B
build/block-library/blocks/comments/style.css 631 B
build/block-library/blocks/cover/editor-rtl.css 668 B
build/block-library/blocks/cover/editor.css 669 B
build/block-library/blocks/cover/style-rtl.css 1.62 kB
build/block-library/blocks/cover/style.css 1.6 kB
build/block-library/blocks/details/editor-rtl.css 65 B
build/block-library/blocks/details/editor.css 65 B
build/block-library/blocks/details/style-rtl.css 86 B
build/block-library/blocks/details/style.css 86 B
build/block-library/blocks/embed/editor-rtl.css 314 B
build/block-library/blocks/embed/editor.css 314 B
build/block-library/blocks/embed/style-rtl.css 419 B
build/block-library/blocks/embed/style.css 419 B
build/block-library/blocks/embed/theme-rtl.css 133 B
build/block-library/blocks/embed/theme.css 133 B
build/block-library/blocks/file/editor-rtl.css 326 B
build/block-library/blocks/file/editor.css 326 B
build/block-library/blocks/file/style-rtl.css 278 B
build/block-library/blocks/file/style.css 279 B
build/block-library/blocks/file/view.min.js 324 B
build/block-library/blocks/footnotes/style-rtl.css 198 B
build/block-library/blocks/footnotes/style.css 197 B
build/block-library/blocks/form-input/editor-rtl.css 229 B
build/block-library/blocks/form-input/editor.css 229 B
build/block-library/blocks/form-input/style-rtl.css 342 B
build/block-library/blocks/form-input/style.css 342 B
build/block-library/blocks/form-submission-notification/editor-rtl.css 344 B
build/block-library/blocks/form-submission-notification/editor.css 341 B
build/block-library/blocks/form-submit-button/style-rtl.css 69 B
build/block-library/blocks/form-submit-button/style.css 69 B
build/block-library/blocks/form/view.min.js 470 B
build/block-library/blocks/freeform/editor-rtl.css 2.6 kB
build/block-library/blocks/freeform/editor.css 2.6 kB
build/block-library/blocks/gallery/editor-rtl.css 955 B
build/block-library/blocks/gallery/editor.css 958 B
build/block-library/blocks/gallery/style-rtl.css 1.71 kB
build/block-library/blocks/gallery/style.css 1.71 kB
build/block-library/blocks/gallery/theme-rtl.css 108 B
build/block-library/blocks/gallery/theme.css 108 B
build/block-library/blocks/group/style-rtl.css 103 B
build/block-library/blocks/group/style.css 103 B
build/block-library/blocks/group/theme-rtl.css 79 B
build/block-library/blocks/group/theme.css 79 B
build/block-library/blocks/heading/style-rtl.css 188 B
build/block-library/blocks/heading/style.css 188 B
build/block-library/blocks/html/editor-rtl.css 346 B
build/block-library/blocks/html/editor.css 347 B
build/block-library/blocks/image/style-rtl.css 1.59 kB
build/block-library/blocks/image/style.css 1.59 kB
build/block-library/blocks/image/theme-rtl.css 137 B
build/block-library/blocks/image/theme.css 137 B
build/block-library/blocks/image/view.min.js 1.65 kB
build/block-library/blocks/latest-comments/style-rtl.css 355 B
build/block-library/blocks/latest-comments/style.css 354 B
build/block-library/blocks/latest-posts/editor-rtl.css 186 B
build/block-library/blocks/latest-posts/editor.css 183 B
build/block-library/blocks/latest-posts/style-rtl.css 509 B
build/block-library/blocks/latest-posts/style.css 510 B
build/block-library/blocks/list/style-rtl.css 107 B
build/block-library/blocks/list/style.css 107 B
build/block-library/blocks/media-text/editor-rtl.css 304 B
build/block-library/blocks/media-text/editor.css 303 B
build/block-library/blocks/media-text/style-rtl.css 516 B
build/block-library/blocks/media-text/style.css 515 B
build/block-library/blocks/more/editor-rtl.css 427 B
build/block-library/blocks/more/editor.css 427 B
build/block-library/blocks/navigation-link/editor-rtl.css 663 B
build/block-library/blocks/navigation-link/editor.css 664 B
build/block-library/blocks/navigation-link/style-rtl.css 192 B
build/block-library/blocks/navigation-link/style.css 191 B
build/block-library/blocks/navigation-submenu/editor-rtl.css 295 B
build/block-library/blocks/navigation-submenu/editor.css 294 B
build/block-library/blocks/navigation/style-rtl.css 2.25 kB
build/block-library/blocks/navigation/style.css 2.23 kB
build/block-library/blocks/navigation/view.min.js 1.03 kB
build/block-library/blocks/nextpage/editor-rtl.css 392 B
build/block-library/blocks/nextpage/editor.css 392 B
build/block-library/blocks/page-list/editor-rtl.css 378 B
build/block-library/blocks/page-list/editor.css 378 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 236 B
build/block-library/blocks/paragraph/editor.css 236 B
build/block-library/blocks/paragraph/style-rtl.css 341 B
build/block-library/blocks/paragraph/style.css 340 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/editor-rtl.css 96 B
build/block-library/blocks/post-comments-form/editor.css 96 B
build/block-library/blocks/post-comments-form/style-rtl.css 527 B
build/block-library/blocks/post-comments-form/style.css 528 B
build/block-library/blocks/post-content/editor-rtl.css 74 B
build/block-library/blocks/post-content/editor.css 74 B
build/block-library/blocks/post-date/style-rtl.css 62 B
build/block-library/blocks/post-date/style.css 62 B
build/block-library/blocks/post-excerpt/editor-rtl.css 71 B
build/block-library/blocks/post-excerpt/editor.css 71 B
build/block-library/blocks/post-featured-image/editor-rtl.css 729 B
build/block-library/blocks/post-featured-image/editor.css 726 B
build/block-library/blocks/post-featured-image/style-rtl.css 341 B
build/block-library/blocks/post-featured-image/style.css 341 B
build/block-library/blocks/post-navigation-link/style-rtl.css 215 B
build/block-library/blocks/post-navigation-link/style.css 214 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 399 B
build/block-library/blocks/post-template/style.css 398 B
build/block-library/blocks/post-terms/style-rtl.css 96 B
build/block-library/blocks/post-terms/style.css 96 B
build/block-library/blocks/post-time-to-read/style-rtl.css 70 B
build/block-library/blocks/post-time-to-read/style.css 70 B
build/block-library/blocks/post-title/style-rtl.css 100 B
build/block-library/blocks/post-title/style.css 100 B
build/block-library/blocks/preformatted/style-rtl.css 125 B
build/block-library/blocks/preformatted/style.css 125 B
build/block-library/blocks/pullquote/editor-rtl.css 134 B
build/block-library/blocks/pullquote/editor.css 134 B
build/block-library/blocks/pullquote/style-rtl.css 342 B
build/block-library/blocks/pullquote/style.css 342 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 121 B
build/block-library/blocks/query-pagination-numbers/editor.css 118 B
build/block-library/blocks/query-pagination/editor-rtl.css 220 B
build/block-library/blocks/query-pagination/editor.css 208 B
build/block-library/blocks/query-pagination/style-rtl.css 287 B
build/block-library/blocks/query-pagination/style.css 283 B
build/block-library/blocks/query-title/style-rtl.css 64 B
build/block-library/blocks/query-title/style.css 64 B
build/block-library/blocks/query/editor-rtl.css 452 B
build/block-library/blocks/query/editor.css 451 B
build/block-library/blocks/query/view.min.js 958 B
build/block-library/blocks/quote/style-rtl.css 238 B
build/block-library/blocks/quote/style.css 238 B
build/block-library/blocks/quote/theme-rtl.css 221 B
build/block-library/blocks/quote/theme.css 225 B
build/block-library/blocks/read-more/style-rtl.css 138 B
build/block-library/blocks/read-more/style.css 138 B
build/block-library/blocks/rss/editor-rtl.css 101 B
build/block-library/blocks/rss/editor.css 101 B
build/block-library/blocks/rss/style-rtl.css 288 B
build/block-library/blocks/rss/style.css 287 B
build/block-library/blocks/search/editor-rtl.css 193 B
build/block-library/blocks/search/editor.css 193 B
build/block-library/blocks/search/style-rtl.css 672 B
build/block-library/blocks/search/style.css 671 B
build/block-library/blocks/search/theme-rtl.css 113 B
build/block-library/blocks/search/theme.css 113 B
build/block-library/blocks/search/view.min.js 475 B
build/block-library/blocks/separator/editor-rtl.css 100 B
build/block-library/blocks/separator/editor.css 100 B
build/block-library/blocks/separator/style-rtl.css 248 B
build/block-library/blocks/separator/style.css 248 B
build/block-library/blocks/separator/theme-rtl.css 195 B
build/block-library/blocks/separator/theme.css 195 B
build/block-library/blocks/shortcode/editor-rtl.css 286 B
build/block-library/blocks/shortcode/editor.css 286 B
build/block-library/blocks/site-logo/editor-rtl.css 806 B
build/block-library/blocks/site-logo/editor.css 803 B
build/block-library/blocks/site-logo/style-rtl.css 218 B
build/block-library/blocks/site-logo/style.css 218 B
build/block-library/blocks/site-tagline/editor-rtl.css 87 B
build/block-library/blocks/site-tagline/editor.css 87 B
build/block-library/blocks/site-title/editor-rtl.css 123 B
build/block-library/blocks/site-title/editor.css 123 B
build/block-library/blocks/social-link/editor-rtl.css 338 B
build/block-library/blocks/social-link/editor.css 338 B
build/block-library/blocks/social-links/editor-rtl.css 676 B
build/block-library/blocks/social-links/editor.css 675 B
build/block-library/blocks/social-links/style-rtl.css 1.51 kB
build/block-library/blocks/social-links/style.css 1.5 kB
build/block-library/blocks/spacer/editor-rtl.css 346 B
build/block-library/blocks/spacer/editor.css 346 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-of-contents/style-rtl.css 83 B
build/block-library/blocks/table-of-contents/style.css 83 B
build/block-library/blocks/table/editor-rtl.css 394 B
build/block-library/blocks/table/editor.css 394 B
build/block-library/blocks/table/style-rtl.css 640 B
build/block-library/blocks/table/style.css 639 B
build/block-library/blocks/table/theme-rtl.css 152 B
build/block-library/blocks/table/theme.css 152 B
build/block-library/blocks/tag-cloud/editor-rtl.css 63 B
build/block-library/blocks/tag-cloud/editor.css 63 B
build/block-library/blocks/tag-cloud/style-rtl.css 266 B
build/block-library/blocks/tag-cloud/style.css 265 B
build/block-library/blocks/template-part/editor-rtl.css 393 B
build/block-library/blocks/template-part/editor.css 393 B
build/block-library/blocks/template-part/theme-rtl.css 113 B
build/block-library/blocks/template-part/theme.css 113 B
build/block-library/blocks/term-description/style-rtl.css 126 B
build/block-library/blocks/term-description/style.css 126 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 165 B
build/block-library/blocks/text-columns/style.css 165 B
build/block-library/blocks/verse/style-rtl.css 98 B
build/block-library/blocks/verse/style.css 98 B
build/block-library/blocks/video/editor-rtl.css 541 B
build/block-library/blocks/video/editor.css 542 B
build/block-library/blocks/video/style-rtl.css 192 B
build/block-library/blocks/video/style.css 192 B
build/block-library/blocks/video/theme-rtl.css 134 B
build/block-library/blocks/video/theme.css 134 B
build/block-library/classic-rtl.css 179 B
build/block-library/classic.css 179 B
build/block-library/common-rtl.css 1.1 kB
build/block-library/common.css 1.1 kB
build/block-library/editor-elements-rtl.css 75 B
build/block-library/editor-elements.css 75 B
build/block-library/elements-rtl.css 54 B
build/block-library/elements.css 54 B
build/block-library/reset-rtl.css 472 B
build/block-library/reset.css 472 B
build/block-library/theme-rtl.css 702 B
build/block-library/theme.css 707 B
build/block-serialization-default-parser/index.min.js 1.12 kB
build/block-serialization-spec-parser/index.min.js 2.87 kB
build/commands/index.min.js 16.1 kB
build/commands/style-rtl.css 955 B
build/commands/style.css 952 B
build/compose/index.min.js 12.9 kB
build/core-commands/index.min.js 2.81 kB
build/customize-widgets/index.min.js 11 kB
build/customize-widgets/style-rtl.css 1.35 kB
build/customize-widgets/style.css 1.35 kB
build/data-controls/index.min.js 641 B
build/data/index.min.js 8.98 kB
build/date/index.min.js 18 kB
build/deprecated/index.min.js 458 B
build/dom-ready/index.min.js 325 B
build/dom/index.min.js 4.65 kB
build/edit-post/classic-rtl.css 578 B
build/edit-post/classic.css 580 B
build/edit-post/index.min.js 12.6 kB
build/edit-post/style-rtl.css 2.31 kB
build/edit-post/style.css 2.31 kB
build/edit-widgets/style-rtl.css 4.2 kB
build/edit-widgets/style.css 4.2 kB
build/element/index.min.js 4.83 kB
build/escape-html/index.min.js 537 B
build/hooks/index.min.js 1.54 kB
build/html-entities/index.min.js 445 B
build/i18n/index.min.js 3.58 kB
build/interactivity/debug.min.js 16.5 kB
build/interactivity/file.min.js 447 B
build/interactivity/image.min.js 1.78 kB
build/interactivity/index.min.js 13.4 kB
build/interactivity/navigation.min.js 1.16 kB
build/interactivity/query.min.js 742 B
build/interactivity/router.min.js 2.8 kB
build/interactivity/search.min.js 615 B
build/is-shallow-equal/index.min.js 526 B
build/keyboard-shortcuts/index.min.js 1.31 kB
build/keycodes/index.min.js 1.46 kB
build/list-reusable-blocks/index.min.js 2.16 kB
build/list-reusable-blocks/style-rtl.css 846 B
build/list-reusable-blocks/style.css 846 B
build/media-utils/index.min.js 2.92 kB
build/modules/importmap-polyfill.min.js 12.3 kB
build/notices/index.min.js 946 B
build/nux/index.min.js 1.59 kB
build/nux/style-rtl.css 749 B
build/nux/style.css 745 B
build/patterns/index.min.js 7.36 kB
build/patterns/style-rtl.css 687 B
build/patterns/style.css 685 B
build/plugins/index.min.js 1.81 kB
build/preferences-persistence/index.min.js 2.06 kB
build/preferences/index.min.js 2.9 kB
build/preferences/style-rtl.css 554 B
build/preferences/style.css 554 B
build/primitives/index.min.js 829 B
build/priority-queue/index.min.js 1.54 kB
build/private-apis/index.min.js 1.01 kB
build/react-i18n/index.min.js 630 B
build/react-refresh-entry/index.min.js 9.47 kB
build/react-refresh-runtime/index.min.js 6.76 kB
build/redux-routine/index.min.js 2.69 kB
build/reusable-blocks/index.min.js 2.54 kB
build/reusable-blocks/style-rtl.css 256 B
build/reusable-blocks/style.css 256 B
build/rich-text/index.min.js 10.1 kB
build/router/index.min.js 1.96 kB
build/server-side-render/index.min.js 1.94 kB
build/shortcode/index.min.js 1.4 kB
build/style-engine/index.min.js 2.03 kB
build/token-list/index.min.js 581 B
build/url/index.min.js 3.85 kB
build/vendors/react-dom.min.js 41.7 kB
build/vendors/react-jsx-runtime.min.js 560 B
build/vendors/react.min.js 4.02 kB
build/viewport/index.min.js 965 B
build/warning/index.min.js 250 B
build/widgets/index.min.js 7.19 kB
build/widgets/style-rtl.css 1.16 kB
build/widgets/style.css 1.16 kB
build/wordcount/index.min.js 1.03 kB

compressed-size-action

@DaniGuardiola
Copy link
Contributor Author

This was kind of a PITA to pull off, since it required reverting the lockfile, doing a distclean, installing deps, checking the lockfile to manually verify that the right version was installed (thanks npm), building, and then running all tests. For every, single, version.

I was extremely careful in double checking that the fixes take the expected effect and everything looks correct. This allowed me to figure out when the mistery new test failures come, and that's at version v0.4.6. Will be working on those next, until we're at latest (v0.4.7).

Please @WordPress/gutenberg-components read through the new, much shorter description since we need to discuss some last details and I would also appreciate some help with testing and generally making sure I didn't miss anything important.

@ciampo
Copy link
Contributor

ciampo commented Jul 30, 2024

Thank you, Dani!

As mentioned in #62947, we should probably look at cleaning up the custom render utility that was added in Composite (and in general, any other workarounds that could be removed with the updated render function)

Discuss idea: enforce @ariakit/test's render in all components package tests? (e.g. noRestrictedImports)

That could be a way to improve the devX in the components package (I'm always in favor of consistency).

But we should also consider consumers of the components package (both other Gutenberg packages, and third-party consumers), who may end up struggling with the same failures. How can we help them? Considering that ariakit is considered an implementation detail, should we still point them at @ariakit/test ? Should we instead offer a render function as part of some Gutenberg testing utils (which could also help to bridge any API gap between @ariakit/test and RTL ?)

Discuss: "aria-describedBy" in tooltip anchors (context)

For more context, the main change here is that "users are responsible for making anchors accessible" (source).

Judging by previous conversations (example), we should be ok with this change. Although I would still have a pass and make sure that the removal of the tooltip description won't cause anchors to suddenly become inaccessible (and we should fix that by adding the information back in other ways, like with visually hidden text in the anchor).

@DaniGuardiola
Copy link
Contributor Author

DaniGuardiola commented Jul 30, 2024

we should probably look at cleaning up the custom render utility

Yep, ideally by contributing to Ariakit which is currently being discussed (ariakit/ariakit#3939 (comment)). It's on the TODO list!

That could be a way to improve the devX in the components package

+1

But we should also consider consumers of the components package (both other Gutenberg packages, and third-party consumers), who may end up struggling with the same failures. How can we help them? Considering that ariakit is considered an implementation detail, should we still point them at @ariakit/test ?

I would suggest being consistent: whatever we do in the components package is what we recommend on the outside. For now, that'd be switching to @ariakit/test, at least for the render and event trigger functions. Diego mentioned in the linked thread that, long-term, this package might stop using RTL altogether, which might result in things like screen.get/find/query not working anymore. At that point, we could recommend switching to Ariakit's query replacement (q), which is a simpler but pretty powerful alternative that we could potentially codemod into.

Note that, while it is indeed under the @ariakit scope, @ariakit/test is something that works on its own, and probably how RTL should've worked all along. It's actually exciting to think about it as a replacement for RTL altogether, at least in the long term. There are improvements beyond the waits, like the new (awesome imo) query API. All this to say that I don't think @ariakit/react being an implementation detail should influence our decisions in regards to @ariakit/test.

Should we instead offer a render function as part of some Gutenberg testing utils (which could also help to bridge any API gap between @ariakit/test and RTL ?)

This could be a good strategy in that eventuality, yes!

However, that seems like a future issue that's not even completely guaranteed to exist, so I think we're fine for now with:

  • consistently using render and event trigger functions for @ariakit/test in @wordpress/components
  • recommending the same only when necessary for tests in other packages that use Ariakit (independently e.g. dataviews or through the components library) under the hood

What do you think?

Judging by previous conversations (ariakit/ariakit#3242), we should be ok with this change. Although I would still have a pass and make sure that the removal of the tooltip description won't cause anchors to suddenly become inaccessible (and we should fix that by adding the information back in other ways, like with visually hidden text in the anchor).

Great to know! Agree, we should do a pass.

@DaniGuardiola
Copy link
Contributor Author

DaniGuardiola commented Jul 30, 2024

I added the restrictedImport rules (7a43523):

image

This is the output: https://pastebin.com/raw/RH2WGREJ (144 errors in the components package)

I reverted this change (412f612) to keep this PR focused on the upgrade itself, this should be done in a follow-up, but wanted to see how this would look.

cc @ciampo

@DaniGuardiola DaniGuardiola added [Type] Code Quality Issues or PRs that relate to code quality [Feature] Component System WordPress component system [Package] Components /packages/components labels Jul 30, 2024
Copy link
Member

@tyxla tyxla left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Doing some testing in the editor and in Storybook today (and will do some tomorrow).

Initial observation: changing the color in a color picker seems to have become clunkier:

Trunk:

Screen.Recording.2024-07-31.at.18.57.21.mov

This branch:

Screen.Recording.2024-07-31.at.18.56.13.mov

Copy link
Member

@tyxla tyxla left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did some more smoke testing and couldn't find any issues - nice work!

Are you planning any other changes before marking the PR as open and ready for review?

@DaniGuardiola
Copy link
Contributor Author

@tyxla just need to go through the remaining todos. If nothing else comes up, changelog will be the only change.

@DaniGuardiola DaniGuardiola self-assigned this Aug 1, 2024
@DaniGuardiola DaniGuardiola marked this pull request as ready for review August 1, 2024 15:11
Copy link

github-actions bot commented Aug 1, 2024

The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the props-bot label.

If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.

Co-authored-by: DaniGuardiola <daniguardiola@git.wordpress.org>
Co-authored-by: tyxla <tyxla@git.wordpress.org>
Co-authored-by: mirka <0mirka00@git.wordpress.org>
Co-authored-by: ciampo <mciampini@git.wordpress.org>

To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook.

@DaniGuardiola
Copy link
Contributor Author

Checked components for any potential remaining animation issues but couldn't find any. Also did some general testing in the Storybook and Gutenberg and nothing looks broken. Undrafting, get your final reviews in! :) @WordPress/gutenberg-components

@DaniGuardiola DaniGuardiola requested review from mirka, tyxla and a team August 1, 2024 15:16
@tyxla
Copy link
Member

tyxla commented Aug 1, 2024

I'm unable to reproduce this anymore 🎉 (not sure what was going on)

Copy link
Member

@tyxla tyxla left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the hard work on it @DaniGuardiola 🙌

I gave this a thorough amount of testing in Storybook, the site editor, and the post editor and didn't spot any regressions. ✅

The code looks good! 🚀 Thanks for pointing out all the changes and follow-ups in such detail!

The navigate metric seems to have doubled, but it's possible that it's a false alarm:

Screenshot 2024-08-01 at 18 59 09

Let's keep an eye on performance metrics after merging this one, just in case. ⏲️

Also, let's monitor unit test builds for flakiness ❄️ in the next couple of days.

@DaniGuardiola DaniGuardiola merged commit 23fe5e5 into trunk Aug 1, 2024
70 checks passed
@DaniGuardiola DaniGuardiola deleted the upgrade/ariakit-again branch August 1, 2024 16:03
@github-actions github-actions bot added this to the Gutenberg 19.0 milestone Aug 1, 2024
@tyxla
Copy link
Member

tyxla commented Aug 2, 2024

Filed #64205 to clean up the arbitrary sleep calls.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Component System WordPress component system [Package] Components /packages/components [Type] Code Quality Issues or PRs that relate to code quality
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants