Posts, Post Types: Ensure that all post stati are countable in wp_count_posts
.
When `wp_count_posts()` is cached, it does so with all statuses defaulted to 0. The problem is however, if this is called before all plugins have registered their desired statuses, they won't have that default. Fixes #49685. Props obliviousharmony, SergeyBiryukov. git-svn-id: https://develop.svn.wordpress.org/trunk@48497 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
ceccb7b3b1
commit
082cb0ab20
@ -2647,6 +2647,13 @@ function wp_count_posts( $type = 'post', $perm = '' ) {
|
|||||||
|
|
||||||
$counts = wp_cache_get( $cache_key, 'counts' );
|
$counts = wp_cache_get( $cache_key, 'counts' );
|
||||||
if ( false !== $counts ) {
|
if ( false !== $counts ) {
|
||||||
|
// We may have cached this before every status was registered.
|
||||||
|
foreach ( get_post_stati() as $status ) {
|
||||||
|
if ( ! isset( $counts->{$status} ) ) {
|
||||||
|
$counts->{$status} = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/** This filter is documented in wp-includes/post.php */
|
/** This filter is documented in wp-includes/post.php */
|
||||||
return apply_filters( 'wp_count_posts', $counts, $type, $perm );
|
return apply_filters( 'wp_count_posts', $counts, $type, $perm );
|
||||||
}
|
}
|
||||||
|
@ -879,6 +879,22 @@ class Tests_Post extends WP_UnitTestCase {
|
|||||||
$this->assertNotEquals( $initial_counts->publish, $after_trash_counts->publish );
|
$this->assertNotEquals( $initial_counts->publish, $after_trash_counts->publish );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ticket 49685
|
||||||
|
*/
|
||||||
|
function test_wp_count_posts_status_changes_visible() {
|
||||||
|
self::factory()->post->create_many( 3 );
|
||||||
|
|
||||||
|
// Trigger a cache.
|
||||||
|
wp_count_posts();
|
||||||
|
|
||||||
|
register_post_status( 'test' );
|
||||||
|
|
||||||
|
$counts = wp_count_posts();
|
||||||
|
$this->assertTrue( isset( $counts->test ) );
|
||||||
|
$this->assertEquals( 0, $counts->test );
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ticket 13771
|
* @ticket 13771
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user