assertSame( self::$template_canvas_path, $resolved_template_path ); $this->assertStringEqualsFile( get_stylesheet_directory() . '/templates/page-home.html', $_wp_current_template_content ); } public function test_page_block_template_takes_precedence() { global $_wp_current_template_content; $type = 'page'; $templates = array( 'page-slug-doesnt-exist.php', 'page-1.php', 'page.php', ); $resolved_template_path = locate_block_template( get_stylesheet_directory() . '/page.php', $type, $templates ); $this->assertSame( self::$template_canvas_path, $resolved_template_path ); $this->assertStringEqualsFile( get_stylesheet_directory() . '/templates/page.html', $_wp_current_template_content ); } public function test_block_template_takes_precedence_over_equally_specific_php_template() { global $_wp_current_template_content; $type = 'index'; $templates = array( 'index.php', ); $resolved_template_path = locate_block_template( get_stylesheet_directory() . '/index.php', $type, $templates ); $this->assertSame( self::$template_canvas_path, $resolved_template_path ); $this->assertStringEqualsFile( get_stylesheet_directory() . '/templates/index.html', $_wp_current_template_content ); } /** * In a hybrid theme, a PHP template of higher specificity will take precedence over a block template * with lower specificity. * * Covers https://github.com/WordPress/gutenberg/pull/29026. */ public function test_more_specific_php_template_takes_precedence_over_less_specific_block_template() { $page_id_template = 'page-1.php'; $page_id_template_path = get_stylesheet_directory() . '/' . $page_id_template; $type = 'page'; $templates = array( 'page-slug-doesnt-exist.php', 'page-1.php', 'page.php', ); $resolved_template_path = locate_block_template( $page_id_template_path, $type, $templates ); $this->assertSame( $page_id_template_path, $resolved_template_path ); } /** * If a theme is a child of a block-based parent theme but has php templates for some of its pages, * a php template of the child will take precedence over the parent's block template if they have * otherwise equal specificity. * * Covers https://github.com/WordPress/gutenberg/pull/31123. * Covers https://core.trac.wordpress.org/ticket/54515. * */ public function test_child_theme_php_template_takes_precedence_over_equally_specific_parent_theme_block_template() { switch_theme( 'block-theme-child' ); $page_slug_template = 'page-home.php'; $page_slug_template_path = get_stylesheet_directory() . '/' . $page_slug_template; $type = 'page'; $templates = array( 'page-home.php', 'page-1.php', 'page.php', ); $resolved_template_path = locate_block_template( $page_slug_template_path, $type, $templates ); $this->assertSame( $page_slug_template_path, $resolved_template_path ); } public function test_child_theme_block_template_takes_precedence_over_equally_specific_parent_theme_php_template() { global $_wp_current_template_content; switch_theme( 'block-theme-child' ); $page_template = 'page-1.php'; $parent_theme_page_template_path = get_template_directory() . '/' . $page_template; $type = 'page'; $templates = array( 'page-slug-doesnt-exist.php', 'page-1.php', 'page.php', ); $resolved_template_path = locate_block_template( $parent_theme_page_template_path, $type, $templates ); $this->assertSame( self::$template_canvas_path, $resolved_template_path ); $this->assertStringEqualsFile( get_stylesheet_directory() . '/templates/page-1.html', $_wp_current_template_content ); } /** * Regression: https://github.com/WordPress/gutenberg/issues/31399. */ public function test_custom_page_php_template_takes_precedence_over_all_other_templates() { $custom_page_template = 'templates/full-width.php'; $custom_page_template_path = get_stylesheet_directory() . '/' . $custom_page_template; $type = 'page'; $templates = array( $custom_page_template, 'page-slug.php', 'page-1.php', 'page.php', ); $resolved_template_path = locate_block_template( $custom_page_template_path, $type, $templates ); $this->assertSame( $custom_page_template_path, $resolved_template_path ); } /** * Covers: https://github.com/WordPress/gutenberg/pull/30438. */ public function test_custom_page_block_template_takes_precedence_over_all_other_templates() { global $_wp_current_template_content; // Set up custom template post. $args = array( 'post_type' => 'wp_template', 'post_name' => 'wp-custom-template-my-block-template', 'post_title' => 'My Custom Block Template', 'post_content' => 'Content', 'post_excerpt' => 'Description of my block template', 'tax_input' => array( 'wp_theme' => array( get_stylesheet(), ), ), ); $post = self::factory()->post->create_and_get( $args ); wp_set_post_terms( $post->ID, get_stylesheet(), 'wp_theme' ); $custom_page_block_template = 'wp-custom-template-my-block-template'; $page_template_path = get_stylesheet_directory() . '/' . 'page.php'; $type = 'page'; $templates = array( $custom_page_block_template, 'page-slug.php', 'page-1.php', 'page.php', ); $resolved_template_path = locate_block_template( $page_template_path, $type, $templates ); $this->assertSame( self::$template_canvas_path, $resolved_template_path ); $this->assertSame( $post->post_content, $_wp_current_template_content ); wp_delete_post( $post->ID ); } /** * Regression: https://github.com/WordPress/gutenberg/issues/31652. */ public function test_template_remains_unchanged_if_templates_array_is_empty() { $resolved_template_path = locate_block_template( '', 'search', array() ); $this->assertSame( '', $resolved_template_path ); } /** * Tests that `get_the_block_template_html()` wraps block parsing into the query loop when on a singular template. * * This is necessary since block themes do not include the necessary blocks to trigger the main query loop, and * since there is only a single post in the main query loop in such cases anyway. * * @ticket 58154 * @covers ::get_the_block_template_html */ public function test_get_the_block_template_html_enforces_singular_query_loop() { global $_wp_current_template_content, $wp_query, $wp_the_query; // Register test block to log `in_the_loop()` results. $in_the_loop_logs = array(); $this->register_in_the_loop_logger_block( $in_the_loop_logs ); // Set main query to single post. $post_id = self::factory()->post->create( array( 'post_title' => 'A single post' ) ); $wp_query = new WP_Query( array( 'p' => $post_id ) ); $wp_the_query = $wp_query; // Use block template that just renders post title and the above test block. $_wp_current_template_content = ''; $expected = '