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

Load FSE php files only if experiment is enabled #24182

Merged
merged 6 commits into from
Aug 7, 2020

Conversation

noahtallen
Copy link
Member

Description

Previously, any 3rd party who had the Gutenberg plugin installed could use register_post_type( 'wp_template' ) to opt into block template resolution. Specifically, our template loader file is always loaded and the filter is always registered. When the filter runs, it is gated only by a check for the wp_template CPT. Obviously, anyone can register any CPT they like, so this means that folks can treat template resolution as a stable API simply by registering the CPT themselves.

This is motivated by #24129, in which a user had created the wp_template CPT themselves without the experiment enabled, expecting template resolution to work correctly and to be a stable API.

There are some other examples of this (e.g. the edit-site exporter API is always registered if the plugin is installed).

What if we just avoid loading those files altogether if the experiment is disabled? (This is what I would have expected originally.)

My only concern is that this could be considered a breaking change. I know some others think it might not be a breaking change.

How has this been tested?

Locally, in edit site. Tests should pass

Screenshots

Types of changes

Checklist:

  • My code is tested.
  • My code follows the WordPress code style.
  • My code follows the accessibility standards.
  • My code has proper inline documentation.
  • I've included developer documentation if appropriate.
  • I've updated all React Native files affected by any refactorings/renamings in this PR.

@github-actions
Copy link

github-actions bot commented Jul 24, 2020

Size Change: 0 B

Total Size: 1.15 MB

ℹ️ View Unchanged
Filename Size Change
build/a11y/index.js 1.14 kB 0 B
build/annotations/index.js 3.67 kB 0 B
build/api-fetch/index.js 3.44 kB 0 B
build/autop/index.js 2.82 kB 0 B
build/blob/index.js 620 B 0 B
build/block-directory/index.js 7.97 kB 0 B
build/block-directory/style-rtl.css 953 B 0 B
build/block-directory/style.css 952 B 0 B
build/block-editor/index.js 125 kB 0 B
build/block-editor/style-rtl.css 10.6 kB 0 B
build/block-editor/style.css 10.6 kB 0 B
build/block-library/editor-rtl.css 7.59 kB 0 B
build/block-library/editor.css 7.59 kB 0 B
build/block-library/index.js 132 kB 0 B
build/block-library/style-rtl.css 7.76 kB 0 B
build/block-library/style.css 7.77 kB 0 B
build/block-library/theme-rtl.css 729 B 0 B
build/block-library/theme.css 730 B 0 B
build/block-serialization-default-parser/index.js 1.88 kB 0 B
build/block-serialization-spec-parser/index.js 3.1 kB 0 B
build/blocks/index.js 48.2 kB 0 B
build/components/index.js 200 kB 0 B
build/components/style-rtl.css 15.7 kB 0 B
build/components/style.css 15.7 kB 0 B
build/compose/index.js 9.68 kB 0 B
build/core-data/index.js 11.8 kB 0 B
build/data-controls/index.js 1.29 kB 0 B
build/data/index.js 8.45 kB 0 B
build/date/index.js 5.38 kB 0 B
build/deprecated/index.js 772 B 0 B
build/dom-ready/index.js 568 B 0 B
build/dom/index.js 3.23 kB 0 B
build/edit-navigation/index.js 10.9 kB 0 B
build/edit-navigation/style-rtl.css 1.08 kB 0 B
build/edit-navigation/style.css 1.08 kB 0 B
build/edit-post/index.js 304 kB 0 B
build/edit-post/style-rtl.css 5.59 kB 0 B
build/edit-post/style.css 5.59 kB 0 B
build/edit-site/index.js 17 kB 0 B
build/edit-site/style-rtl.css 3.06 kB 0 B
build/edit-site/style.css 3.06 kB 0 B
build/edit-widgets/index.js 9.38 kB 0 B
build/edit-widgets/style-rtl.css 2.45 kB 0 B
build/edit-widgets/style.css 2.45 kB 0 B
build/editor/editor-styles-rtl.css 537 B 0 B
build/editor/editor-styles.css 539 B 0 B
build/editor/index.js 45.3 kB 0 B
build/editor/style-rtl.css 3.8 kB 0 B
build/editor/style.css 3.79 kB 0 B
build/element/index.js 4.65 kB 0 B
build/escape-html/index.js 733 B 0 B
build/format-library/index.js 7.72 kB 0 B
build/format-library/style-rtl.css 547 B 0 B
build/format-library/style.css 548 B 0 B
build/hooks/index.js 2.13 kB 0 B
build/html-entities/index.js 621 B 0 B
build/i18n/index.js 3.56 kB 0 B
build/is-shallow-equal/index.js 711 B 0 B
build/keyboard-shortcuts/index.js 2.52 kB 0 B
build/keycodes/index.js 1.94 kB 0 B
build/list-reusable-blocks/index.js 3.11 kB 0 B
build/list-reusable-blocks/style-rtl.css 476 B 0 B
build/list-reusable-blocks/style.css 476 B 0 B
build/media-utils/index.js 5.33 kB 0 B
build/notices/index.js 1.79 kB 0 B
build/nux/index.js 3.4 kB 0 B
build/nux/style-rtl.css 671 B 0 B
build/nux/style.css 668 B 0 B
build/plugins/index.js 2.56 kB 0 B
build/primitives/index.js 1.41 kB 0 B
build/priority-queue/index.js 789 B 0 B
build/redux-routine/index.js 2.85 kB 0 B
build/rich-text/index.js 13.9 kB 0 B
build/server-side-render/index.js 2.71 kB 0 B
build/shortcode/index.js 1.7 kB 0 B
build/token-list/index.js 1.27 kB 0 B
build/url/index.js 4.06 kB 0 B
build/viewport/index.js 1.85 kB 0 B
build/warning/index.js 1.14 kB 0 B
build/wordcount/index.js 1.17 kB 0 B

compressed-size-action

@noahtallen noahtallen force-pushed the try/avoid-loading-fse-php-if-experiment-disabled branch from a9428b2 to 7d7a936 Compare July 27, 2020 21:59
@youknowriad
Copy link
Contributor

I like this, it clarifies what's FSE and what's not. Thanks.

@noahtallen noahtallen force-pushed the try/avoid-loading-fse-php-if-experiment-disabled branch from 7d7a936 to a166a45 Compare July 30, 2020 00:29
@noahtallen
Copy link
Member Author

The e2e tests seem to be related to the change. I don't have time to investigate for the next few days, so anyone can feel free to investigate

@noahtallen noahtallen force-pushed the try/avoid-loading-fse-php-if-experiment-disabled branch from a166a45 to 03c8f60 Compare August 5, 2020 23:19
@noahtallen noahtallen force-pushed the try/avoid-loading-fse-php-if-experiment-disabled branch from f7bf2e5 to 5b7e407 Compare August 7, 2020 22:10
@noahtallen
Copy link
Member Author

noahtallen commented Aug 7, 2020

the e2e failures were due to calling an edit-site function even when the FSE experiment was disabled.

@noahtallen noahtallen merged commit 4719212 into master Aug 7, 2020
@noahtallen noahtallen deleted the try/avoid-loading-fse-php-if-experiment-disabled branch August 7, 2020 23:11
@github-actions github-actions bot added this to the Gutenberg 8.8 milestone Aug 7, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants