#54596 closed defect (bug) (fixed)
Block theme with period in name causes blank editor
Reported by: | mkaz | Owned by: | hellofromTonya |
---|---|---|---|
Milestone: | 5.9 | Priority: | normal |
Severity: | normal | Version: | 5.9 |
Component: | REST API | Keywords: | has-testing-info has-patch commit |
Focuses: | Cc: |
Description
Testing instructions:
- Rename a block theme to include periods, for example:
twentytwentytwo-1.0
- Attempt to load site editor, confirm blank screen
- Additional testing, add theme under subdirectory with or without periods
Original issue discovered in #54544
Upstream issue in Gutenberg plugin here:
https://github.com/WordPress/gutenberg/issues/37156
The register rest routes are different between core and the Gutenberg plugin, this same change works in core but not in the plugin. So additional testing is needed to fix upstream.
Attachments (10)
Change History (54)
This ticket was mentioned in Slack in #core-editor by mkaz. View the logs.
3 years ago
This ticket was mentioned in Slack in #core-editor by mkaz. View the logs.
3 years ago
#4
@
3 years ago
- Component changed from General to REST API
- Keywords has-patch has-testing-info added
- Milestone changed from Awaiting Review to 5.9
- Owner set to hellofromTonya
- Status changed from new to accepted
- Version set to trunk
This ticket was mentioned in PR #2034 on WordPress/wordpress-develop by hellofromtonya.
3 years ago
#5
- Keywords has-unit-tests added
Fix: block theme with period in name causes blank editor.
Trac ticket: https://core.trac.wordpress.org/ticket/54596
#6
follow-up:
↓ 11
@
3 years ago
This looks to be a wider problem with other characters that are permitted in folder names but do not currently work. I've put some notes below.
Somewhat challenging is that not all characters allowed in a folder name are permitted in a post name, so global styles set up with the theme my-theme
and my.theme
may both end up with the same slug.
Manual testing with various characters in the folder name with this patch applied follows.
For the 2022 clone, success or failure is indicated by whether the editor works.
For the 2020 clone, success or failure is indicated by whether the customizer works.
Character | 2022 clone | 2020 clone |
---|---|---|
space | Failed | Successful |
. | Successful | Successful |
[ | Failed | Failed |
| | Failed | Successful |
= | Failed | Successful |
( | Failed | Successful |
+ | Failed | Successful |
@ | Failed | Successful |
#7
@
3 years ago
@peterwilsoncc good catch. We can switch the regex to \w\W to grab everything, but not sure if that is a good idea or not, I fear spaces and other characters might introduce additional issues.
Your point about the slug is curious if themes share the same slug the styles and templates can conflict with one another.
#8
@
3 years ago
Yeah, I'm not sure what the correct answer to this is but I thought it better to note it down none the less.
The one thing that did occur to me overnight was that maybe the post slugs could be a hash of the directory name. It doesn't need to be salted as it's a hash of public information anyway. However, I suspect it's way to late in the release cycle to consider such a change.
This ticket was mentioned in Slack in #core-themes by jffng. View the logs.
3 years ago
spacedmonkey commented on PR #2034:
3 years ago
#10
@hellofromtonya I would love to see some unit test with a test data provider, with list of theme names with funny characters, like, {?: etc.
#11
in reply to:
↑ 6
@
3 years ago
Replying to peterwilsoncc:
Character 2022 clone 2020 clone space Failed Successful .
Successful Successful [
Failed Failed |
Failed Successful =
Failed Successful (
Failed Successful +
Failed Successful @
Failed Successful
After testing with @costdev, |
fails on Windows as it's not a valid dirname and +
gets stripped out.
PR 2034 adds support for the following characters: .
, [
, ]
, (,
),
@,
_`, and space.
It's ready for testing and review.
To test:
- Pull and apply the PR.
- Rename the
twentytwentytwo
theme's directory to something liketwentytwentytwo -_@ [(v0.4.0)]
. - Activate the theme.
- Click on the 'Customize' button.
Expected behavior: The Site Editor opens without issue.
hellofromtonya commented on PR #2034:
3 years ago
#12
I would love to see some unit test with a test data provider, with list of theme names with funny characters, like, {?: etc.
Me too, @spacedmonkey. Those data providers are there now.
#13
@
3 years ago
Test Report
Env
- WordPress 5.9-beta2-52344-src
- Chrome 96.0.4664.93
- Windows 10
- Theme: Twenty Twenty-Two
- Gutenberg Editor
- Plugin: None activated.
Steps to test
- Rename a block theme directory to include
[ ] ( ) - _ (space) @
. For example:[twenty_twenty-two] (@ 1.0)
. - Navigate to
Appearance > Themes
and activate the theme. - Navigate to
Appearance > Site Editor
. - The Site Editor should fail to load.
- Apply PR 2034.
- Repeat steps 1-3.
- The Site Editor should now load.
Additional testing:
- Repeat steps 1-7 but place the theme in a sub-directory with
[ ] ( ) - _ (space) @
in its directory name.
Results
- Before the PR: The Site Editor fails to load.
- After the PR: The Site Editor loads as expected.
- Issue fixed ✅
#14
@
3 years ago
Test Report
Env:
- OS: macOS Big Sur 11.6
- Browsers: Edge, Chrome, Safari, and Firefox
- Theme: Copy of TT2 with directory name changed (see test info)
- Plugins: None
- WordPress: trunk
- Patch: PR 2034
- Localhost: wp-end and Local (with ngnix and apache)
Steps
- Copy TT2 theme:
- Rename it's directory to
twentytwentytwo @[0.4.0] ( - _ - )
- Open
style.css
and change theTheme Name
- Rename it's directory to
- Go to Appearance > Themes
- Activate the new TT2 theme with the funky directory naming
- Go to the Site Editor, i.e. click on "Customize" button
Expected behavior: The Site Editor should load
- Navigate back to the Themes UI
- Activate the original TT2 theme
- Rename the TT2 copy to
twentytwentytwo {notvalid}
- Activate this TT2
- Click on "Customize" button
Expected behavior: The Site Editor should not load as there's an error with the invalid theme directory name
Results
- Confirmed using space,
-
,_
,.
,@
,[
,]
,(
,)
characters in dirname works ✅ - Confirmed using
{
and}
does not work and gives a 404 error ✅
#15
@
3 years ago
- Keywords commit added
Marking PR 2034 for commit
.
Note: This patch adds support for the following characters: .
, [
, ]
, (
, )
, _
, and @
. It does not add support for |
(which fail on Windows), +
(which gets stripped), or =
(which is a separator for query string key=value pairs).
spacedmonkey commented on PR #2034:
3 years ago
#16
I would really like @TimothyBJacobs to review this before this is merged.
#17
@
3 years ago
- Keywords commit removed
Removing the commit
keyword until folks like @TimothyBlynJacobs and @mkaz review and/or test the PR.
This ticket was mentioned in Slack in #core-test by hellofromtonya. View the logs.
3 years ago
@
3 years ago
Test: wp-content/themes/subdir/twentytwentytwo v0.4.0 @[( -_-)]
(with latest PR changes). Works ✅
#19
@
3 years ago
Test Report
Env:
- OS: macOS Big Sur 12.0
- Browsers: Firefox Developer Edition 95.0b12
- Theme: Copy of TT2 with directory name changed (see test info https://core.trac.wordpress.org/ticket/54596#comment:14)
- Plugins: None
- WordPress: trunk
- Patch: PR 2034
- Localhost: wp-env
Results
Before the patch
- Confirmed using space,
-
,_
,.
,@
,[
,]
,(
,)
characters in dirname works - Confirmed using
{
and}
does not work, and output a 404 error onhttp://localhost:8889/index.php?rest_route=/wp/v2/templates/twentytwentytwo {notvalid}//home&context=edit&_locale=user
@
3 years ago
Test Report: wp-content/themes/tt2-{invalid}/
(with latest PR changes). Result => status: 404, message: "No route was found matching the URL and request method"
@
3 years ago
Test Report: wp-content/themes/twentytwentytwo @[0.4.0] ( -_-)/
(with latest PR changes). Works ✅
#20
@
3 years ago
Test Report
Env
OS: Windows / WSL2 (Apache)
Theme: Twentytwentytwo
Plugins: None (Issue still present in Gutenberg plugin (See 37167)
WordPress: trunk
Patch: PR 2034
Results
Works as expected, tested using set of characters directory name ( - _ . [ ] ( ) @ )
This ticket was mentioned in Slack in #core by hellofromtonya. View the logs.
3 years ago
#22
@
3 years ago
- Keywords commit added
Marking it again for commit
. If there are follow-ups from @TimothyBlynJacobs, can catch those in a follow-up commit for Beta 3 or Beta 4.
This ticket was mentioned in Slack in #core-restapi by hellofromtonya. View the logs.
3 years ago
#24
follow-up:
↓ 27
@
3 years ago
The change looks good to me. I do worry about @peterwilsoncc's concerns that different themes will end up mapping to the same slug.
spacedmonkey commented on PR #2034:
3 years ago
#25
@hellofromtonya This needs to be rebased and conflicts fixed.
#26
follow-up:
↓ 29
@
3 years ago
Sorry noticed something, does this not affect the themes endpoint? Is that regex already broad enough?
@
3 years ago
Test Report: Do same theme with different directory names resolve correctly? Yes, works ✅
@
3 years ago
Test Report: 2 themes with same theme name but different directory names - Resolve in Site Editor? Yes, works ✅
#27
in reply to:
↑ 24
@
3 years ago
Replying to TimothyBlynJacobs:
I do worry about @peterwilsoncc's concerns that different themes will end up mapping to the same slug.
I was worried about that too. Tested it with 2 the TT2 theme with different theme directory names and changed the wp-content/themes/twentytwentytwo-0.4.0/theme.json
to background color to red. See attachments test-site-editor-same-theme-resolves.png and test-same-theme-slug-resolves.png. Both themes resolve in the Site Editor, front-end, and in the Appearance > Themes.
hellofromtonya commented on PR #2034:
3 years ago
#28
Merge conflict resolved.
#29
in reply to:
↑ 26
;
follow-up:
↓ 32
@
3 years ago
Replying to TimothyBlynJacobs:
Sorry noticed something, does this not affect the themes endpoint? Is that regex already broad enough?
Thanks for raising the question. Did further testing through Customizer, Site Editor, Block Editor, and frontend. I'm curiously not seeing an issue with the Themes endpoint.
hellofromtonya commented on PR #2034:
3 years ago
#31
Committed via https://core.trac.wordpress.org/changeset/52376.
#32
in reply to:
↑ 29
;
follow-up:
↓ 33
@
3 years ago
Replying to hellofromTonya:
Replying to TimothyBlynJacobs:
Sorry noticed something, does this not affect the themes endpoint? Is that regex already broad enough?
Thanks for raising the question. Did further testing through Customizer, Site Editor, Block Editor, and frontend. I'm curiously not seeing an issue with the Themes endpoint.
The single /wp/v2/themes/<theme>
endpoint would need to be tested manually or via Unit Tests. AFAIK, no parts of the UI currently use the single theme endpoint directly, they still use the collections response.
#33
in reply to:
↑ 32
@
3 years ago
- Keywords needs-testing added; has-patch has-unit-tests commit removed
- Resolution fixed deleted
- Status changed from closed to reopened
Replying to TimothyBlynJacobs:
The single
/wp/v2/themes/<theme>
endpoint would need to be tested manually or via Unit Tests. AFAIK, no parts of the UI currently use the single theme endpoint directly, they still use the collections response.
Thanks @TimothyBlynJacobs and DOH on my part :facepalm:. Reopening this ticket to test this, i.e. just to make sure that endpoint is okay or it needs an adjustment too.
Hey @costdev would you have some time this week to manually test this?
#34
@
3 years ago
I installed 5.3 beta and copied twentytwentytwo
theme and renamed it twentytwentytwo!
. After that on the backend, I clicked on Appearance > Editor and the page was blank. There are two errors on console:
- http://localhost/beta/wp-json/wp/v2/templates/twentytwentytwo!//home?context=edit&_locale=user 404 (Not Found)
- Uncaught (in promise) TypeError: Cannot destructure property 'id' of '(intermediate value)' as it is null. - http://localhost/beta/wp-includes/js/dist/edit-site.min.js?ver=dd4604f4d44cfa19261ecfc79f1e6f06
Screenshot: http://prntscr.com/2328a4g
#35
@
3 years ago
I also have the same issue. My theme folder is, twenty!@#$%^&()_+ ~
-+`.
Also, there console error,
Uncaught (in promise) TypeError: Cannot destructure property 'id' of '(intermediate value)' as it is null.
at K (edit-site.min.js?ver=dd4604f4d44cfa19261ecfc79f1e6f06:2)
at K.next (<anonymous>)
at Y (edit-site.min.js?ver=dd4604f4d44cfa19261ecfc79f1e6f06:2)
at Y.next (<anonymous>)
at redux-routine.min.js?ver=f2016f404fbc2c831239953e37cc686c:2
This ticket was mentioned in Slack in #core-test by kafleg. View the logs.
3 years ago
#37
@
3 years ago
Thanks @kafleg and @bijayyadav. Currently, the endpoint does not support these characters: !#$%^&+~
.
TODO: Confirm if all of these characters are valid for directory names on cross-server OSs including Windows, Mac, Linux, etc.
This ticket was mentioned in PR #2064 on WordPress/wordpress-develop by hellofromtonya.
3 years ago
#38
- Keywords has-patch added
Adds support for localized characters (e.g. é) and other valid directory name characters.
Trac ticket: https://core.trac.wordpress.org/ticket/54596
#39
@
3 years ago
[52376] was too limiting as valid directory name characters such as é
, &
, =
, #
, !
, $
, ,
, ^
, ~
, %
, etc.
Notice that the original regex for listing themes global styles excludes .
and /
characters.
'/' . $this->rest_base . '/themes/(?P<stylesheet>[^.\/]+(?:\/[^.\/]+)?)'
Aha, .
was being excluded.
Then @TimothyBlynJacobs asked if WP_REST_Themes_Controller::PATTERN
was also too limiting:
Sorry noticed something, does this not affect the themes endpoint? Is that regex already broad enough?
Here's it original regex:
const PATTERN = '[^.\/]+(?:\/[^.\/]+)?';
Notice again the .
character is excluded.
PR 2064 reverts the regex changes made by [52376], removes the .
from the exclusion lists, and adds additional invalid characters (invalid on Windows). It then adds additional tests to further validate the changes.
@costdev tested it on Windows. I tested it on Mac. Works well on both. Test report is coming.
@
3 years ago
Test PR 2064 (on macOS) with themes in wp-content/themes/subdir/tt2é [v1.0.0](-_-)/
and wp-content/themes/tt2é [v1.0.0] {@!$,^~}(-_-)/
directories. Works ✅
#40
@
3 years ago
- Keywords needs-testing removed
Test Report
Env:
- OS: macOS Big Sur 11.6
- Browsers: Edge
- Theme: Copies of TT2 with directory name changed (see test info)
- Plugins: None
- WordPress: trunk
- Patch: PR 2064
- Localhost: wp-env
Steps
- Prepare first theme:
- Copy
wp-content/themes/twentytwentytwo/
towp-content/themes/tt2é [v1.0.0] {@!$,^~}(-_-)/
- In copied theme, open
style.css
and change theTheme Name
tott2é [v1.0.0] {@!$,^~}(-_-)
- Open the
theme.json
and change the background color of#000000
to#FF0000
(visual cue that this theme resolves)
- Copy
- Prepare second theme:
- Copy
wp-content/themes/tt2é [v1.0.0] {@!$,^~}(-_-)/
towp-content/themes/subdir/tt2é [v1.0.0](-_-)/
- Open
style.css
and change theTheme Name
tosubdir/tt2é [v1.0.0](-_-)
- Open the
theme.json
and change the background color of#FF0000
to#00FF00
(visual cue that this theme resolves)
- Copy
- Go to Appearance > Themes
- Activate the
subdir/tt2é [v1.0.0](-_-)
theme (the one in the subdirectory) - Click its "Customize" button
Expected behavior: The Site Editor should load and the header background should be a bright green color.
- Click on the W logo which opens the Site Editor's sidebar
- Navigate to
Templates
Expected behavior: The Added by
column should list subdir/tt2é [v1.0.0](-_-)
. (See the left side of test-pr2064-macos.gif.)
- View the site in the frontend.
- Repeat steps 4 through 7 with the
wp-content/themes/tt2é [v1.0.0] {@!$,^~}(-_-)/
theme.
Expected behavior: The header background color should red and "Added by" column should list tt2é [v1.0.0] {@!$,^~}(-_-)
. (See the right side of test-pr2064-macos.gif.)
- Repeat steps 4 through 7 with the
wp-content/themes/twentytwentytwo/
theme.
Expected behavior: The header background color should black and "Added by" column should list Twenty Twenty-Two
.
Results
- Twenty Twenty-Two theme loads properly ✅
wp-content/themes/tt2é [v1.0.0] {@!$,^~}(-_-)/
loads properly ✅wp-content/themes/subdir/tt2é [v1.0.0](-_-)/
loads properly ✅- Copying TT2
wp-content/themes/sudir/tt2
loads properly ✅ (an extra test I did)
Works as expected ✅
Notes:
- On Mac, themes named with
&
,=
,%
characters do not load in the Site Editor. No 404 (so the route is found).Uncaught (in promise) TypeError: Cannot destructure property 'id' of '(intermediate value)' as it is null.
error in the console. Suspect this is due to encoding.- Theme directories named with these characters are likely far edge cases.
@
3 years ago
Test (on Mac) BEFORE and AFTER PR 2064 with themes wp-content/themes/ŧĥémé-1.0.0/
and wp-content/themes/subdir/ŧĥémé-1.0.0/
. Results: before fails; after works.
#41
@
3 years ago
- Keywords commit added
Theme directories named with characters like {@!$,^~"}
and &=%
are likely far edge cases. Theme directories named with localized characters like é
are not.
Test Report
Env:
- OS: macOS Big Sur 11.6
- Browsers: Edge
- Theme: Copies of TT2 with directory name changed (see test info)
- Plugins: None
- WordPress: trunk
- Patch: PR 2064
- Localhost: wp-env
Steps
Using the steps as a starting point:
- Prepare first theme:
- Rename
wp-content/themes/tt2é [v1.0.0] {@!$,^~}(-_-)/
towp-content/themes/ŧĥémé-1.0.0/
- Open
style.css
and change theTheme Name
toŧĥémé-1.0.0
- Rename
- Prepare second theme:
- Rename
wp-content/themes/subdir/tt2é [v1.0.0](-_-)/
towp-content/themes/subdir/ŧĥémé-1.0.0
- Open
style.css
and change theTheme Name
tosubdir/ŧĥémé-1.0.0
- Rename
Now test:
- Use
trunk
(not the PR) - Go to Appearance > Themes
- Activate the
subdir/ŧĥémé-1.0.0
theme (the one in the subdirectory) - Click its "Customize" button
Actual behavior: Site Editor does not load and has a 404 with the following error message: {"code":"rest_no_route","message":"No route was found matching the URL and request method.","data":{"status":404}}
(To view the error, open browser's Network tab, refresh the page, scroll down the 404 item in the list, click on it to open a panel, and then click on the Response tab to view the JSON response.)
- Apply PR 2064
- Refresh the Site Editor.
Expected behavior: The Site Editor should load and the header background should be a bright green color.
Results
- Yes, can reproduce the 404 error before the PR is applied ✅
- With the PR 2064 applied, resolves the endpoint (no error) and Site Editor opens as expected ✅
Marking for commit.
hellofromtonya commented on PR #2064:
3 years ago
#43
Committed via changeset https://core.trac.wordpress.org/changeset/52399.
I gave this patch a spin and confirm the site editor loads as expected when a theme name contains a period (e.g. twentytwentytwo-0.4.0), as well as when it appears in a subdirectory.