mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2025-10-16 12:05:38 +00:00
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
247 lines
6.7 KiB
PHP
247 lines
6.7 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_DimComment extends WP_Ajax_UnitTestCase {
|
|
|
|
/**
|
|
* List of comments
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $_comments = array();
|
|
|
|
/**
|
|
* Set up the test fixture
|
|
*/
|
|
public function setUp() {
|
|
parent::setUp();
|
|
$post_id = self::factory()->post->create();
|
|
$this->_comments = self::factory()->comment->create_post_comments( $post_id, 15 );
|
|
$this->_comments = array_map( 'get_comment', $this->_comments );
|
|
}
|
|
|
|
/**
|
|
* Clear the POST actions in between requests
|
|
*/
|
|
protected function _clear_post_action() {
|
|
unset( $_POST['id'] );
|
|
unset( $_POST['new'] );
|
|
$this->_last_response = '';
|
|
}
|
|
|
|
/*
|
|
* Test prototype
|
|
*/
|
|
|
|
/**
|
|
* Test as a privilged user (administrator)
|
|
* Expects test to pass
|
|
*
|
|
* @param mixed $comment Comment object
|
|
* @return void
|
|
*/
|
|
public function _test_as_admin( $comment ) {
|
|
|
|
// Reset request.
|
|
$this->_clear_post_action();
|
|
|
|
// Become an administrator.
|
|
$this->_setRole( 'administrator' );
|
|
|
|
// Set up a default request.
|
|
$_POST['id'] = $comment->comment_ID;
|
|
$_POST['_ajax_nonce'] = wp_create_nonce( 'approve-comment_' . $comment->comment_ID );
|
|
$_POST['_total'] = count( $this->_comments );
|
|
$_POST['_per_page'] = 100;
|
|
$_POST['_page'] = 1;
|
|
$_POST['_url'] = admin_url( 'edit-comments.php' );
|
|
|
|
// Save the comment status.
|
|
$prev_status = wp_get_comment_status( $comment->comment_ID );
|
|
|
|
// Make the request.
|
|
try {
|
|
$this->_handleAjax( 'dim-comment' );
|
|
} catch ( WPAjaxDieContinueException $e ) {
|
|
unset( $e );
|
|
}
|
|
|
|
// Get the response.
|
|
$xml = simplexml_load_string( $this->_last_response, 'SimpleXMLElement', LIBXML_NOCDATA );
|
|
|
|
// Ensure everything is correct.
|
|
$this->assertEquals( $comment->comment_ID, (string) $xml->response[0]->comment['id'] );
|
|
$this->assertEquals( 'dim-comment_' . $comment->comment_ID, (string) $xml->response['action'] );
|
|
$this->assertGreaterThanOrEqual( time() - 10, (int) $xml->response[0]->comment[0]->supplemental[0]->time[0] );
|
|
$this->assertLessThanOrEqual( time(), (int) $xml->response[0]->comment[0]->supplemental[0]->time[0] );
|
|
|
|
// Check the status.
|
|
$current = wp_get_comment_status( $comment->comment_ID );
|
|
if ( in_array( $prev_status, array( 'unapproved', 'spam' ), true ) ) {
|
|
$this->assertEquals( 'approved', $current );
|
|
} else {
|
|
$this->assertEquals( 'unapproved', $current );
|
|
}
|
|
|
|
// The total is calculated based on a page break -OR- a random number. Let's look for both possible outcomes.
|
|
$comment_count = wp_count_comments( 0 );
|
|
$recalc_total = $comment_count->total_comments;
|
|
|
|
// Delta is not specified, it will always be 1 lower than the request.
|
|
$total = $_POST['_total'] - 1;
|
|
|
|
// Check for either possible total.
|
|
$this->assertTrue( in_array( (int) $xml->response[0]->comment[0]->supplemental[0]->total[0], array( $total, $recalc_total ), true ) );
|
|
}
|
|
|
|
/**
|
|
* Test as a non-privileged user (subscriber)
|
|
* Expects test to fail
|
|
*
|
|
* @param mixed $comment Comment object
|
|
* @return void
|
|
*/
|
|
public function _test_as_subscriber( $comment ) {
|
|
|
|
// Reset request.
|
|
$this->_clear_post_action();
|
|
|
|
// Become a subscriber.
|
|
$this->_setRole( 'subscriber' );
|
|
|
|
// Set up the $_POST request.
|
|
$_POST['id'] = $comment->comment_ID;
|
|
$_POST['_ajax_nonce'] = wp_create_nonce( 'approve-comment_' . $comment->comment_ID );
|
|
$_POST['_total'] = count( $this->_comments );
|
|
$_POST['_per_page'] = 100;
|
|
$_POST['_page'] = 1;
|
|
$_POST['_url'] = admin_url( 'edit-comments.php' );
|
|
|
|
// Make the request.
|
|
$this->setExpectedException( 'WPAjaxDieStopException', '-1' );
|
|
$this->_handleAjax( 'dim-comment' );
|
|
}
|
|
|
|
/**
|
|
* Test with a bad nonce
|
|
* Expects test to fail
|
|
*
|
|
* @param mixed $comment Comment object
|
|
* @return void
|
|
*/
|
|
public function _test_with_bad_nonce( $comment ) {
|
|
|
|
// Reset request.
|
|
$this->_clear_post_action();
|
|
|
|
// Become a subscriber.
|
|
$this->_setRole( 'administrator' );
|
|
|
|
// Set up the $_POST request.
|
|
$_POST['id'] = $comment->comment_ID;
|
|
$_POST['_ajax_nonce'] = wp_create_nonce( uniqid() );
|
|
$_POST['_total'] = count( $this->_comments );
|
|
$_POST['_per_page'] = 100;
|
|
$_POST['_page'] = 1;
|
|
$_POST['_url'] = admin_url( 'edit-comments.php' );
|
|
|
|
// Make the request.
|
|
$this->setExpectedException( 'WPAjaxDieStopException', '-1' );
|
|
$this->_handleAjax( 'dim-comment' );
|
|
}
|
|
|
|
/**
|
|
* Test with a bad id
|
|
* Expects test to fail
|
|
*
|
|
* @return void
|
|
*/
|
|
public function test_with_bad_id() {
|
|
|
|
// Reset request.
|
|
$this->_clear_post_action();
|
|
|
|
// Become a subscriber.
|
|
$this->_setRole( 'administrator' );
|
|
|
|
// Set up the $_POST request.
|
|
$_POST['id'] = 12346789;
|
|
$_POST['_ajax_nonce'] = wp_create_nonce( 'dim-comment_12346789' );
|
|
$_POST['_total'] = count( $this->_comments );
|
|
$_POST['_per_page'] = 100;
|
|
$_POST['_page'] = 1;
|
|
$_POST['_url'] = admin_url( 'edit-comments.php' );
|
|
|
|
// Make the request, look for a timestamp in the exception.
|
|
try {
|
|
$this->_handleAjax( 'dim-comment' );
|
|
$this->fail( 'Expected exception: WPAjaxDieContinueException' );
|
|
} catch ( WPAjaxDieContinueException $e ) {
|
|
|
|
// Get the response.
|
|
$xml = simplexml_load_string( $this->_last_response, 'SimpleXMLElement', LIBXML_NOCDATA );
|
|
|
|
// Ensure everything is correct.
|
|
$this->assertEquals( '0', (string) $xml->response[0]->comment['id'] );
|
|
$this->assertEquals( 'dim-comment_0', (string) $xml->response['action'] );
|
|
$this->assertContains( 'Comment ' . $_POST['id'] . ' does not exist', $this->_last_response );
|
|
|
|
} catch ( Exception $e ) {
|
|
$this->fail( 'Unexpected exception type: ' . get_class( $e ) );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Dim a comment as an administrator (expects success)
|
|
*
|
|
* @return void
|
|
*/
|
|
public function test_ajax_comment_dim_actions_as_administrator() {
|
|
$comment = array_pop( $this->_comments );
|
|
$this->_test_as_admin( $comment );
|
|
$this->_test_as_admin( $comment );
|
|
}
|
|
|
|
/**
|
|
* Dim a comment as a subscriber (expects permission denied)
|
|
*
|
|
* @return void
|
|
*/
|
|
public function test_ajax_comment_dim_actions_as_subscriber() {
|
|
$comment = array_pop( $this->_comments );
|
|
$this->_test_as_subscriber( $comment );
|
|
}
|
|
|
|
/**
|
|
* Dim a comment with no id
|
|
*
|
|
* @return void
|
|
*/
|
|
public function test_ajax_dim_comment_no_id() {
|
|
$comment = array_pop( $this->_comments );
|
|
$this->_test_as_admin( $comment );
|
|
}
|
|
|
|
/**
|
|
* Dim a comment with a bad nonce
|
|
*
|
|
* @return void
|
|
*/
|
|
public function test_ajax_dim_comment_bad_nonce() {
|
|
$comment = array_pop( $this->_comments );
|
|
$this->_test_with_bad_nonce( $comment );
|
|
}
|
|
}
|