REST API: Avoid undefined-property notice when setting parent term to 0.
Only try to access `term_id` once `$parent_term` is known to be a `WP_Term`. Props dlh, earnjam. Fixes #44983. git-svn-id: https://develop.svn.wordpress.org/trunk@44965 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
9a129eec78
commit
49d8c2590c
@ -685,11 +685,15 @@ class WP_REST_Terms_Controller extends WP_REST_Controller {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( isset( $request['parent'] ) && ! empty( $schema['properties']['parent'] ) ) {
|
if ( isset( $request['parent'] ) && ! empty( $schema['properties']['parent'] ) ) {
|
||||||
$parent_term_id = 0;
|
$parent_term_id = 0;
|
||||||
$parent_term = get_term( (int) $request['parent'], $this->taxonomy );
|
$requested_parent = (int) $request['parent'];
|
||||||
|
|
||||||
if ( $parent_term ) {
|
if ( $requested_parent ) {
|
||||||
$parent_term_id = $parent_term->term_id;
|
$parent_term = get_term( $requested_parent, $this->taxonomy );
|
||||||
|
|
||||||
|
if ( $parent_term instanceof WP_Term ) {
|
||||||
|
$parent_term_id = $parent_term->term_id;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$prepared_term->parent = $parent_term_id;
|
$prepared_term->parent = $parent_term_id;
|
||||||
|
@ -859,6 +859,18 @@ class WP_Test_REST_Categories_Controller extends WP_Test_REST_Controller_Testcas
|
|||||||
$this->assertErrorResponse( 'rest_term_invalid', $response, 400 );
|
$this->assertErrorResponse( 'rest_term_invalid', $response, 400 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function test_create_item_with_no_parent() {
|
||||||
|
wp_set_current_user( self::$administrator );
|
||||||
|
$parent = 0;
|
||||||
|
$request = new WP_REST_Request( 'POST', '/wp/v2/categories' );
|
||||||
|
$request->set_param( 'name', 'My Awesome Term' );
|
||||||
|
$request->set_param( 'parent', $parent );
|
||||||
|
$response = rest_get_server()->dispatch( $request );
|
||||||
|
$this->assertEquals( 201, $response->get_status() );
|
||||||
|
$data = $response->get_data();
|
||||||
|
$this->assertEquals( $parent, $data['parent'] );
|
||||||
|
}
|
||||||
|
|
||||||
public function test_update_item() {
|
public function test_update_item() {
|
||||||
wp_set_current_user( self::$administrator );
|
wp_set_current_user( self::$administrator );
|
||||||
$orig_args = array(
|
$orig_args = array(
|
||||||
@ -929,6 +941,33 @@ class WP_Test_REST_Categories_Controller extends WP_Test_REST_Controller_Testcas
|
|||||||
$this->assertEquals( $parent->term_id, $data['parent'] );
|
$this->assertEquals( $parent->term_id, $data['parent'] );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function test_update_item_remove_parent() {
|
||||||
|
wp_set_current_user( self::$administrator );
|
||||||
|
|
||||||
|
$old_parent_term = get_term_by( 'id', $this->factory->category->create(), 'category' );
|
||||||
|
$new_parent_id = 0;
|
||||||
|
|
||||||
|
$term = get_term_by(
|
||||||
|
'id',
|
||||||
|
$this->factory->category->create(
|
||||||
|
[
|
||||||
|
'parent' => $old_parent_term->term_id,
|
||||||
|
]
|
||||||
|
),
|
||||||
|
'category'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals( $old_parent_term->term_id, $term->parent );
|
||||||
|
|
||||||
|
$request = new WP_REST_Request( 'POST', '/wp/v2/categories/' . $term->term_id );
|
||||||
|
$request->set_param( 'parent', $new_parent_id );
|
||||||
|
$response = rest_get_server()->dispatch( $request );
|
||||||
|
$this->assertEquals( 200, $response->get_status() );
|
||||||
|
|
||||||
|
$data = $response->get_data();
|
||||||
|
$this->assertEquals( $new_parent_id, $data['parent'] );
|
||||||
|
}
|
||||||
|
|
||||||
public function test_update_item_invalid_parent() {
|
public function test_update_item_invalid_parent() {
|
||||||
wp_set_current_user( self::$administrator );
|
wp_set_current_user( self::$administrator );
|
||||||
$term = get_term_by( 'id', $this->factory->category->create(), 'category' );
|
$term = get_term_by( 'id', $this->factory->category->create(), 'category' );
|
||||||
|
Loading…
Reference in New Issue
Block a user