Krinkle has uploaded a new change for review. ( https://gerrit.wikimedia.org/r/345947 )
Change subject: changes: Remove assertTag from RCCacheEntryFactoryTest ...................................................................... changes: Remove assertTag from RCCacheEntryFactoryTest Use PHPUnit's Xml::load() to validate that all tags and attributes are balanced. Use simple assertEquals or assertRegexp for the specific parts. Change-Id: I25796954a3bb9903e88256b8345ef751c767d7d5 --- M tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php 1 file changed, 21 insertions(+), 47 deletions(-) git pull ssh://gerrit.wikimedia.org:29418/mediawiki/core refs/changes/47/345947/1 diff --git a/tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php b/tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php index 4ff1eb8..9c6d57c 100644 --- a/tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php +++ b/tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php @@ -141,77 +141,51 @@ $this->assertEquals( 'prev', $cacheEntry->lastlink, 'pref link for delete log or rev' ); } + private function assertValidHTML( $actual ) { + // Throws if invalid + $doc = PHPUnit_Util_XML::load( $actual, /* isHtml */ true ); + } + private function assertUserLinks( $user, $cacheEntry ) { - $this->assertTag( - [ - 'tag' => 'a', - 'attributes' => [ - 'class' => 'new mw-userlink' - ], - 'content' => $user - ], + $this->assertValidHTML( $cacheEntry->userlink ); + $this->assertRegExp( + '#^<a .*class="new mw-userlink".*><bdi>' . $user . '</bdi></a>#', $cacheEntry->userlink, 'verify user link' ); - $this->assertTag( - [ - 'tag' => 'span', - 'attributes' => [ - 'class' => 'mw-usertoollinks' - ], - 'child' => [ - 'tag' => 'a', - 'content' => 'talk', - ] - ], + $this->assertValidHTML( $cacheEntry->usertalklink ); + $this->assertRegExp( + '#^ <span class="mw-usertoollinks">\(.*<a .+>talk</a>.*\)</span>#', $cacheEntry->usertalklink, 'verify user talk link' ); - $this->assertTag( - [ - 'tag' => 'span', - 'attributes' => [ - 'class' => 'mw-usertoollinks' - ], - 'child' => [ - 'tag' => 'a', - 'content' => 'contribs', - ] - ], + $this->assertValidHTML( $cacheEntry->usertalklink ); + $this->assertRegExp( + '#^ <span class="mw-usertoollinks">\(.*<a .+>contribs</a>.*\)</span>$#', $cacheEntry->usertalklink, 'verify user tool links' ); } private function assertDeleteLogLink( $cacheEntry ) { - $this->assertTag( - [ - 'tag' => 'a', - 'attributes' => [ - 'href' => '/wiki/Special:Log/delete', - 'title' => 'Special:Log/delete' - ], - 'content' => 'Deletion log' - ], + $this->assertEquals( + '(<a href="/wiki/Special:Log/delete" title="Special:Log/delete">Deletion log</a>)', $cacheEntry->link, 'verify deletion log link' ); + + $this->assertValidHTML( $cacheEntry->link ); } private function assertRevDel( $cacheEntry ) { - $this->assertTag( - [ - 'tag' => 'span', - 'attributes' => [ - 'class' => 'history-deleted' - ], - 'content' => '(username removed)' - ], + $this->assertEquals( + ' <span class="history-deleted">(username removed)</span>', $cacheEntry->userlink, 'verify user link for change with deleted revision and user' ); + $this->assertValidHTML( $cacheEntry->userlink ); } private function assertTitleLink( $title, $cacheEntry ) { -- To view, visit https://gerrit.wikimedia.org/r/345947 To unsubscribe, visit https://gerrit.wikimedia.org/r/settings Gerrit-MessageType: newchange Gerrit-Change-Id: I25796954a3bb9903e88256b8345ef751c767d7d5 Gerrit-PatchSet: 1 Gerrit-Project: mediawiki/core Gerrit-Branch: master Gerrit-Owner: Krinkle <krinklem...@gmail.com> _______________________________________________ MediaWiki-commits mailing list MediaWiki-commits@lists.wikimedia.org https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits