wordpress-develop/tests/phpunit/tests/comment/walker.php
Tonya Mork 40ac5de838 Coding Standards: Add visibility to methods in tests/phpunit/tests/.
Adds a `public` visibility to test fixtures, tests, data providers, and callbacks methods.

Adds a `private` visibility to helper methods within test classes.

Renames callbacks and helpers that previously started with a `_` prefix. Why? For consistency and to leverage using the method visibility. Further naming standardizations is beyond the scope of this commit.

Props costdev, jrf, hellofromTonya.
Fixes #54177.

git-svn-id: https://develop.svn.wordpress.org/trunk@52010 602fd350-edb4-49c9-b593-d223f7449a82
2021-11-04 15:22:47 +00:00

66 lines
1.7 KiB
PHP

<?php
/**
* @group comment
*/
class Tests_Comment_Walker extends WP_UnitTestCase {
public function set_up() {
parent::set_up();
$this->post_id = self::factory()->post->create();
}
/**
* @ticket 14041
*/
public function test_has_children() {
$comment_parent = self::factory()->comment->create( array( 'comment_post_ID' => $this->post_id ) );
$comment_child = self::factory()->comment->create(
array(
'comment_post_ID' => $this->post_id,
'comment_parent' => $comment_parent,
)
);
$comment_parent = get_comment( $comment_parent );
$comment_child = get_comment( $comment_child );
$comment_walker = new Walker_Comment();
$comment_callback = new Comment_Callback_Test( $this, $comment_walker );
wp_list_comments(
array(
'callback' => array( $comment_callback, 'comment' ),
'walker' => $comment_walker,
'echo' => false,
),
array( $comment_parent, $comment_child )
);
wp_list_comments(
array(
'callback' => array( $comment_callback, 'comment' ),
'walker' => $comment_walker,
'echo' => false,
),
array( $comment_child, $comment_parent )
);
}
}
class Comment_Callback_Test {
public function __construct( Tests_Comment_Walker $test_walker, Walker_Comment $walker ) {
$this->test_walker = $test_walker;
$this->walker = $walker;
}
public function comment( $comment, $args, $depth ) {
if ( 1 === $depth ) {
$this->test_walker->assertTrue( $this->walker->has_children );
$this->test_walker->assertTrue( $args['has_children'] ); // Back compat.
} elseif ( 2 === $depth ) {
$this->test_walker->assertFalse( $this->walker->has_children );
$this->test_walker->assertFalse( $args['has_children'] ); // Back compat.
}
}
}