mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/AbuseFilter.git
synced 2025-01-07 10:14:19 +00:00
5377ebe819
composer: * mediawiki/mediawiki-codesniffer: 36.0.0 → 37.0.0 npm: * postcss: 7.0.35 → 7.0.36 * https://npmjs.com/advisories/1693 (CVE-2021-23368) Change-Id: I2b382f3bb236fb44eb24c6a257b13b8fd886541c
67 lines
2 KiB
PHP
67 lines
2 KiB
PHP
<?php
|
|
|
|
use MediaWiki\MediaWikiServices;
|
|
|
|
/**
|
|
* This trait can be used to perform uploads in integration tests.
|
|
* NOTE: The implementing classes MUST extend MediaWikiIntegrationTestCase
|
|
* The tearDown method must clear the local file
|
|
* @todo This might be moved to MediaWikiIntegrationTestCase
|
|
*
|
|
* @method string getNewTempDirectory()
|
|
* @method setMwGlobals($pairs)
|
|
*/
|
|
trait AbuseFilterUploadTestTrait {
|
|
/**
|
|
* @var string|null The path represented by this variable will be cleared in tearDown
|
|
*/
|
|
protected $clearPath;
|
|
|
|
/**
|
|
* Clear any temporary uploads, should be called from tearDown
|
|
*/
|
|
protected function clearUploads(): void {
|
|
if ( $this->clearPath ) {
|
|
$backend = MediaWikiServices::getInstance()->getRepoGroup()->getLocalRepo()->getBackend();
|
|
$backend->delete( [ 'src' => $this->clearPath ], [ 'force' => 1 ] );
|
|
$this->clearPath = null;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This is based on ApiUploadTestCase::fakeUploadFile
|
|
*
|
|
* @param User $user
|
|
* @param string $fileName
|
|
* @param string $pageText
|
|
* @param string $summary
|
|
* @return array [ Status, file path ]
|
|
*/
|
|
protected function doUpload( User $user, string $fileName, string $pageText, string $summary ): array {
|
|
global $wgFileExtensions;
|
|
|
|
$this->setMwGlobals( [ 'wgFileExtensions' => array_merge( $wgFileExtensions, [ 'svg' ] ) ] );
|
|
$imgGen = new RandomImageGenerator();
|
|
// Use SVG, since the ImageGenerator doesn't need anything special to create it
|
|
$format = 'svg';
|
|
$mime = 'image/svg+xml';
|
|
$filePath = $imgGen->writeImages( 1, $format, $this->getNewTempDirectory() )[0];
|
|
clearstatcache();
|
|
$request = new FauxRequest( [
|
|
'wpDestFile' => $fileName
|
|
] );
|
|
$request->setUpload( 'wpUploadFile', [
|
|
'name' => $fileName,
|
|
'type' => $mime,
|
|
'tmp_name' => $filePath,
|
|
'error' => UPLOAD_ERR_OK,
|
|
'size' => filesize( $filePath ),
|
|
] );
|
|
/** @var UploadFromFile $ub */
|
|
$ub = UploadBase::createFromRequest( $request );
|
|
$ub->verifyUpload();
|
|
$status = $ub->performUpload( $summary, $pageText, false, $user );
|
|
return [ $status, $ub->getLocalFile()->getPath() ];
|
|
}
|
|
}
|