blob: 7e11210bd4b5638f93a478ce22682adaaf2634ec (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
<?php
use MediaWiki\SiteStats\SiteStats;
use Wikimedia\Rdbms\Platform\ISQLPlatform;
/**
* @group Database
*/
class SiteStatsTest extends MediaWikiIntegrationTestCase {
/**
* @covers \MediaWiki\SiteStats\SiteStats::jobs
*/
public function testJobsCountGetCached() {
$cache = new WANObjectCache( [ 'cache' => new HashBagOStuff() ] );
$this->setService( 'MainWANObjectCache', $cache );
$jobq = $this->getServiceContainer()->getJobQueueGroup();
$jobq->push( new NullJob( [] ) );
$this->assertSame( 1, SiteStats::jobs(),
'A single job enqueued bumps jobscount stat to 1' );
$jobq->push( new NullJob( [] ) );
$this->assertSame( 1, SiteStats::jobs(),
'SiteStats::jobs() count does not reflect addition ' .
'of a second job (cached)'
);
$jobq->get( 'null' )->delete(); // clear jobqueue
$this->assertSame( 0, $jobq->get( 'null' )->getSize(),
'Job queue for NullJob has been cleaned' );
$cache->delete( $cache->makeKey( 'SiteStats', 'jobscount' ) );
$this->assertSame( 1, SiteStats::jobs(),
'jobs count is kept in process cache' );
$cache->clearProcessCache();
$this->assertSame( 0, SiteStats::jobs() );
}
/**
* @covers \MediaWiki\SiteStats\SiteStats
*/
public function testInit() {
$this->getDb()->newDeleteQueryBuilder()
->deleteFrom( 'site_stats' )
->where( ISQLPlatform::ALL_ROWS )
->caller( __METHOD__ )
->execute();
SiteStats::unload();
SiteStats::edits();
$row = $this->getDb()->newSelectQueryBuilder()
->select( '1' )
->from( 'site_stats' )
->caller( __METHOD__ )->fetchRow();
$this->assertNotFalse( $row );
}
}
|