2016-01-19 04:55:19 +01:00
|
|
|
<?php
|
|
|
|
|
2017-06-30 06:35:39 +02:00
|
|
|
/**
|
|
|
|
* Unit test factory for users.
|
|
|
|
*
|
|
|
|
* 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 create( $args = array(), $generation_definitions = null )
|
|
|
|
* @method WP_User create_and_get( $args = array(), $generation_definitions = null )
|
|
|
|
* @method int[] create_many( $count, $args = array(), $generation_definitions = null )
|
|
|
|
*/
|
2016-01-19 04:55:19 +01:00
|
|
|
class WP_UnitTest_Factory_For_User extends WP_UnitTest_Factory_For_Thing {
|
|
|
|
|
2019-03-15 13:15:08 +01:00
|
|
|
public function __construct( $factory = null ) {
|
2016-01-19 04:55:19 +01:00
|
|
|
parent::__construct( $factory );
|
|
|
|
$this->default_generation_definitions = array(
|
|
|
|
'user_login' => new WP_UnitTest_Generator_Sequence( 'User %s' ),
|
2017-12-01 00:09:33 +01:00
|
|
|
'user_pass' => 'password',
|
2016-01-19 04:55:19 +01:00
|
|
|
'user_email' => new WP_UnitTest_Generator_Sequence( 'user_%s@example.org' ),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-01-09 06:43:14 +01:00
|
|
|
/**
|
|
|
|
* Inserts an user.
|
|
|
|
*
|
|
|
|
* @param array $args The user data to insert.
|
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @return int|WP_Error The user ID on success, WP_Error object on failure.
|
2019-01-09 06:43:14 +01:00
|
|
|
*/
|
2019-03-15 13:15:08 +01:00
|
|
|
public function create_object( $args ) {
|
2016-01-19 04:55:19 +01:00
|
|
|
return wp_insert_user( $args );
|
|
|
|
}
|
|
|
|
|
2019-01-09 06:43:14 +01:00
|
|
|
/**
|
|
|
|
* Updates the user data.
|
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @param int $user_id ID of the user to update.
|
2019-01-09 06:43:14 +01:00
|
|
|
* @param array $fields The user data to update.
|
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @return int|WP_Error The user ID on success, WP_Error object on failure.
|
2019-01-09 06:43:14 +01:00
|
|
|
*/
|
2019-03-15 13:15:08 +01:00
|
|
|
public function update_object( $user_id, $fields ) {
|
2016-01-19 04:55:19 +01:00
|
|
|
$fields['ID'] = $user_id;
|
|
|
|
return wp_update_user( $fields );
|
|
|
|
}
|
|
|
|
|
2019-01-09 06:43:14 +01:00
|
|
|
/**
|
2019-12-18 01:17:54 +01:00
|
|
|
* Retrieves the user for a given ID.
|
2019-01-09 06:43:14 +01:00
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @param int $user_id ID of the user ID to retrieve.
|
2019-01-09 06:43:14 +01:00
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @return WP_User The user object.
|
2019-01-09 06:43:14 +01:00
|
|
|
*/
|
2019-03-15 13:15:08 +01:00
|
|
|
public function get_object_by_id( $user_id ) {
|
2016-01-19 04:55:19 +01:00
|
|
|
return new WP_User( $user_id );
|
|
|
|
}
|
|
|
|
}
|