Ticket #44005: 44005.4.diff
File 44005.4.diff, 12.8 KB (added by , 6 years ago) |
---|
-
src/wp-admin/includes/file.php
36 36 'single.php' => __( 'Single Post' ), 37 37 'page.php' => __( 'Single Page' ), 38 38 'front-page.php' => __( 'Homepage' ), 39 'privacy-policy.php' => __( 'Privacy Policy Page' ), 39 40 // Attachments 40 41 'attachment.php' => __( 'Attachment Template' ), 41 42 'image.php' => __( 'Image Attachment Template' ), -
src/wp-includes/class-wp-query.php
326 326 public $is_home = false; 327 327 328 328 /** 329 * Signifies whether the current query is for the Privacy Policy page. 330 * 331 * @since 5.2.0 332 * @var bool 333 */ 334 public $is_privacy_policy = false; 335 336 /** 329 337 * Signifies whether the current query couldn't find anything. 330 338 * 331 339 * @since 1.5.0 … … 463 471 $this->is_comment_feed = false; 464 472 $this->is_trackback = false; 465 473 $this->is_home = false; 474 $this->is_privacy_policy = false; 466 475 $this->is_404 = false; 467 476 $this->is_paged = false; 468 477 $this->is_admin = false; … … 998 1007 $this->is_home = true; 999 1008 $this->is_posts_page = true; 1000 1009 } 1010 1011 if ( isset( $this->queried_object_id ) && $this->queried_object_id == get_option( 'wp_page_for_privacy_policy' ) ) { 1012 $this->is_privacy_policy = true; 1013 } 1001 1014 } 1002 1015 1003 1016 if ( $qv['page_id'] ) { … … 1006 1019 $this->is_home = true; 1007 1020 $this->is_posts_page = true; 1008 1021 } 1022 1023 if ( $qv['page_id'] == get_option( 'wp_page_for_privacy_policy' ) ) { 1024 $this->is_privacy_policy = true; 1025 } 1009 1026 } 1010 1027 1011 1028 if ( ! empty( $qv['post_type'] ) ) { … … 3878 3895 } 3879 3896 3880 3897 /** 3898 * Is the query for the Privacy Policy page? 3899 * 3900 * This is the page which shows the Privacy Policy content of your site. 3901 * 3902 * Depends on the site's "Change your Privacy Policy page" Privacy Settings 'wp_page_for_privacy_policy'. 3903 * 3904 * This function will return true only on the page you set as the "Privacy Policy page". 3905 * 3906 * @see WP_Query::is_front_page() 3907 * 3908 * @since 5.2.0 3909 * 3910 * @return bool True, if Privacy Policy page. 3911 */ 3912 public function is_privacy_policy() { 3913 if ( get_option( 'wp_page_for_privacy_policy' ) && $this->is_page( get_option( 'wp_page_for_privacy_policy' ) ) ) { 3914 return true; 3915 } else { 3916 return false; 3917 } 3918 } 3919 3920 /** 3881 3921 * Is the query for an existing month archive? 3882 3922 * 3883 3923 * @since 3.1.0 -
src/wp-includes/post-template.php
603 603 if ( is_home() ) { 604 604 $classes[] = 'blog'; 605 605 } 606 if ( is_privacy_policy() ) { 607 $classes[] = 'privacy-policy'; 608 } 606 609 if ( is_archive() ) { 607 610 $classes[] = 'archive'; 608 611 } -
src/wp-includes/query.php
490 490 } 491 491 492 492 /** 493 * Determines whether the query is for the Privacy Policy page. 494 * 495 * The Privacy Policy page is the page that shows the Privacy Policy content of the site. 496 * 497 * is_privacy_policy() is dependent on the site's "Change your Privacy Policy page" Privacy Settings 'wp_page_for_privacy_policy'. 498 * 499 * This function will return true only on the page you set as the "Privacy Policy page". 500 * 501 * For more information on this and similar theme functions, check out 502 * the {@link https://developer.wordpress.org/themes/basics/conditional-tags/ 503 * Conditional Tags} article in the Theme Developer Handbook. 504 * 505 * @since 5.2.0 506 * 507 * @global WP_Query $wp_query Global WP_Query instance. 508 * 509 * @return bool 510 */ 511 function is_privacy_policy() { 512 global $wp_query; 513 514 if ( ! isset( $wp_query ) ) { 515 _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1.0' ); 516 return false; 517 } 518 519 return $wp_query->is_privacy_policy(); 520 } 521 522 /** 493 523 * Determines whether the query is for an existing month archive. 494 524 * 495 525 * For more information on this and similar theme functions, check out -
src/wp-includes/template-loader.php
51 51 elseif ( is_search() && $template = get_search_template() ) : 52 52 elseif ( is_front_page() && $template = get_front_page_template() ) : 53 53 elseif ( is_home() && $template = get_home_template() ) : 54 elseif ( is_privacy_policy() && $template = get_privacy_policy_template() ) : 54 55 elseif ( is_post_type_archive() && $template = get_post_type_archive_template() ) : 55 56 elseif ( is_tax() && $template = get_taxonomy_template() ) : 56 57 elseif ( is_attachment() && $template = get_attachment_template() ) : -
src/wp-includes/template.php
33 33 * The last element in the array should always be the fallback template for this query type. 34 34 * 35 35 * Possible values for `$type` include: 'index', '404', 'archive', 'author', 'category', 'tag', 'taxonomy', 'date', 36 * 'embed', 'home', 'frontpage', 'p age', 'paged', 'search', 'single', 'singular', and 'attachment'.36 * 'embed', 'home', 'frontpage', 'privacypolicy', 'page', 'paged', 'search', 'single', 'singular', and 'attachment'. 37 37 * 38 38 * @since 4.7.0 39 39 * … … 51 51 * This hook also applies to various types of files loaded as part of the Template Hierarchy. 52 52 * 53 53 * Possible values for `$type` include: 'index', '404', 'archive', 'author', 'category', 'tag', 'taxonomy', 'date', 54 * 'embed', 'home', 'frontpage', 'p age', 'paged', 'search', 'single', 'singular', and 'attachment'.54 * 'embed', 'home', 'frontpage', 'privacypolicy', 'page', 'paged', 'search', 'single', 'singular', and 'attachment'. 55 55 * 56 56 * @since 1.5.0 57 57 * @since 4.8.0 The `$type` and `$templates` parameters were added. … … 377 377 } 378 378 379 379 /** 380 * Retrieve path of Privacy Policy page template in current or parent template. 381 * 382 * The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'} 383 * and {@see '$type_template'} dynamic hooks, where `$type` is 'privacypolicy'. 384 * 385 * @since 5.2.0 386 * 387 * @see get_query_template() 388 * 389 * @return string Full path to front page template file. 390 */ 391 function get_privacy_policy_template() { 392 $templates = array( 'privacy-policy.php' ); 393 394 return get_query_template( 'privacy_policy', $templates ); 395 } 396 397 /** 380 398 * Retrieve path of page template in current or parent template. 381 399 * 382 400 * The hierarchy for this template looks like: -
tests/phpunit/includes/abstract-testcase.php
821 821 'is_feed', 822 822 'is_front_page', 823 823 'is_home', 824 'is_privacy_policy', 824 825 'is_month', 825 826 'is_page', 826 827 'is_paged', -
tests/phpunit/tests/post/getBodyClass.php
202 202 $this->assertContains( "attachmentid-{$attachment_id}", $class ); 203 203 $this->assertContains( 'attachment-jpeg', $class ); 204 204 } 205 206 /** 207 * @ticket 44005 208 * @group privacy 209 */ 210 public function test_privacy_policy_body_class() { 211 $page_id = self::factory()->post->create( 212 array( 213 'post_type' => 'page', 214 'post_title' => 'Privacy Policy', 215 ) 216 ); 217 update_option( 'wp_page_for_privacy_policy', $page_id ); 218 219 $this->go_to( get_permalink( $page_id ) ); 220 221 $class = get_body_class(); 222 223 $this->assertContains( 'privacy-policy', $class ); 224 $this->assertContains( 'page-template-default', $class ); 225 $this->assertContains( 'page', $class ); 226 $this->assertContains( "page-id-{$page_id}", $class ); 227 } 228 205 229 } -
tests/phpunit/tests/query/conditionals.php
1590 1590 $this->assertTrue( is_single( $p2 ) ); 1591 1591 $this->assertFalse( is_single( $p1 ) ); 1592 1592 } 1593 1594 /** 1595 * @ticket 44005 1596 * @group privacy 1597 */ 1598 public function test_is_privacy_policy() { 1599 $page_id = self::factory()->post->create( 1600 array( 1601 'post_type' => 'page', 1602 'post_title' => 'Privacy Policy', 1603 ) 1604 ); 1605 1606 update_option( 'wp_page_for_privacy_policy', $page_id ); 1607 1608 $this->go_to( get_permalink( $page_id ) ); 1609 1610 $this->assertQueryTrue( 'is_page', 'is_singular', 'is_privacy_policy' ); 1611 } 1612 1593 1613 } -
tests/phpunit/tests/template.php
13 13 protected static $page; 14 14 protected static $post; 15 15 16 /** 17 * Page For Privacy Policy. 18 * 19 * @since 5.2.0 20 * 21 * @var WP_Post $page_for_privacy_policy 22 */ 23 protected static $page_for_privacy_policy; 24 16 25 public static function wpSetUpBeforeClass( WP_UnitTest_Factory $factory ) { 17 26 self::$page_on_front = $factory->post->create_and_get( 18 27 array( … … 45 54 ); 46 55 set_post_format( self::$post, 'quote' ); 47 56 add_post_meta( self::$post->ID, '_wp_page_template', 'templates/post.php' ); 57 58 self::$page_for_privacy_policy = $factory->post->create_and_get( 59 array( 60 'post_type' => 'page', 61 'post_title' => 'Privacy Policy', 62 ) 63 ); 48 64 } 49 65 50 66 public function setUp() { … … 273 289 } 274 290 275 291 /** 292 * @ticket 44005 293 * @group privacy 294 */ 295 public function test_privacy_template_hierarchy() { 296 update_option( 'wp_page_for_privacy_policy', self::$page_for_privacy_policy->ID ); 297 298 $this->assertTemplateHierarchy( 299 get_permalink( self::$page_for_privacy_policy->ID ), 300 array( 301 'privacy-policy.php', 302 'page-privacy-policy.php', 303 'page-' . self::$page_for_privacy_policy->ID . '.php', 304 'page.php', 305 'singular.php', 306 ) 307 ); 308 } 309 310 /** 276 311 * @ticket 18375 277 312 */ 278 313 public function test_single_template_hierarchy_for_post() { … … 436 471 'search' => 'is_search', 437 472 'front_page' => 'is_front_page', 438 473 'home' => 'is_home', 474 'privacy_policy' => 'is_privacy_policy', 439 475 'post_type_archive' => 'is_post_type_archive', 440 476 'taxonomy' => 'is_tax', 441 477 'attachment' => 'is_attachment', -
tests/phpunit/tests/theme.php
288 288 $this->assertEquals( get_category_template(), get_query_template( 'category' ) ); 289 289 $this->assertEquals( get_date_template(), get_query_template( 'date' ) ); 290 290 $this->assertEquals( get_home_template(), get_query_template( 'home', array( 'home.php', 'index.php' ) ) ); 291 $this->assertEquals( get_privacy_policy_template(), get_query_template( 'privacy_policy', array( 'privacy-policy.php' ) ) ); 291 292 $this->assertEquals( get_page_template(), get_query_template( 'page' ) ); 292 293 $this->assertEquals( get_search_template(), get_query_template( 'search' ) ); 293 294 $this->assertEquals( get_single_template(), get_query_template( 'single' ) ); -
tests/phpunit/tests/url/getPrivacyPolicyUrl.php
45 45 'post_title' => WP_TESTS_DOMAIN . ' Privacy Policy', 46 46 ) 47 47 ); 48 49 self::$privacy_policy_url = get_permalink( self::$privacy_policy_page_id );50 48 } 51 49 52 50 /** … … 60 58 * The function should return the privacy policy URL when `wp_page_for_privacy_policy` is set. 61 59 */ 62 60 public function test_get_privacy_policy_url_should_return_valid_url_when_policy_page_set() { 61 $privacy_policy_url = get_permalink( self::$privacy_policy_page_id ); 63 62 update_option( 'wp_page_for_privacy_policy', self::$privacy_policy_page_id ); 64 63 65 $this->assertSame( self::$privacy_policy_url, get_privacy_policy_url() );64 $this->assertSame( $privacy_policy_url, get_privacy_policy_url() ); 66 65 } 67 66 68 67 /**