Site Health: Improve the reliability of asynchronous tests.
This change adds additional logic to catch HTTP failures that do not return a `WP_Error` object (for example, a wp-json REST API error error). This also fixes instances where REST API callbacks performed from cron do not work due to a lack of authentication by introducing a direct callback route that asynchronous tests can register. Props dd32, clorith, timothyblynjacobs. Fixes #51547. Built from https://develop.svn.wordpress.org/trunk@49232 git-svn-id: http://core.svn.wordpress.org/trunk@48994 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
0287a48764
commit
8778aa8922
|
@ -2158,16 +2158,19 @@ class WP_Site_Health {
|
||||||
'label' => __( 'Communication with WordPress.org' ),
|
'label' => __( 'Communication with WordPress.org' ),
|
||||||
'test' => rest_url( 'wp-site-health/v1/tests/dotorg-communication' ),
|
'test' => rest_url( 'wp-site-health/v1/tests/dotorg-communication' ),
|
||||||
'has_rest' => true,
|
'has_rest' => true,
|
||||||
|
'async_direct_test' => array( WP_Site_Health::get_instance(), 'get_test_dotorg_communication' ),
|
||||||
),
|
),
|
||||||
'background_updates' => array(
|
'background_updates' => array(
|
||||||
'label' => __( 'Background updates' ),
|
'label' => __( 'Background updates' ),
|
||||||
'test' => rest_url( 'wp-site-health/v1/tests/background-updates' ),
|
'test' => rest_url( 'wp-site-health/v1/tests/background-updates' ),
|
||||||
'has_rest' => true,
|
'has_rest' => true,
|
||||||
|
'async_direct_test' => array( WP_Site_Health::get_instance(), 'get_test_background_updates' ),
|
||||||
),
|
),
|
||||||
'loopback_requests' => array(
|
'loopback_requests' => array(
|
||||||
'label' => __( 'Loopback request' ),
|
'label' => __( 'Loopback request' ),
|
||||||
'test' => rest_url( 'wp-site-health/v1/tests/loopback-requests' ),
|
'test' => rest_url( 'wp-site-health/v1/tests/loopback-requests' ),
|
||||||
'has_rest' => true,
|
'has_rest' => true,
|
||||||
|
'async_direct_test' => array( WP_Site_Health::get_instance(), 'get_test_loopback_requests' ),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
@ -2208,6 +2211,9 @@ class WP_Site_Health {
|
||||||
* @type mixed $test A callable to perform a direct test, or a string AJAX action to be
|
* @type mixed $test A callable to perform a direct test, or a string AJAX action to be
|
||||||
* called to perform an async test.
|
* called to perform an async test.
|
||||||
* @type boolean $has_rest Optional. Denote if `$test` has a REST API endpoint.
|
* @type boolean $has_rest Optional. Denote if `$test` has a REST API endpoint.
|
||||||
|
* @type callable $async_direct_test A manner of directly calling the test marked as asynchronous, as
|
||||||
|
* the scheduled event can not authenticate, and endpoints may require
|
||||||
|
* authentication.
|
||||||
* }
|
* }
|
||||||
* }
|
* }
|
||||||
*/
|
*/
|
||||||
|
@ -2550,10 +2556,18 @@ class WP_Site_Health {
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ( $tests['async'] as $test ) {
|
foreach ( $tests['async'] as $test ) {
|
||||||
|
// Local endpoints may require authentication, so asynchronous tests can pass a direct test runner as well.
|
||||||
|
if ( ! empty( $test['async_direct_test'] ) && is_callable( $test['async_direct_test'] ) ) {
|
||||||
|
// This test is callable, do so and continue to the next asynchronous check.
|
||||||
|
$results[] = $this->perform_test( $test['async_direct_test'] );
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if ( is_string( $test['test'] ) ) {
|
if ( is_string( $test['test'] ) ) {
|
||||||
|
// Check if this test has a REST API endpoint.
|
||||||
if ( isset( $test['has_rest'] ) && $test['has_rest'] ) {
|
if ( isset( $test['has_rest'] ) && $test['has_rest'] ) {
|
||||||
$result_fetch = wp_remote_post(
|
$result_fetch = wp_remote_get(
|
||||||
rest_url( $test['test'] ),
|
$test['test'],
|
||||||
array(
|
array(
|
||||||
'body' => array(
|
'body' => array(
|
||||||
'_wpnonce' => wp_create_nonce( 'wp_rest' ),
|
'_wpnonce' => wp_create_nonce( 'wp_rest' ),
|
||||||
|
@ -2572,7 +2586,7 @@ class WP_Site_Health {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( ! is_wp_error( $result_fetch ) ) {
|
if ( ! is_wp_error( $result_fetch ) && 200 === wp_remote_retrieve_response_code( $result_fetch ) ) {
|
||||||
$result = json_decode( wp_remote_retrieve_body( $result_fetch ), true );
|
$result = json_decode( wp_remote_retrieve_body( $result_fetch ), true );
|
||||||
} else {
|
} else {
|
||||||
$result = false;
|
$result = false;
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '5.6-alpha-49231';
|
$wp_version = '5.6-alpha-49232';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
Loading…
Reference in New Issue