Make WordPress Core


Ignore:
Timestamp:
10/17/2023 03:46:44 PM (11 months 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/blocks/wpBlockPatternsRegistry.php

    r56896 r56960  
    318318
    319319    /**
     320     * Should insert a theme attribute into Template Part blocks in registered patterns.
     321     *
     322     * @ticket 59583
     323     *
     324     * @covers WP_Block_Patterns_Registry::register
     325     * @covers WP_Block_Patterns_Registry::get_all_registered
     326     */
     327    public function test_get_all_registered_includes_theme_attribute() {
     328        $test_pattern = array(
     329            'title'   => 'Test Pattern',
     330            'content' => '<!-- wp:template-part {"slug":"header","align":"full","tagName":"header","className":"site-header"} /-->',
     331        );
     332        $this->registry->register( 'test/pattern', $test_pattern );
     333
     334        $expected = sprintf(
     335            '<!-- wp:template-part {"slug":"header","align":"full","tagName":"header","className":"site-header","theme":"%s"} /-->',
     336            get_stylesheet()
     337        );
     338        $patterns = $this->registry->get_all_registered();
     339        $this->assertSame( $expected, $patterns[0]['content'] );
     340    }
     341
     342    /**
    320343     * Should insert hooked blocks into registered patterns.
    321344     *
     
    370393
    371394    /**
     395     * Should insert a theme attribute into Template Part blocks in registered patterns.
     396     *
     397     * @ticket 59583
     398     *
     399     * @covers WP_Block_Patterns_Registry::register
     400     * @covers WP_Block_Patterns_Registry::get_registered
     401     */
     402    public function test_get_registered_includes_theme_attribute() {
     403        $test_pattern = array(
     404            'title'   => 'Test Pattern',
     405            'content' => '<!-- wp:template-part {"slug":"header","align":"full","tagName":"header","className":"site-header"} /-->',
     406        );
     407        $this->registry->register( 'test/pattern', $test_pattern );
     408
     409        $expected = sprintf(
     410            '<!-- wp:template-part {"slug":"header","align":"full","tagName":"header","className":"site-header","theme":"%s"} /-->',
     411            get_stylesheet()
     412        );
     413        $pattern  = $this->registry->get_registered( 'test/pattern' );
     414        $this->assertSame( $expected, $pattern['content'] );
     415    }
     416
     417    /**
    372418     * Should insert hooked blocks into registered patterns.
    373419     *
Note: See TracChangeset for help on using the changeset viewer.