wiki.techinc.nl/tests/phpunit/includes/deferred/SearchUpdateTest.php
James D. Forrester ad06527fb4 Reorg: Namespace the Title class
This is moderately messy.

Process was principally:

* xargs rg --files-with-matches '^use Title;' | grep 'php$' | \
  xargs -P 1 -n 1 sed -i -z 's/use Title;/use MediaWiki\\Title\\Title;/1'
* rg --files-without-match 'MediaWiki\\Title\\Title;' . | grep 'php$' | \
  xargs rg --files-with-matches 'Title\b' | \
  xargs -P 1 -n 1 sed -i -z 's/\nuse /\nuse MediaWiki\\Title\\Title;\nuse /1'
* composer fix

Then manual fix-ups for a few files that don't have any use statements.

Bug: T166010
Follows-Up: Ia5d8cb759dc3bc9e9bbe217d0fb109e2f8c4101a
Change-Id: If8fc9d0d95fc1a114021e282a706fc3e7da3524b
2023-03-02 08:46:53 -05:00

74 lines
1.5 KiB
PHP

<?php
use MediaWiki\Title\Title;
/**
* @group Search
*/
class SearchUpdateTest extends MediaWikiIntegrationTestCase {
/**
* @var SearchUpdate
*/
private $su;
protected function setUp(): void {
parent::setUp();
$pageIdentity = Title::newMainPage()->toPageIdentity();
$this->su = new SearchUpdate( 0, $pageIdentity );
}
public function updateText( $text ) {
return trim( $this->su->updateText( $text ) );
}
/**
* @covers SearchUpdate::updateText
*/
public function testUpdateText() {
$this->assertEquals(
'test',
$this->updateText( '<div>TeSt</div>' ),
'HTML stripped, text lowercased'
);
$this->assertEquals(
'foo bar boz quux',
$this->updateText( <<<EOT
<table style="color:red; font-size:100px">
<tr class="scary"><td><div>foo</div></td><tr>bar</td></tr>
<tr><td>boz</td><tr>quux</td></tr>
</table>
EOT
), 'Stripping HTML tables' );
$this->assertEquals(
'a b',
$this->updateText( 'a > b' ),
'Handle unclosed tags'
);
$text = str_pad( "foo <barbarbar \n", 10000, 'x' );
$this->assertNotEquals(
'',
$this->updateText( $text ),
'T20609'
);
}
/**
* @covers SearchUpdate::updateText
* Test T34712
* Test if unicode quotes in article links make its search index empty
*/
public function testUnicodeLinkSearchIndexError() {
$text = "text „http://example.com“ text";
$result = $this->updateText( $text );
$processed = preg_replace( '/Q/u', 'Q', $result );
$this->assertTrue(
$processed != '',
'Link surrounded by unicode quotes should not fail UTF-8 validation'
);
}
}