mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2025-10-16 12:05:38 +00:00
* Automatically delete objects that we were created during `wpSetUpBeforeClass` - posts, comments, terms (except 1), and user (except 1) * The amount of leftover data between tests was breathtaking - use the new function: `_delete_all_data()` * Commit database transactions for all `TestCase`s, not just those that implement `wpSetUpBeforeClass` and `wpTearDownAfterClass` * The tests run 10-20 seconds faster now See #37699. git-svn-id: https://develop.svn.wordpress.org/trunk@38398 602fd350-edb4-49c9-b593-d223f7449a82
96 lines
1.9 KiB
PHP
96 lines
1.9 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group post
|
|
*/
|
|
class Tests_Post_WpPost extends WP_UnitTestCase {
|
|
protected static $post_id;
|
|
|
|
public static function wpSetUpBeforeClass( $factory ) {
|
|
global $wpdb;
|
|
|
|
// Ensure that there is a post with ID 1.
|
|
if ( ! get_post( 1 ) ) {
|
|
$wpdb->insert( $wpdb->posts, array(
|
|
'ID' => 1,
|
|
'post_title' => 'Post 1',
|
|
) );
|
|
}
|
|
|
|
self::$post_id = self::factory()->post->create();
|
|
}
|
|
|
|
/**
|
|
* @ticket 37738
|
|
*/
|
|
public function test_get_instance_should_work_for_numeric_string() {
|
|
$found = WP_Post::get_instance( (string) self::$post_id );
|
|
|
|
$this->assertSame( self::$post_id, $found->ID );
|
|
}
|
|
|
|
/**
|
|
* @ticket 37738
|
|
*/
|
|
public function test_get_instance_should_fail_for_negative_number() {
|
|
$found = WP_Post::get_instance( -self::$post_id );
|
|
|
|
$this->assertFalse( $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 37738
|
|
*/
|
|
public function test_get_instance_should_fail_for_non_numeric_string() {
|
|
$found = WP_Post::get_instance( 'abc' );
|
|
|
|
$this->assertFalse( $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 37738
|
|
*/
|
|
public function test_get_instance_should_fail_for_bool() {
|
|
$found = WP_Post::get_instance( true );
|
|
|
|
$this->assertFalse( $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 37738
|
|
*/
|
|
public function test_get_instance_should_succeed_for_float_that_is_equal_to_post_id() {
|
|
$found = WP_Post::get_instance( 1.0 );
|
|
|
|
$this->assertSame( 1, $found->ID );
|
|
}
|
|
|
|
/**
|
|
* @ticket 37738
|
|
*/
|
|
public function test_get_instance_should_fail_for_float() {
|
|
$found = WP_Post::get_instance( 1.6 );
|
|
|
|
$this->assertFalse( $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 37738
|
|
*/
|
|
public function test_get_instance_should_fail_for_array() {
|
|
$found = WP_Post::get_instance( array( 1 ) );
|
|
|
|
$this->assertFalse( $found );
|
|
}
|
|
|
|
/**
|
|
* @ticket 37738
|
|
*/
|
|
public function test_get_instance_should_fail_for_class() {
|
|
$class = new stdClass();
|
|
$found = WP_Post::get_instance( $class );
|
|
|
|
$this->assertFalse( $found );
|
|
}
|
|
}
|