XML-RPC: Introduce the concept of unit testing to wp_xmlrpc_server::wp_newComment()
:
* Don't allow comments to be created for posts that have `comment_status` set to `'closed'` * Set some magic props on `WP_User` to vars before passing them to `wp_xmlrpc_server::escape()` Props wonderboymusic, jesin. Fixes #27471. git-svn-id: https://develop.svn.wordpress.org/trunk@34559 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
8bf8320afd
commit
a9e30d8e94
@ -3453,19 +3453,29 @@ class wp_xmlrpc_server extends IXR_Server {
|
|||||||
else
|
else
|
||||||
$post_id = url_to_postid($post);
|
$post_id = url_to_postid($post);
|
||||||
|
|
||||||
if ( ! $post_id )
|
if ( ! $post_id ) {
|
||||||
return new IXR_Error( 404, __( 'Invalid post ID.' ) );
|
return new IXR_Error( 404, __( 'Invalid post ID.' ) );
|
||||||
|
}
|
||||||
|
|
||||||
if ( ! get_post($post_id) )
|
if ( ! get_post( $post_id ) ) {
|
||||||
return new IXR_Error( 404, __( 'Invalid post ID.' ) );
|
return new IXR_Error( 404, __( 'Invalid post ID.' ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! comments_open( $post_id ) ) {
|
||||||
|
return new IXR_Error( 403, __( 'Sorry, comments are closed for this item.' ) );
|
||||||
|
}
|
||||||
|
|
||||||
$comment = array();
|
$comment = array();
|
||||||
$comment['comment_post_ID'] = $post_id;
|
$comment['comment_post_ID'] = $post_id;
|
||||||
|
|
||||||
if ( $logged_in ) {
|
if ( $logged_in ) {
|
||||||
$comment['comment_author'] = $this->escape( $user->display_name );
|
$display_name = $user->display_name;
|
||||||
$comment['comment_author_email'] = $this->escape( $user->user_email );
|
$user_email = $user->user_email;
|
||||||
$comment['comment_author_url'] = $this->escape( $user->user_url );
|
$user_url = $user->user_url;
|
||||||
|
|
||||||
|
$comment['comment_author'] = $this->escape( $display_name );
|
||||||
|
$comment['comment_author_email'] = $this->escape( $user_email );
|
||||||
|
$comment['comment_author_url'] = $this->escape( $user_url );
|
||||||
$comment['user_ID'] = $user->ID;
|
$comment['user_ID'] = $user->ID;
|
||||||
} else {
|
} else {
|
||||||
$comment['comment_author'] = '';
|
$comment['comment_author'] = '';
|
||||||
|
23
tests/phpunit/tests/xmlrpc/wp/newComment.php
Normal file
23
tests/phpunit/tests/xmlrpc/wp/newComment.php
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group xmlrpc
|
||||||
|
*/
|
||||||
|
class Tests_XMLRPC_wp_newComment extends WP_XMLRPC_UnitTestCase {
|
||||||
|
function test_new_comment_post_closed() {
|
||||||
|
$this->make_user_by_role( 'administrator' );
|
||||||
|
$post = $this->factory->post->create_and_get( array(
|
||||||
|
'comment_status' => 'closed'
|
||||||
|
) );
|
||||||
|
|
||||||
|
$this->assertEquals( 'closed', $post->comment_status );
|
||||||
|
|
||||||
|
$result = $this->myxmlrpcserver->wp_newComment( array( 1, 'administrator', 'administrator', $post->ID, array(
|
||||||
|
'comment_content' => rand_str( 100 ),
|
||||||
|
'status' => 'approved'
|
||||||
|
) ) );
|
||||||
|
|
||||||
|
$this->assertInstanceOf( 'IXR_Error', $result );
|
||||||
|
$this->assertEquals( 403, $result->code );
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user