wordpress-develop/tests/phpunit/tests/ajax/GetComments.php
Sergey Biryukov e72fff9cef Code Modernization: Replace dirname( __FILE__ ) calls with __DIR__ magic constant.
This avoids the performance overhead of the function call every time `dirname( __FILE__ )` was used instead of `__DIR__`.

This commit also includes:

* Removing unnecessary parentheses from `include`/`require` statements. These are language constructs, not function calls.
* Replacing `include` statements for several files with `require_once`, for consistency:
 * `wp-admin/admin-header.php`
 * `wp-admin/admin-footer.php`
 * `wp-includes/version.php`

Props ayeshrajans, desrosj, valentinbora, jrf, joostdevalk, netweb.
Fixes #48082.

git-svn-id: https://develop.svn.wordpress.org/trunk@47198 602fd350-edb4-49c9-b593-d223f7449a82
2020-02-06 06:31:22 +00:00

162 lines
4.0 KiB
PHP

<?php
/**
* Admin Ajax functions to be tested.
*/
require_once ABSPATH . 'wp-admin/includes/ajax-actions.php';
/**
* Testing Ajax comment functionality.
*
* @package WordPress
* @subpackage UnitTests
* @since 3.4.0
* @group ajax
*/
class Tests_Ajax_GetComments extends WP_Ajax_UnitTestCase {
/**
* A post with at least one comment
*
* @var mixed
*/
protected static $comment_post = null;
/**
* A post with no comments
*
* @var mixed
*/
protected static $no_comment_post = null;
protected static $comment_ids = array();
public static function wpSetUpBeforeClass( $factory ) {
self::$comment_post = $factory->post->create_and_get();
self::$comment_ids = $factory->comment->create_post_comments( self::$comment_post->ID, 5 );
self::$no_comment_post = $factory->post->create_and_get();
}
/**
* Get comments as a privilged user (administrator)
* Expects test to pass
*
* @return void
*/
public function test_as_admin() {
// Become an administrator.
$this->_setRole( 'administrator' );
// Set up a default request.
$_POST['_ajax_nonce'] = wp_create_nonce( 'get-comments' );
$_POST['action'] = 'get-comments';
$_POST['p'] = self::$comment_post->ID;
// Make the request.
try {
$this->_handleAjax( 'get-comments' );
} catch ( WPAjaxDieContinueException $e ) {
unset( $e );
}
// Get the response.
$xml = simplexml_load_string( $this->_last_response, 'SimpleXMLElement', LIBXML_NOCDATA );
// Check the meta data.
$this->assertEquals( 1, (string) $xml->response[0]->comments['position'] );
$this->assertEquals( 0, (string) $xml->response[0]->comments['id'] );
$this->assertEquals( 'get-comments_0', (string) $xml->response['action'] );
// Check the payload.
$this->assertNotEmpty( (string) $xml->response[0]->comments[0]->response_data );
// And supplemental is empty.
$this->assertEmpty( (string) $xml->response[0]->comments[0]->supplemental );
}
/**
* Get comments as a non-privileged user (subscriber)
* Expects test to fail
*
* @return void
*/
public function test_as_subscriber() {
// Become a subscriber.
$this->_setRole( 'subscriber' );
// Set up a default request.
$_POST['_ajax_nonce'] = wp_create_nonce( 'get-comments' );
$_POST['action'] = 'get-comments';
$_POST['p'] = self::$comment_post->ID;
// Make the request.
$this->setExpectedException( 'WPAjaxDieStopException', '-1' );
$this->_handleAjax( 'get-comments' );
}
/**
* Get comments with a bad nonce
* Expects test to fail
*
* @return void
*/
public function test_bad_nonce() {
// Become an administrator.
$this->_setRole( 'administrator' );
// Set up a default request.
$_POST['_ajax_nonce'] = wp_create_nonce( uniqid() );
$_POST['action'] = 'get-comments';
$_POST['p'] = self::$comment_post->ID;
// Make the request.
$this->setExpectedException( 'WPAjaxDieStopException', '-1' );
$this->_handleAjax( 'get-comments' );
}
/**
* Get comments for an invalid post
* Bad post IDs are set to 0, this should return valid XML
*
* @return void
*/
public function test_invalid_post() {
// Become an administrator.
$this->_setRole( 'administrator' );
// Set up a default request.
$_POST['_ajax_nonce'] = wp_create_nonce( 'get-comments' );
$_POST['action'] = 'get-comments';
$_POST['p'] = 'b0rk';
// Make the request.
$this->setExpectedException( 'WPAjaxDieStopException', '-1' );
$this->_handleAjax( 'get-comments' );
}
/**
* Get comments for an invalid post
* Bad post IDs are set to 0, this should return valid XML
*
* @return void
*/
public function test_post_with_no_comments() {
// Become an administrator.
$this->_setRole( 'administrator' );
// Set up a default request.
$_POST['_ajax_nonce'] = wp_create_nonce( 'get-comments' );
$_POST['action'] = 'get-comments';
$_POST['p'] = self::$no_comment_post->ID;
// Make the request.
$this->setExpectedException( 'WPAjaxDieStopException', '1' );
$this->_handleAjax( 'get-comments' );
}
}