From e0e312b43bbf1098e8f8a876049a74cfbe073db8 Mon Sep 17 00:00:00 2001 From: Alain Schlesser Date: Fri, 25 Oct 2019 07:07:24 +0200 Subject: [PATCH 1/4] Change template hierarchy query arguments to public --- includes/class-amp-theme-support.php | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/includes/class-amp-theme-support.php b/includes/class-amp-theme-support.php index ac35769410f..9e56934b8a4 100644 --- a/includes/class-amp-theme-support.php +++ b/includes/class-amp-theme-support.php @@ -922,8 +922,8 @@ public static function get_supportable_templates() { } $taxonomy_args = [ - '_builtin' => false, - 'publicly_queryable' => true, + '_builtin' => false, + 'public' => true, ]; foreach ( get_taxonomies( $taxonomy_args, 'objects' ) as $taxonomy ) { $templates[ sprintf( 'is_tax[%s]', $taxonomy->name ) ] = [ @@ -936,8 +936,8 @@ public static function get_supportable_templates() { } $post_type_args = [ - 'has_archive' => true, - 'publicly_queryable' => true, + 'has_archive' => true, + 'public' => true, ]; foreach ( get_post_types( $post_type_args, 'objects' ) as $post_type ) { $templates[ sprintf( 'is_post_type_archive[%s]', $post_type->name ) ] = [ From a1b291bee95d6891f62f1a3233f99e40383463d8 Mon Sep 17 00:00:00 2001 From: Alain Schlesser Date: Fri, 25 Oct 2019 07:44:32 +0200 Subject: [PATCH 2/4] Throw a _doing_it_wrong() when an expected parent is not found --- includes/class-amp-theme-support.php | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/includes/class-amp-theme-support.php b/includes/class-amp-theme-support.php index 9e56934b8a4..38dfd0e053f 100644 --- a/includes/class-amp-theme-support.php +++ b/includes/class-amp-theme-support.php @@ -715,7 +715,27 @@ public static function get_template_availability( $query = null ) { if ( ! $has_children ) { $supportable_template = $supportable_templates[ $id ]; while ( ! empty( $supportable_template['parent'] ) ) { - $parent = $supportable_template['parent']; + $parent = $supportable_template['parent']; + + /* + * If the parent is not amongst the supportable templates, then something is off in terms of hierarchy. + * Either the matching is off-track, or the template is badly configured. + */ + if ( ! array_key_exists( $parent, $supportable_templates ) ) { + _doing_it_wrong( + __METHOD__, + esc_html( + sprintf( + /* translators: %s: amp_supportable_templates */ + __( 'An expected parent was not found. Did you filter %s to not honor the template hierarchy?', 'amp' ), + 'amp_supportable_templates' + ) + ), + '1.4' + ); + break; + } + $supportable_template = $supportable_templates[ $parent ]; // Let the child supported status override the parent's supported status. From 1f5a241d62e44a4618fb3969010f1f1acdc369cd Mon Sep 17 00:00:00 2001 From: Alain Schlesser Date: Fri, 25 Oct 2019 08:56:43 +0200 Subject: [PATCH 3/4] Adapt broken test --- tests/php/test-class-amp-theme-support.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/php/test-class-amp-theme-support.php b/tests/php/test-class-amp-theme-support.php index 16cf8d35f7c..623d52ca37e 100644 --- a/tests/php/test-class-amp-theme-support.php +++ b/tests/php/test-class-amp-theme-support.php @@ -783,8 +783,8 @@ public function test_get_template_availability_with_ambiguity() { register_post_type( $custom_post_type, [ - 'has_archive' => true, - 'publicly_queryable' => true, + 'has_archive' => true, + 'public' => true, ] ); self::factory()->post->create( From 1adf6c86bb82eb5963ad746a118ad4557bd4062b Mon Sep 17 00:00:00 2001 From: Alain Schlesser Date: Fri, 25 Oct 2019 09:14:52 +0200 Subject: [PATCH 4/4] Add test case for broken parent relationship --- tests/php/test-class-amp-theme-support.php | 37 ++++++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/tests/php/test-class-amp-theme-support.php b/tests/php/test-class-amp-theme-support.php index 623d52ca37e..49143d9b4ef 100644 --- a/tests/php/test-class-amp-theme-support.php +++ b/tests/php/test-class-amp-theme-support.php @@ -813,6 +813,43 @@ public function test_get_template_availability_with_ambiguity() { $this->assertEquals( 'is_search', $availability['template'] ); } + /** + * Test get_template_availability with broken parent relationship. + * + * @covers AMP_Theme_Support::get_template_availability() + */ + public function test_get_template_availability_with_missing_parent() { + AMP_Options_Manager::update_option( 'supported_templates', [ 'missing_parent' ] ); + add_theme_support( AMP_Theme_Support::SLUG ); + add_filter( + 'amp_supportable_templates', + static function ( $templates ) { + $templates['missing_parent'] = [ + 'label' => 'Missing parent', + 'parent' => 'is_unknown', + 'callback' => static function( WP_Query $query ) { + return false !== $query->get( 'missing_parent', false ); + }, + ]; + return $templates; + } + ); + add_filter( + 'query_vars', + static function ( $vars ) { + $vars[] = 'missing_parent'; + return $vars; + } + ); + + // Test missing_parent. + $this->go_to( '/?missing_parent=1' ); + $this->setExpectedIncorrectUsage( 'AMP_Theme_Support::get_template_availability' ); + $availability = AMP_Theme_Support::get_template_availability(); + $this->assertTrue( $availability['supported'] ); + $this->assertEquals( 'missing_parent', $availability['template'] ); + } + /** * Test get_supportable_templates. *