wiki.techinc.nl/tests/phpunit/maintenance/MwSqlTest.php
Dreamy Jazz 7420433040 Test sql.php
Why:
* The maintenance scripts in core are mostly untested and testing
  the less complex scripts will improve the test coverage in core.

What:
* Add an integration test for sql.php which partly covers the
  file.

Bug: T371167
Change-Id: I5ba73fcc648652d39cc69a9eba78b3ee579b0db5
2024-07-29 08:34:03 +00:00

46 lines
1.2 KiB
PHP

<?php
namespace MediaWiki\Tests\Maintenance;
use MwSql;
/**
* @covers \MwSql
* @group Database
* @author Dreamy Jazz
*/
class MwSqlTest extends MaintenanceBaseTestCase {
protected function getMaintenanceClass() {
return MwSql::class;
}
public function testExecuteForSelectQuery() {
// Add a testing row to the updatelog table, which we will use the maintenance script to read back.
$this->getDb()->newInsertQueryBuilder()
->insertInto( 'updatelog' )
->row( [ 'ul_key' => 'testing', 'ul_value' => 'testing-value-12345' ] )
->caller( __METHOD__ )
->execute();
// Output JSON to make it easier to assert that the script worked.
$this->maintenance->setOption( 'json', 1 );
// Specify the query using the 'query' option to avoid needing to write to STDIN.
$this->maintenance->setOption(
'query',
$this->newSelectQueryBuilder()
->field( 'ul_value' )
->from( 'updatelog' )
->where( [ 'ul_key' => 'testing' ] )
->caller( __METHOD__ )
->getSQL()
);
$this->maintenance->execute();
$this->assertArrayEquals(
[ [ 'ul_value' => 'testing-value-12345' ] ],
json_decode( $this->getActualOutputForAssertion(), true ),
true,
true,
'JSON output was not as expected.'
);
}
}