Unit Tests: one $factory to rule them all, and it shall be static.

Using more than one instance of `WP_UnitTest_Factory` causes all kinds of craziness, due to out-of-sync internal generator sequences. Since we want to use `setUpBeforeClass`, we were creating ad hoc instances. To avoid that, we were injecting one `static` instance via Dependency Injection in `wpSetUpBeforeClass`. All tests should really use the `static` instance, so we will remove the instance prop `$factory`.

Replace `$this->factory` with `self::$factory` over 2000 times.
Rewrite all of the tests that were hard-coding dynamic values. 

#YOLOFriday



git-svn-id: https://develop.svn.wordpress.org/trunk@35225 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Scott Taylor
2015-10-16 21:04:12 +00:00
parent 84272ff8cd
commit e70ebea219
169 changed files with 2631 additions and 2616 deletions

View File

@@ -15,7 +15,7 @@ class Tests_AdminBar extends WP_UnitTestCase {
* @ticket 21117
*/
function test_content_post_type() {
wp_set_current_user( $this->factory->user->create( array( 'role' => 'editor' ) ) );
wp_set_current_user( self::$factory->user->create( array( 'role' => 'editor' ) ) );
register_post_type( 'content', array( 'show_in_admin_bar' => true ) );
@@ -34,7 +34,7 @@ class Tests_AdminBar extends WP_UnitTestCase {
* @ticket 21117
*/
function test_merging_existing_meta_values() {
wp_set_current_user( $this->factory->user->create( array( 'role' => 'editor' ) ) );
wp_set_current_user( self::$factory->user->create( array( 'role' => 'editor' ) ) );
$admin_bar = new WP_Admin_Bar;
@@ -62,7 +62,7 @@ class Tests_AdminBar extends WP_UnitTestCase {
$this->markTestSkipped( 'Test does not run in multisite' );
}
$nobody = $this->factory->user->create( array( 'role' => '' ) );
$nobody = self::$factory->user->create( array( 'role' => '' ) );
$this->assertFalse( user_can( $nobody, 'read' ) );
wp_set_current_user( $nobody );
@@ -92,7 +92,7 @@ class Tests_AdminBar extends WP_UnitTestCase {
$this->markTestSkipped( 'Test does not run in multisite' );
}
$editor = $this->factory->user->create( array( 'role' => 'editor' ) );
$editor = self::$factory->user->create( array( 'role' => 'editor' ) );
$this->assertTrue( user_can( $editor, 'read' ) );
wp_set_current_user( $editor );
@@ -125,13 +125,13 @@ class Tests_AdminBar extends WP_UnitTestCase {
$this->markTestSkipped( 'Test only runs in multisite' );
}
$admin = $this->factory->user->create( array( 'role' => 'administrator' ) );
$editor = $this->factory->user->create( array( 'role' => 'editor' ) );
$admin = self::$factory->user->create( array( 'role' => 'administrator' ) );
$editor = self::$factory->user->create( array( 'role' => 'editor' ) );
$this->assertTrue( user_can( $admin, 'read' ) );
$this->assertTrue( user_can( $editor, 'read' ) );
$new_blog_id = $this->factory->blog->create( array(
$new_blog_id = self::$factory->blog->create( array(
'user_id' => $admin,
) );
@@ -179,13 +179,13 @@ class Tests_AdminBar extends WP_UnitTestCase {
$this->markTestSkipped( 'Test only runs in multisite' );
}
$admin = $this->factory->user->create( array( 'role' => 'administrator' ) );
$nobody = $this->factory->user->create( array( 'role' => '' ) );
$admin = self::$factory->user->create( array( 'role' => 'administrator' ) );
$nobody = self::$factory->user->create( array( 'role' => '' ) );
$this->assertTrue( user_can( $admin, 'read' ) );
$this->assertFalse( user_can( $nobody, 'read' ) );
$new_blog_id = $this->factory->blog->create( array(
$new_blog_id = self::$factory->blog->create( array(
'user_id' => $admin,
) );