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:
Scott Taylor 2015-09-25 20:19:19 +00:00
parent 8bf8320afd
commit a9e30d8e94
2 changed files with 38 additions and 5 deletions

View File

@ -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'] = '';

View 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 );
}
}