mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2026-03-30 18:24:31 +00:00
REST API: Filter responses based on the _fields parameter, before data is processed.
Historically, the REST API would generate the entire response object, including running expensive filters, then it would apply the `_fields` parameter, discarding the fields that weren't specificed. This change causes `_fields` to be applied earlier, so that only requested fields are processed. Props danielbachhuber. See #43874. git-svn-id: https://develop.svn.wordpress.org/trunk@43087 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
@@ -847,6 +847,20 @@ class WP_Test_REST_Comments_Controller extends WP_Test_REST_Controller_Testcase
|
||||
$this->check_comment_data( $data, 'edit', $response->get_links() );
|
||||
}
|
||||
|
||||
public function test_prepare_item_limit_fields() {
|
||||
wp_set_current_user( self::$admin_id );
|
||||
$endpoint = new WP_REST_Comments_Controller;
|
||||
$request = new WP_REST_Request( 'GET', sprintf( '/wp/v2/comments/%d', self::$approved_id ) );
|
||||
$request->set_param( 'context', 'edit' );
|
||||
$request->set_param( '_fields', 'id,status' );
|
||||
$obj = get_comment( self::$approved_id );
|
||||
$response = $endpoint->prepare_item_for_response( $obj, $request );
|
||||
$this->assertEquals( array(
|
||||
'id',
|
||||
'status',
|
||||
), array_keys( $response->get_data() ) );
|
||||
}
|
||||
|
||||
public function test_get_comment_author_avatar_urls() {
|
||||
$request = new WP_REST_Request( 'GET', sprintf( '/wp/v2/comments/%d', self::$approved_id ) );
|
||||
|
||||
|
||||
Reference in New Issue
Block a user