5 class UploadStashTest
extends MediaWikiTestCase
{
7 * @var Array of UploadStashTestUser
11 public function setUp() {
14 // Setup a file for bug 29408
15 $this->bug29408File
= dirname( __FILE__
) . '/bug29408';
16 file_put_contents( $this->bug29408File
, "\x00" );
19 'sysop' => new ApiTestUser(
20 'Uploadstashtestsysop',
21 'Upload Stash Test Sysop',
22 'upload_stash_test_sysop@example.com',
25 'uploader' => new ApiTestUser(
26 'Uploadstashtestuser',
27 'Upload Stash Test User',
28 'upload_stash_test_user@example.com',
34 public function testBug29408() {
36 $wgUser = self
::$users['uploader']->user
;
38 $repo = RepoGroup
::singleton()->getLocalRepo();
39 $stash = new UploadStash( $repo );
41 // Throws exception caught by PHPUnit on failure
42 $file = $stash->stashFile( $this->bug29408File
);
43 // We'll never reach this point if we hit bug 29408
44 $this->assertTrue( true, 'Unrecognized file without extension' );
46 $stash->removeFile( $file->getFileKey() );
49 public function testValidRequest() {
50 $request = new FauxRequest( array( 'wpFileKey' => 'foo') );
51 $this->assertFalse( UploadFromStash
::isValidRequest($request), 'Check failure on bad wpFileKey' );
53 $request = new FauxRequest( array( 'wpSessionKey' => 'foo') );
54 $this->assertFalse( UploadFromStash
::isValidRequest($request), 'Check failure on bad wpSessionKey' );
56 $request = new FauxRequest( array( 'wpFileKey' => 'testkey-test.test') );
57 $this->assertTrue( UploadFromStash
::isValidRequest($request), 'Check good wpFileKey' );
59 $request = new FauxRequest( array( 'wpFileKey' => 'testkey-test.test') );
60 $this->assertTrue( UploadFromStash
::isValidRequest($request), 'Check good wpSessionKey' );
62 $request = new FauxRequest( array( 'wpFileKey' => 'testkey-test.test', 'wpSessionKey' => 'foo') );
63 $this->assertTrue( UploadFromStash
::isValidRequest($request), 'Check key precedence' );
66 public function tearDown() {
69 if( file_exists( $this->bug29408File
. "." ) ) {
70 unlink( $this->bug29408File
. "." );
73 if( file_exists( $this->bug29408File
) ) {
74 unlink( $this->bug29408File
);