Make WordPress Core


Ignore:
Timestamp:
10/17/2023 03:46:44 PM (2 years ago)
Author:
Bernhard Reiter
Message:

Patterns, Templates: Inject theme attr into Template Part blocks.

It was found that Template Part blocks were broken in the Site Editor, showing the Template part has been deleted or is unavailable message, due to a missing theme attribute.

This bug seems to have been introduced by [56896], whose goal was to only inject that attribute into the markup returned by the templates and patterns REST API endpoints but not on the frontend, in order to improve performance. It has been demonstrated locally that reverting that changeset fixes the bug.

Reverts [56896].
Props mmcalister, swisspidy, thelovelist, hellofromTonya, pbiron, Pauthake015, richtabor, nicolefurlan, huzaifaalmesbah, annezazu, kafleg, aegkr, sunitarai, shresthaaman, andraganescu, onemaggie, gziolo.
Fixes #59629.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/tests/phpunit/tests/block-template-utils.php

    r56896 r56960  
    163163
    164164    /**
     165     * @ticket 59325
     166     *
     167     * @covers ::_build_block_template_result_from_file
     168     *
     169     * @dataProvider data_build_block_template_result_from_file_injects_theme_attribute
     170     *
     171     * @param string $filename The template's filename.
     172     * @param string $expected The expected block markup.
     173     */
     174    public function test_build_block_template_result_from_file_injects_theme_attribute( $filename, $expected ) {
     175        $template = _build_block_template_result_from_file(
     176            array(
     177                'slug' => 'single',
     178                'path' => DIR_TESTDATA . "/templates/$filename",
     179            ),
     180            'wp_template'
     181        );
     182        $this->assertSame( $expected, $template->content );
     183    }
     184
     185    /**
     186     * Data provider.
     187     *
     188     * @return array[]
     189     */
     190    public function data_build_block_template_result_from_file_injects_theme_attribute() {
     191        $theme = 'block-theme';
     192        return array(
     193            'a template with a template part block'  => array(
     194                'filename' => 'template-with-template-part.html',
     195                'expected' => sprintf(
     196                    '<!-- wp:template-part {"slug":"header","align":"full","tagName":"header","className":"site-header","theme":"%s"} /-->',
     197                    $theme
     198                ),
     199            ),
     200            'a template with a template part block nested inside another block' => array(
     201                'filename' => 'template-with-nested-template-part.html',
     202                'expected' => sprintf(
     203                    '<!-- wp:group -->
     204<!-- wp:template-part {"slug":"header","align":"full","tagName":"header","className":"site-header","theme":"%s"} /-->
     205<!-- /wp:group -->',
     206                    $theme
     207                ),
     208            ),
     209            'a template with a template part block with an existing theme attribute' => array(
     210                'filename' => 'template-with-template-part-with-existing-theme-attribute.html',
     211                'expected' => '<!-- wp:template-part {"slug":"header","theme":"fake-theme","align":"full","tagName":"header","className":"site-header"} /-->',
     212            ),
     213            'a template with no template part block' => array(
     214                'filename' => 'template.html',
     215                'expected' => '<!-- wp:paragraph -->
     216<p>Just a paragraph</p>
     217<!-- /wp:paragraph -->',
     218            ),
     219        );
     220    }
     221
     222    /**
    165223     * @ticket 59338
    166224     *
Note: See TracChangeset for help on using the changeset viewer.