wiki.techinc.nl/tests/phpunit/includes/deferred/SiteStatsUpdateTest.php
addshore 959bc315f2 MediaWikiTestCase to MediaWikiIntegrationTestCase
The name change happened some time ago, and I think its
about time to start using the name name!
(Done with a find and replace)

My personal motivation for doing this is that I have started
trying out vscode as an IDE for mediawiki development, and
right now it doesn't appear to handle php aliases very well
or at all.

Change-Id: I412235d91ae26e4c1c6a62e0dbb7e7cf3c5ed4a6
2020-06-30 17:02:22 +01:00

79 lines
2.6 KiB
PHP

<?php
use Wikimedia\TestingAccessWrapper;
/**
* @group Database
*/
class SiteStatsUpdateTest extends MediaWikiIntegrationTestCase {
/**
* @covers SiteStatsUpdate::factory
* @covers SiteStatsUpdate::merge
*/
public function testFactoryAndMerge() {
$update1 = SiteStatsUpdate::factory( [ 'pages' => 1, 'users' => 2 ] );
$update2 = SiteStatsUpdate::factory( [ 'users' => 1, 'images' => 1 ] );
$update1->merge( $update2 );
$wrapped = TestingAccessWrapper::newFromObject( $update1 );
$this->assertSame( 1, $wrapped->pages );
$this->assertEquals( 3, $wrapped->users );
$this->assertSame( 1, $wrapped->images );
$this->assertSame( 0, $wrapped->edits );
$this->assertSame( 0, $wrapped->articles );
}
/**
* @covers SiteStatsUpdate::doUpdate()
* @covers SiteStatsInit::refresh()
*/
public function testDoUpdate() {
$this->setMwGlobals( 'wgSiteStatsAsyncFactor', false );
$this->setMwGlobals( 'wgCommandLineMode', false ); // disable opportunistic updates
$dbw = wfGetDB( DB_MASTER );
$statsInit = new SiteStatsInit( $dbw );
$statsInit->refresh();
$ei = SiteStats::edits(); // trigger load
$pi = SiteStats::pages();
$ui = SiteStats::users();
$fi = SiteStats::images();
$ai = SiteStats::articles();
$this->assertSame( 0, DeferredUpdates::pendingUpdatesCount() );
$dbw->begin( __METHOD__ ); // block opportunistic updates
DeferredUpdates::addUpdate(
SiteStatsUpdate::factory( [ 'pages' => 2, 'images' => 1, 'edits' => 2 ] )
);
$this->assertSame( 1, DeferredUpdates::pendingUpdatesCount() );
// Still the same
SiteStats::unload();
$this->assertEquals( $pi, SiteStats::pages(), 'page count' );
$this->assertEquals( $ei, SiteStats::edits(), 'edit count' );
$this->assertEquals( $ui, SiteStats::users(), 'user count' );
$this->assertEquals( $fi, SiteStats::images(), 'file count' );
$this->assertEquals( $ai, SiteStats::articles(), 'article count' );
$this->assertSame( 1, DeferredUpdates::pendingUpdatesCount() );
$dbw->commit( __METHOD__ );
$this->assertSame( 1, DeferredUpdates::pendingUpdatesCount() );
DeferredUpdates::doUpdates();
$this->assertSame( 0, DeferredUpdates::pendingUpdatesCount() );
SiteStats::unload();
$this->assertEquals( $pi + 2, SiteStats::pages(), 'page count' );
$this->assertEquals( $ei + 2, SiteStats::edits(), 'edit count' );
$this->assertEquals( $ui, SiteStats::users(), 'user count' );
$this->assertEquals( $fi + 1, SiteStats::images(), 'file count' );
$this->assertEquals( $ai, SiteStats::articles(), 'article count' );
$statsInit = new SiteStatsInit();
$statsInit->refresh();
}
}