Tests: Use a data provider in get_site_by_path() tests

See #36566, #34941.


git-svn-id: https://develop.svn.wordpress.org/trunk@37237 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Jeremy Felt 2016-04-18 02:38:49 +00:00
parent 48ba391b9b
commit 5e2f936c28

View File

@ -86,71 +86,54 @@ class Tests_Multisite_Bootstrap extends WP_UnitTestCase {
/** /**
* @ticket 27003 * @ticket 27003
* @ticket 27927 * @ticket 27927
* @dataProvider data_get_site_by_path
*
* @param string $expected_key The array key associated with expected data for the test.
* @param string $domain The requested domain.
* @param string $path The requested path.
* @param int $segments Optional. Number of segments to use in `get_site_by_path()`.
*/ */
function test_get_site_by_path() { public function test_get_site_by_path( $expected_key, $domain, $path, $segments = null ) {
$this->assertEquals( self::$site_ids['wordpress.org/'], $site = get_site_by_path( $domain, $path, $segments );
get_site_by_path( 'wordpress.org', '/notapath/' )->blog_id );
$this->assertEquals( self::$site_ids['wordpress.org/'], if ( $expected_key ) {
get_site_by_path( 'www.wordpress.org', '/notapath/' )->blog_id ); $this->assertEquals( self::$site_ids[ $expected_key ], $site->blog_id );
} else {
$this->assertFalse( $site );
}
}
$this->assertEquals( self::$site_ids['wordpress.org/foo/bar/'], public function data_get_site_by_path() {
get_site_by_path( 'wordpress.org', '/foo/bar/baz/' )->blog_id ); return array(
array( 'wordpress.org/', 'wordpress.org', '/notapath/' ),
$this->assertEquals( self::$site_ids['wordpress.org/foo/bar/'], array( 'wordpress.org/', 'www.wordpress.org', '/notapath/' ),
get_site_by_path( 'www.wordpress.org', '/foo/bar/baz/' )->blog_id ); array( 'wordpress.org/foo/bar/', 'wordpress.org', '/foo/bar/baz/' ),
array( 'wordpress.org/foo/bar/', 'www.wordpress.org', '/foo/bar/baz/' ),
$this->assertEquals( self::$site_ids['wordpress.org/foo/bar/'], array( 'wordpress.org/foo/bar/', 'wordpress.org', '/foo/bar/baz/', 3 ),
get_site_by_path( 'wordpress.org', '/foo/bar/baz/', 3 )->blog_id ); array( 'wordpress.org/foo/bar/', 'www.wordpress.org', '/foo/bar/baz/', 3 ),
array( 'wordpress.org/foo/bar/', 'wordpress.org', '/foo/bar/baz/', 2 ),
$this->assertEquals( self::$site_ids['wordpress.org/foo/bar/'], array( 'wordpress.org/foo/bar/', 'www.wordpress.org', '/foo/bar/baz/', 2 ),
get_site_by_path( 'www.wordpress.org', '/foo/bar/baz/', 3 )->blog_id ); array( 'wordpress.org/foo/', 'wordpress.org', '/foo/bar/baz/', 1 ),
array( 'wordpress.org/foo/', 'www.wordpress.org', '/foo/bar/baz/', 1 ),
$this->assertEquals( self::$site_ids['wordpress.org/foo/bar/'], array( 'wordpress.org/', 'wordpress.org', '/', 0 ),
get_site_by_path( 'wordpress.org', '/foo/bar/baz/', 2 )->blog_id ); array( 'wordpress.org/', 'www.wordpress.org', '/', 0 ),
array( 'make.wordpress.org/foo/', 'make.wordpress.org', '/foo/bar/baz/quz/', 4 ),
$this->assertEquals( self::$site_ids['wordpress.org/foo/bar/'], array( 'make.wordpress.org/foo/', 'www.make.wordpress.org', '/foo/bar/baz/quz/', 4 ),
get_site_by_path( 'www.wordpress.org', '/foo/bar/baz/', 2 )->blog_id ); array( 'www.w.org/', 'www.w.org', '/', 0 ),
array( 'www.w.org/', 'www.w.org', '/notapath' ),
$this->assertEquals( self::$site_ids['wordpress.org/foo/'], array( 'www.w.org/foo/bar/', 'www.w.org', '/foo/bar/baz/' ),
get_site_by_path( 'wordpress.org', '/foo/bar/baz/', 1 )->blog_id ); array( 'www.w.org/foo/', 'www.w.org', '/foo/bar/baz/', 1 ),
$this->assertEquals( self::$site_ids['wordpress.org/foo/'],
get_site_by_path( 'www.wordpress.org', '/foo/bar/baz/', 1 )->blog_id );
$this->assertEquals( self::$site_ids['wordpress.org/'],
get_site_by_path( 'wordpress.org', '/', 0 )->blog_id );
$this->assertEquals( self::$site_ids['wordpress.org/'],
get_site_by_path( 'www.wordpress.org', '/', 0 )->blog_id );
$this->assertEquals( self::$site_ids['make.wordpress.org/foo/'],
get_site_by_path( 'make.wordpress.org', '/foo/bar/baz/qux/', 4 )->blog_id );
$this->assertEquals( self::$site_ids['make.wordpress.org/foo/'],
get_site_by_path( 'www.make.wordpress.org', '/foo/bar/baz/qux/', 4 )->blog_id );
$this->assertEquals( self::$site_ids['www.w.org/'],
get_site_by_path( 'www.w.org', '/', 0 )->blog_id );
$this->assertEquals( self::$site_ids['www.w.org/'],
get_site_by_path( 'www.w.org', '/notapath/' )->blog_id );
$this->assertEquals( self::$site_ids['www.w.org/foo/bar/'],
get_site_by_path( 'www.w.org', '/foo/bar/baz/' )->blog_id );
$this->assertEquals( self::$site_ids['www.w.org/foo/'],
get_site_by_path( 'www.w.org', '/foo/bar/baz/', 1 )->blog_id );
// A site installed with www will not be found by the root domain. // A site installed with www will not be found by the root domain.
$this->assertFalse( get_site_by_path( 'w.org', '/' ) ); array( false, 'w.org', '/' ),
$this->assertFalse( get_site_by_path( 'w.org', '/notapath/' ) ); array( false, 'w.org', '/notapath/' ),
$this->assertFalse( get_site_by_path( 'w.org', '/foo/bar/baz/' ) ); array( false, 'w.org', '/foo/bar/baz/' ),
$this->assertFalse( get_site_by_path( 'w.org', '/foo/bar/baz/', 1 ) ); array( false, 'w.org', '/foo/bar/baz/', 1 ),
// A site will not be found by its root domain when an invalid subdomain is requested. // A site will not be found by its root domain when an invalid subdomain is requested.
$this->assertFalse( get_site_by_path( 'invalid.wordpress.org', '/' ) ); array( false, 'invalid.wordpress.org', '/' ),
$this->assertFalse( get_site_by_path( 'invalid.wordpress.org', '/foo/bar/' ) ); array( false, 'invalid.wordpress.org', '/foo/bar/' ),
);
} }
/** /**