File: PatchSqlTest.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (34 lines) | stat: -rw-r--r-- 928 bytes parent folder | download
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
<?php

namespace MediaWiki\Tests\Maintenance;

use PatchSql;

/**
 * @covers \PatchSql
 * @group Database
 * @author Dreamy Jazz
 */
class PatchSqlTest extends MaintenanceBaseTestCase {

	protected function getMaintenanceClass() {
		return PatchSql::class;
	}

	public function testExecute() {
		// Create a SQL file with an insert query
		$testFilename = $this->getNewTempFile();
		$testFile = fopen( $testFilename, 'w' );
		fwrite( $testFile, "INSERT INTO /*_*/updatelog (ul_key, ul_value) VALUES ('testing1234', 'testing');\n" );
		fclose( $testFile );
		// Pass the file to the maintenance script and run it
		$this->maintenance->setArg( 'patch-name', $testFilename );
		$this->maintenance->execute();
		// Check that the insert query worked
		$this->newSelectQueryBuilder()
			->select( [ 'ul_key', 'ul_value' ] )
			->from( 'updatelog' )
			->caller( __METHOD__ )
			->assertRowValue( [ 'testing1234', 'testing' ] );
	}
}