wiki.techinc.nl/tests/phpunit/includes/api/ApiProtectTest.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

53 lines
1.3 KiB
PHP

<?php
use MediaWiki\MainConfigNames;
use MediaWiki\Title\Title;
/**
* Tests for protect API.
*
* @group API
* @group Database
* @group medium
*
* @covers ApiProtect
*/
class ApiProtectTest extends ApiTestCase {
protected function setUp(): void {
parent::setUp();
$this->tablesUsed = array_merge(
$this->tablesUsed,
[ 'page_restrictions', 'logging', 'watchlist', 'watchlist_expiry' ]
);
$this->overrideConfigValue( MainConfigNames::WatchlistExpiry, true );
}
/**
* @covers ApiProtect::execute()
*/
public function testProtectWithWatch(): void {
$name = ucfirst( __FUNCTION__ );
$title = Title::newFromText( $name );
$this->editPage( $name, 'Some text' );
$apiResult = $this->doApiRequestWithToken( [
'action' => 'protect',
'title' => $name,
'protections' => 'edit=sysop',
'expiry' => '55550123000000',
'watchlist' => 'watch',
'watchlistexpiry' => '99990123000000',
] )[0];
$this->assertArrayHasKey( 'protect', $apiResult );
$this->assertSame( $name, $apiResult['protect']['title'] );
$this->assertTrue( $this->getServiceContainer()->getRestrictionStore()->isProtected( $title, 'edit' ) );
$this->assertTrue( $this->getServiceContainer()->getWatchlistManager()->isTempWatched(
$this->getTestSysop()->getUser(),
$title
) );
}
}