Make WordPress Core


Ignore:
Timestamp:
12/28/2022 02:07:16 PM (3 years ago)
Author:
SergeyBiryukov
Message:

Tests: Bring some consistency to creating and updating objects in factory classes.

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.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/tests/phpunit/includes/factory/class-wp-unittest-factory-for-post.php

    r49789 r55019  
    77 * as a way to indicate expected return values from the given factory methods.
    88 *
    9  * @method int create( $args = array(), $generation_definitions = null )
    10  * @method WP_Post create_and_get( $args = array(), $generation_definitions = null )
    11  * @method int[] create_many( $count, $args = array(), $generation_definitions = null )
     9 * @method int|WP_Error    create( $args = array(), $generation_definitions = null )
     10 * @method WP_Post|WP_Error create_and_get( $args = array(), $generation_definitions = null )
     11 * @method (int|WP_Error)[] create_many( $count, $args = array(), $generation_definitions = null )
    1212 */
    1313class WP_UnitTest_Factory_For_Post extends WP_UnitTest_Factory_For_Thing {
     
    2727     * Creates a post object.
    2828     *
     29     * @since UT (3.7.0)
     30     * @since 6.2.0 Returns a WP_Error object on failure.
     31     *
    2932     * @param array $args Array with elements for the post.
    3033     *
    31      * @return int The post ID on success. The value 0 on failure.
     34     * @return int|WP_Error The post ID on success, WP_Error object on failure.
    3235     */
    3336    public function create_object( $args ) {
    34         return wp_insert_post( $args );
     37        return wp_insert_post( $args, true );
    3538    }
    3639
     
    3841     * Updates an existing post object.
    3942     *
     43     * @since UT (3.7.0)
     44     * @since 6.2.0 Returns a WP_Error object on failure.
     45     *
    4046     * @param int   $post_id ID of the post to update.
    4147     * @param array $fields  Post data.
    4248     *
    43      * @return int The post ID on success. The value 0 on failure.
     49     * @return int|WP_Error The post ID on success, WP_Error object on failure.
    4450     */
    4551    public function update_object( $post_id, $fields ) {
    4652        $fields['ID'] = $post_id;
    47         return wp_update_post( $fields );
     53        return wp_update_post( $fields, true );
    4854    }
    4955
    5056    /**
    5157     * Retrieves a post by a given ID.
     58     *
     59     * @since UT (3.7.0)
    5260     *
    5361     * @param int $post_id ID of the post to retrieve.
Note: See TracChangeset for help on using the changeset viewer.