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
61 lines
1.9 KiB
PHP
61 lines
1.9 KiB
PHP
<?php
|
|
|
|
use MediaWiki\MainConfigNames;
|
|
use MediaWiki\Title\Title;
|
|
|
|
/**
|
|
* @group Database
|
|
*/
|
|
class EmailNotificationTest extends MediaWikiIntegrationTestCase {
|
|
|
|
protected $emailNotification;
|
|
|
|
protected function setUp(): void {
|
|
parent::setUp();
|
|
|
|
$this->tablesUsed = [
|
|
'watchlist',
|
|
'watchlist_expiry',
|
|
];
|
|
|
|
$this->emailNotification = new EmailNotification();
|
|
|
|
$this->overrideConfigValue( MainConfigNames::WatchlistExpiry, true );
|
|
}
|
|
|
|
/**
|
|
* @covers EmailNotification::notifyOnPageChange
|
|
*/
|
|
public function testNotifyOnPageChange(): void {
|
|
$store = $this->getServiceContainer()->getWatchedItemStore();
|
|
|
|
// both Alice and Bob watch 'Foobar'
|
|
$title = Title::makeTitle( NS_MAIN, 'Foobar' );
|
|
$alice = $this->getTestSysop()->getUser();
|
|
$store->addWatch( $alice, $title );
|
|
$bob = $this->getTestUser()->getUser();
|
|
$store->addWatch( $bob, $title );
|
|
|
|
// Alice edits the page (doesn't actually have to edit in this test).
|
|
// Bob (as in, not Alice) should have received an email notification.
|
|
$notifyArgs = [ $alice, $title, '20200624000000', '', false ];
|
|
$sent = $this->emailNotification->notifyOnPageChange( ...$notifyArgs );
|
|
static::assertTrue( $sent );
|
|
|
|
// Alice edits again, but Bob shouldn't be notified again
|
|
// (only one email until Bob visits the page again).
|
|
$sent = $this->emailNotification->notifyOnPageChange( ...$notifyArgs );
|
|
static::assertFalse( $sent );
|
|
|
|
// Reset notification timestamp, simulating that Bob visited the page.
|
|
$store->resetAllNotificationTimestampsForUser( $bob );
|
|
|
|
// Bob re-watches temporarily. For testing purposes we use a past expiry,
|
|
// so an email shouldn't be sent after Alice edits the page.
|
|
$store->addWatch( $bob, $title, '20060123000000' );
|
|
|
|
// Alice edits again, email should not be sent.
|
|
$sent = $this->emailNotification->notifyOnPageChange( ...$notifyArgs );
|
|
static::assertFalse( $sent );
|
|
}
|
|
}
|