Query: Improve tests for set_found_posts dealing with non arrays
Use a data provider and include tests for `false` and `''`. Previous: [42581] [42585] See #42860 git-svn-id: https://develop.svn.wordpress.org/trunk@42594 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
dd9122b011
commit
47f6031fbd
@ -643,35 +643,22 @@ class Tests_Post_Query extends WP_UnitTestCase {
|
|||||||
$this->assertEquals( 2, $q->max_num_pages );
|
$this->assertEquals( 2, $q->max_num_pages );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public function set_found_posts_provider() {
|
||||||
* @ticket 42860
|
// count return 0 for null, but 1 for other data you may not expect
|
||||||
*/
|
return array(
|
||||||
public function test_set_found_posts_fields_posts_is_string() {
|
array( null, 0 ),
|
||||||
if ( version_compare( PHP_VERSION, '5.3', '<' ) ) {
|
array( '', 1 ),
|
||||||
$this->markTestSkipped( 'ReflectionMethod::setAccessible is only available in PHP 5.3+' );
|
array( "To life, to life, l'chaim", 1 ),
|
||||||
return;
|
array( false, 1 ),
|
||||||
}
|
|
||||||
|
|
||||||
$q = new WP_Query(
|
|
||||||
array(
|
|
||||||
'post_type' => 'wptests_pt',
|
|
||||||
'posts_per_page' => 1,
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
$q->posts = "To life, to life, l'chaim";
|
|
||||||
|
|
||||||
$methd = new \ReflectionMethod( 'WP_Query', 'set_found_posts' );
|
|
||||||
$methd->setAccessible( true );
|
|
||||||
$methd->invoke( $q, array( 'no_found_rows' => false ), array() );
|
|
||||||
|
|
||||||
$this->assertEquals( 1, $q->found_posts );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ticket 42860
|
* @ticket 42860
|
||||||
|
*
|
||||||
|
* @dataProvider set_found_posts_provider
|
||||||
*/
|
*/
|
||||||
public function test_set_found_posts_fields_posts_is_null() {
|
public function test_set_found_posts_not_posts_as_an_array( $posts, $expected ) {
|
||||||
if ( version_compare( PHP_VERSION, '5.3', '<' ) ) {
|
if ( version_compare( PHP_VERSION, '5.3', '<' ) ) {
|
||||||
$this->markTestSkipped( 'ReflectionMethod::setAccessible is only available in PHP 5.3+' );
|
$this->markTestSkipped( 'ReflectionMethod::setAccessible is only available in PHP 5.3+' );
|
||||||
return;
|
return;
|
||||||
@ -684,13 +671,13 @@ class Tests_Post_Query extends WP_UnitTestCase {
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
$q->posts = null;
|
$q->posts = $posts;
|
||||||
|
|
||||||
$methd = new \ReflectionMethod( 'WP_Query', 'set_found_posts' );
|
$methd = new \ReflectionMethod( 'WP_Query', 'set_found_posts' );
|
||||||
$methd->setAccessible( true );
|
$methd->setAccessible( true );
|
||||||
$methd->invoke( $q, array( 'no_found_rows' => false ), array() );
|
$methd->invoke( $q, array( 'no_found_rows' => false ), array() );
|
||||||
|
|
||||||
$this->assertEquals( 0, $q->found_posts );
|
$this->assertEquals( $expected, $q->found_posts );
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user