wiki.techinc.nl/tests/phpunit/maintenance/DatabaseLagTest.php
TheresNoTime a60327b9df lag.php: Return replication stopped or errored instead of False
Bug: T358484
Change-Id: Ibc88d2b86384a68b3cf6fe0d9739144247534821
2024-02-27 10:48:49 +00:00

48 lines
1.2 KiB
PHP

<?php
namespace MediaWiki\Tests\Maintenance;
use Wikimedia\Rdbms\ILoadBalancer;
/**
* @covers \DatabaseLag
* @group Maintenance
*/
class DatabaseLagTest extends MaintenanceBaseTestCase {
public function getMaintenanceClass() {
return \DatabaseLag::class;
}
public static function provideLagTimes() {
return [
'No lag' => [ 0, 'db-nolag-01', '/^db-nolag-01\s+0$/m' ],
'Some lag' => [ 42, 'db-somelag-02', '/^db-somelag-02\s+42$/m' ],
'Not replicating' => [
false, 'db-not-replicating-03',
'/db-not-replicating-03\s+replication stopped or errored$/m'
],
];
}
/**
* @dataProvider provideLagTimes
*/
public function testReportedOutput( $lag, $servername, $expected ) {
$lb = $this->createMock( ILoadBalancer::class );
$lb->method( 'getLagTimes' )->willReturn( [ $lag ] );
$lb->method( 'getServerName' )->willReturn( $servername );
$this->setService( 'DBLoadBalancer', $lb );
$this->maintenance->setOption( '-r', false );
$this->maintenance->execute();
$this->maintenance->setOption( '-r', true );
$this->maintenance->stopReporting = true;
$this->maintenance->execute();
$this->expectOutputRegex( $expected );
}
}