Wordpress/tests/phpunit/tests/comment/wpUpdateCommentCountNow.php
Aaron Jorbin ead6585754 Correct usage of Covers for Tests_Update_Comment_Count_Now
When @covers is used with a plain alphanumeric string, PHPUnit assumes that it is covering a class. If there is no class, it fails and exits rather than continuing to generate coverage. To cover a global function, the name must start with ::. See https://phpunit.de/manual/5.3/en/appendixes.annotations.html#appendixes.annotations.covers

[37445] for trunk

See #35060, #36867



git-svn-id: https://develop.svn.wordpress.org/trunk@37447 602fd350-edb4-49c9-b593-d223f7449a82
2016-05-17 20:19:50 +00:00

53 lines
1.6 KiB
PHP

<?php
/**
* @group comment
* @covers ::wp_update_comment_count_now
*/
class Tests_Update_Comment_Count_Now extends WP_UnitTestCase {
public function _return_100() {
return 100;
}
public function test_invalid_post_bails_early() {
$this->assertFalse( wp_update_comment_count_now( 100 ) );
$this->assertFalse( wp_update_comment_count_now( null ) );
$this->assertFalse( wp_update_comment_count_now( 0 ) );
}
public function test_regular_post_updates_comment_count() {
global $wpdb;
$post_id = self::factory()->post->create();
self::factory()->comment->create_post_comments( $post_id, 1 );
$this->assertSame( '1', get_comments_number( $post_id ) );
$num_queries = $wpdb->num_queries;
$this->assertTrue( wp_update_comment_count_now( $post_id ) );
$this->assertSame( $num_queries + 2, $wpdb->num_queries );
$this->assertSame( '1', get_comments_number( $post_id ) );
}
public function test_using_filter_adjusts_comment_count_without_an_additional_database_query() {
global $wpdb;
add_filter( 'pre_wp_update_comment_count_now', array( $this, '_return_100' ) );
$post_id = self::factory()->post->create();
self::factory()->comment->create_post_comments( $post_id, 1 );
$this->assertSame( '100', get_comments_number( $post_id ) );
$num_queries = $wpdb->num_queries;
$this->assertTrue( wp_update_comment_count_now( $post_id ) );
// Only one query is made instead of two.
$this->assertSame( $num_queries + 1, $wpdb->num_queries );
$this->assertSame( '100', get_comments_number( $post_id ) );
remove_filter( 'pre_wp_update_comment_count_now', array( $this, '_return_100' ) );
}
}