Properly set $subdomain_error to false when applicable in ms_subdomain_constants(). This was previously untestable because it used static vars: use globals instead.

Adds unit test.
Fixes #28697.


git-svn-id: https://develop.svn.wordpress.org/trunk@29200 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Scott Taylor 2014-07-16 22:34:18 +00:00
parent 8a5d825fac
commit bda6f0cffe
2 changed files with 25 additions and 10 deletions

View File

@ -114,17 +114,20 @@ function ms_file_constants() {
* we will have translations loaded and can trigger warnings easily. * we will have translations loaded and can trigger warnings easily.
* *
* @since 3.0.0 * @since 3.0.0
*
* @global boolean $subdomain_error
* @global boolean $subdomain_error_warn
*/ */
function ms_subdomain_constants() { function ms_subdomain_constants() {
static $error = null; global $subdomain_error, $subdomain_error_warn;
static $error_warn = false;
if ( false === $error ) if ( false === $subdomain_error ) {
return; return;
}
if ( $error ) { if ( $subdomain_error ) {
$vhost_deprecated = __( 'The constant <code>VHOST</code> <strong>is deprecated</strong>. Use the boolean constant <code>SUBDOMAIN_INSTALL</code> in wp-config.php to enable a subdomain configuration. Use is_subdomain_install() to check whether a subdomain configuration is enabled.' ); $vhost_deprecated = __( 'The constant <code>VHOST</code> <strong>is deprecated</strong>. Use the boolean constant <code>SUBDOMAIN_INSTALL</code> in wp-config.php to enable a subdomain configuration. Use is_subdomain_install() to check whether a subdomain configuration is enabled.' );
if ( $error_warn ) { if ( $subdomain_error_warn ) {
trigger_error( __( '<strong>Conflicting values for the constants VHOST and SUBDOMAIN_INSTALL.</strong> The value of SUBDOMAIN_INSTALL will be assumed to be your subdomain configuration setting.' ) . ' ' . $vhost_deprecated, E_USER_WARNING ); trigger_error( __( '<strong>Conflicting values for the constants VHOST and SUBDOMAIN_INSTALL.</strong> The value of SUBDOMAIN_INSTALL will be assumed to be your subdomain configuration setting.' ) . ' ' . $vhost_deprecated, E_USER_WARNING );
} else { } else {
_deprecated_argument( 'define()', '3.0', $vhost_deprecated ); _deprecated_argument( 'define()', '3.0', $vhost_deprecated );
@ -133,17 +136,18 @@ function ms_subdomain_constants() {
} }
if ( defined( 'SUBDOMAIN_INSTALL' ) && defined( 'VHOST' ) ) { if ( defined( 'SUBDOMAIN_INSTALL' ) && defined( 'VHOST' ) ) {
if ( SUBDOMAIN_INSTALL == ( 'yes' == VHOST ) ) { $subdomain_error = true;
$error = true; if ( SUBDOMAIN_INSTALL !== ( 'yes' == VHOST ) ) {
} else { $subdomain_error_warn = true;
$error = $error_warn = true;
} }
} elseif ( defined( 'SUBDOMAIN_INSTALL' ) ) { } elseif ( defined( 'SUBDOMAIN_INSTALL' ) ) {
$subdomain_error = false;
define( 'VHOST', SUBDOMAIN_INSTALL ? 'yes' : 'no' ); define( 'VHOST', SUBDOMAIN_INSTALL ? 'yes' : 'no' );
} elseif ( defined( 'VHOST' ) ) { } elseif ( defined( 'VHOST' ) ) {
$error = true; $subdomain_error = true;
define( 'SUBDOMAIN_INSTALL', 'yes' == VHOST ); define( 'SUBDOMAIN_INSTALL', 'yes' == VHOST );
} else { } else {
$subdomain_error = false;
define( 'SUBDOMAIN_INSTALL', false ); define( 'SUBDOMAIN_INSTALL', false );
define( 'VHOST', 'no' ); define( 'VHOST', 'no' );
} }

View File

@ -25,6 +25,17 @@ class Tests_MS extends WP_UnitTestCase {
$wpdb->suppress_errors( $this->suppress ); $wpdb->suppress_errors( $this->suppress );
} }
/**
* @ticket 28697
*/
function test_ms_subdomain_constants() {
global $subdomain_error;
$this->assertFalse( $subdomain_error );
ms_subdomain_constants();
$this->assertFalse( $subdomain_error );
}
function test_remove_user_from_blog() { function test_remove_user_from_blog() {
$user1 = $this->factory->user->create_and_get(); $user1 = $this->factory->user->create_and_get();
$user2 = $this->factory->user->create_and_get(); $user2 = $this->factory->user->create_and_get();