mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2025-10-16 12:05:38 +00:00
This ensures that not only the return values match the expected results, but also that their type is the same. Going forward, stricter type checking by using `assertSame()` should generally be preferred to `assertEquals()` where appropriate, to make the tests more reliable. Props johnbillion, jrf, SergeyBiryukov. See #38266. git-svn-id: https://develop.svn.wordpress.org/trunk@48937 602fd350-edb4-49c9-b593-d223f7449a82
82 lines
2.5 KiB
PHP
82 lines
2.5 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group comment
|
|
*/
|
|
class Tests_Comment_GetCommentAuthorUrlLink extends WP_UnitTestCase {
|
|
protected static $comments = array();
|
|
|
|
public static function wpSetUpBeforeClass( $factory ) {
|
|
unset( $GLOBALS['comment'] );
|
|
|
|
$comment_ids = $factory->comment->create_post_comments( 0, 1 );
|
|
self::$comments = array_map( 'get_comment', $comment_ids );
|
|
}
|
|
|
|
protected function parseCommentAuthorUrl( $comment, $linktext = '' ) {
|
|
if ( empty( $linktext ) ) {
|
|
$linktext = rtrim( preg_replace( '#http://(www\.)?#', '', $comment->comment_author_url ), '/' );
|
|
}
|
|
return sprintf(
|
|
'<a href=\'%s\' rel=\'external\'>%s</a>',
|
|
$comment->comment_author_url,
|
|
$linktext
|
|
);
|
|
}
|
|
|
|
public function test_no_comment() {
|
|
$url_link = get_comment_author_url_link();
|
|
|
|
$this->assertSame( "<a href='' rel='external'></a>", $url_link );
|
|
}
|
|
|
|
public function test_global_comment() {
|
|
$comment = reset( self::$comments );
|
|
$GLOBALS['comment'] = $comment;
|
|
|
|
$url_link = get_comment_author_url_link();
|
|
$link = $this->parseCommentAuthorUrl( $comment );
|
|
$this->assertSame( $link, $url_link );
|
|
}
|
|
|
|
public function test_comment_arg() {
|
|
$comment = reset( self::$comments );
|
|
|
|
$url_link = get_comment_author_url_link( '', '', '', $comment );
|
|
$link = $this->parseCommentAuthorUrl( $comment );
|
|
$this->assertSame( $link, $url_link );
|
|
}
|
|
|
|
public function test_linktext() {
|
|
$comment = reset( self::$comments );
|
|
|
|
$url_link = get_comment_author_url_link( 'Burrito', '', '', $comment );
|
|
$link = $this->parseCommentAuthorUrl( $comment, 'Burrito' );
|
|
$this->assertSame( $link, $url_link );
|
|
}
|
|
|
|
public function test_before() {
|
|
$comment = reset( self::$comments );
|
|
|
|
$url_link = get_comment_author_url_link( 'Burrito', 'I would love a ', '', $comment );
|
|
$link = 'I would love a ' . $this->parseCommentAuthorUrl( $comment, 'Burrito' );
|
|
$this->assertSame( $link, $url_link );
|
|
}
|
|
|
|
public function test_after() {
|
|
$comment = reset( self::$comments );
|
|
|
|
$url_link = get_comment_author_url_link( 'Burrito', '', ' is my favorite word.', $comment );
|
|
$link = $this->parseCommentAuthorUrl( $comment, 'Burrito' ) . ' is my favorite word.';
|
|
$this->assertSame( $link, $url_link );
|
|
}
|
|
|
|
public function test_before_after() {
|
|
$comment = reset( self::$comments );
|
|
|
|
$url_link = get_comment_author_url_link( 'Burrito', 'I would love a ', ' right now.', $comment );
|
|
$link = 'I would love a ' . $this->parseCommentAuthorUrl( $comment, 'Burrito' ) . ' right now.';
|
|
$this->assertSame( $link, $url_link );
|
|
}
|
|
}
|