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/abstract-testcase.php

    r55016 r55019  
    15231523     *
    15241524     * @since 4.4.0
     1525     * @since 6.2.0 Returns a WP_Error object on failure.
    15251526     *
    15261527     * @param array $upload         Array of information about the uploaded file, provided by wp_upload_bits().
    15271528     * @param int   $parent_post_id Optional. Parent post ID.
    1528      * @return int|WP_Error The attachment ID on success. The value 0 or WP_Error on failure.
     1529     * @return int|WP_Error The attachment ID on success, WP_Error object on failure.
    15291530     */
    15301531    public function _make_attachment( $upload, $parent_post_id = 0 ) {
     
    15481549        );
    15491550
    1550         $id = wp_insert_attachment( $attachment, $upload['file'], $parent_post_id );
    1551         wp_update_attachment_metadata( $id, wp_generate_attachment_metadata( $id, $upload['file'] ) );
    1552         return $id;
     1551        $attachment_id = wp_insert_attachment( $attachment, $upload['file'], $parent_post_id, true );
     1552
     1553        if ( is_wp_error( $attachment_id ) ) {
     1554            return $attachment_id;
     1555        }
     1556
     1557        wp_update_attachment_metadata(
     1558            $attachment_id,
     1559            wp_generate_attachment_metadata( $attachment_id, $upload['file'] )
     1560        );
     1561
     1562        return $attachment_id;
    15531563    }
    15541564
Note: See TracChangeset for help on using the changeset viewer.