mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2025-10-16 12:05:38 +00:00
In various unit test factory classes, some of the `create_object()` and `update_object()` methods returned a `WP_Error` object on failure, while a few others were documented to do so, but did not in practice, instead returning the value `0` or `false`, or not accounting for a failure at all. This commit aims to handle this in a consistent way by updating the methods to always return the object ID on success and a `WP_Error` object on failure. Includes: * Updating and correcting the relevant documentation parts. * Adding missing documentation and `@since` tags in some classes. * Renaming some variables to clarify that it is the object ID which is passed around, not the object itself. Follow-up to [760/tests], [838/tests], [922/tests], [948/tests], [985/tests], [27178], [32659], [34855], [37563], [40968], [44497], [46262]. See #56793. git-svn-id: https://develop.svn.wordpress.org/trunk@55019 602fd350-edb4-49c9-b593-d223f7449a82
69 lines
2.0 KiB
PHP
69 lines
2.0 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Unit test factory for posts.
|
|
*
|
|
* Note: The below @method notations are defined solely for the benefit of IDEs,
|
|
* as a way to indicate expected return values from the given factory methods.
|
|
*
|
|
* @method int|WP_Error create( $args = array(), $generation_definitions = null )
|
|
* @method WP_Post|WP_Error create_and_get( $args = array(), $generation_definitions = null )
|
|
* @method (int|WP_Error)[] create_many( $count, $args = array(), $generation_definitions = null )
|
|
*/
|
|
class WP_UnitTest_Factory_For_Post extends WP_UnitTest_Factory_For_Thing {
|
|
|
|
public function __construct( $factory = null ) {
|
|
parent::__construct( $factory );
|
|
$this->default_generation_definitions = array(
|
|
'post_status' => 'publish',
|
|
'post_title' => new WP_UnitTest_Generator_Sequence( 'Post title %s' ),
|
|
'post_content' => new WP_UnitTest_Generator_Sequence( 'Post content %s' ),
|
|
'post_excerpt' => new WP_UnitTest_Generator_Sequence( 'Post excerpt %s' ),
|
|
'post_type' => 'post',
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Creates a post object.
|
|
*
|
|
* @since UT (3.7.0)
|
|
* @since 6.2.0 Returns a WP_Error object on failure.
|
|
*
|
|
* @param array $args Array with elements for the post.
|
|
*
|
|
* @return int|WP_Error The post ID on success, WP_Error object on failure.
|
|
*/
|
|
public function create_object( $args ) {
|
|
return wp_insert_post( $args, true );
|
|
}
|
|
|
|
/**
|
|
* Updates an existing post object.
|
|
*
|
|
* @since UT (3.7.0)
|
|
* @since 6.2.0 Returns a WP_Error object on failure.
|
|
*
|
|
* @param int $post_id ID of the post to update.
|
|
* @param array $fields Post data.
|
|
*
|
|
* @return int|WP_Error The post ID on success, WP_Error object on failure.
|
|
*/
|
|
public function update_object( $post_id, $fields ) {
|
|
$fields['ID'] = $post_id;
|
|
return wp_update_post( $fields, true );
|
|
}
|
|
|
|
/**
|
|
* Retrieves a post by a given ID.
|
|
*
|
|
* @since UT (3.7.0)
|
|
*
|
|
* @param int $post_id ID of the post to retrieve.
|
|
*
|
|
* @return WP_Post|null WP_Post object on success, null on failure.
|
|
*/
|
|
public function get_object_by_id( $post_id ) {
|
|
return get_post( $post_id );
|
|
}
|
|
}
|