2016-01-19 04:55:19 +01:00
|
|
|
<?php
|
|
|
|
|
2017-06-30 06:35:39 +02:00
|
|
|
/**
|
|
|
|
* Unit test factory for comments.
|
|
|
|
*
|
|
|
|
* 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_Comment 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_Comment 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(
|
2017-12-01 00:09:33 +01:00
|
|
|
'comment_author' => new WP_UnitTest_Generator_Sequence( 'Commenter %s' ),
|
2016-01-19 04:55:19 +01:00
|
|
|
'comment_author_url' => new WP_UnitTest_Generator_Sequence( 'http://example.com/%s/' ),
|
2017-12-01 00:09:33 +01:00
|
|
|
'comment_approved' => 1,
|
|
|
|
'comment_content' => 'This is a comment',
|
2016-01-19 04:55:19 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-01-09 06:43:14 +01:00
|
|
|
/**
|
|
|
|
* Inserts a comment.
|
|
|
|
*
|
|
|
|
* @param array $args The comment details.
|
|
|
|
*
|
|
|
|
* @return false|int The comment's ID on success, false on failure.
|
|
|
|
*/
|
2019-03-15 13:15:08 +01:00
|
|
|
public function create_object( $args ) {
|
2016-01-19 04:55:19 +01:00
|
|
|
return wp_insert_comment( $this->addslashes_deep( $args ) );
|
|
|
|
}
|
|
|
|
|
2019-01-09 06:43:14 +01:00
|
|
|
/**
|
|
|
|
* Updates a comment.
|
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @param int $comment_id The comment ID.
|
2019-01-09 06:43:14 +01:00
|
|
|
* @param array $fields The comment details.
|
|
|
|
*
|
|
|
|
* @return int When updated 1, not update 0.
|
|
|
|
*/
|
2019-03-15 13:15:08 +01:00
|
|
|
public function update_object( $comment_id, $fields ) {
|
2016-01-19 04:55:19 +01:00
|
|
|
$fields['comment_ID'] = $comment_id;
|
|
|
|
return wp_update_comment( $this->addslashes_deep( $fields ) );
|
|
|
|
}
|
|
|
|
|
2019-01-09 06:43:14 +01:00
|
|
|
/**
|
2019-12-18 01:17:54 +01:00
|
|
|
* Creates multiple comments on a given post.
|
2019-01-09 06:43:14 +01:00
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @param int $post_id ID of the post to create comments for.
|
2019-01-09 06:43:14 +01:00
|
|
|
* @param int $count Total amount of comments to create.
|
|
|
|
* @param array $args The comment details.
|
|
|
|
* @param null $generation_definitions Default values.
|
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @return int[] Array with the comment IDs.
|
2019-01-09 06:43:14 +01:00
|
|
|
*/
|
2019-03-15 13:15:08 +01:00
|
|
|
public function create_post_comments( $post_id, $count = 1, $args = array(), $generation_definitions = null ) {
|
2016-01-19 04:55:19 +01:00
|
|
|
$args['comment_post_ID'] = $post_id;
|
|
|
|
return $this->create_many( $count, $args, $generation_definitions );
|
|
|
|
}
|
|
|
|
|
2019-01-09 06:43:14 +01:00
|
|
|
/**
|
2019-12-18 01:17:54 +01:00
|
|
|
* Retrieves a comment by a given ID.
|
2019-01-09 06:43:14 +01:00
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @param int $comment_id ID of the comment to retrieve.
|
2019-01-09 06:43:14 +01:00
|
|
|
*
|
2019-12-18 01:17:54 +01:00
|
|
|
* @return WP_Comment|null WP_Comment object on success, null on failure.
|
2019-01-09 06:43:14 +01:00
|
|
|
*/
|
2019-03-15 13:15:08 +01:00
|
|
|
public function get_object_by_id( $comment_id ) {
|
2016-01-19 04:55:19 +01:00
|
|
|
return get_comment( $comment_id );
|
|
|
|
}
|
|
|
|
}
|