mirror of
https://github.com/phpbb/phpbb.git
synced 2025-05-06 15:45:34 +02:00
If we already have a mimetype and the guesser's guess is the default fallback, we should keep the already existing mimetype the browser supplied. Otherwise, platforms that might not support mimetype guessers will cause us to always have the mimetype set to application/octet-stream on images. This will prevent users from uploading images. PHPBB3-13031
137 lines
3.4 KiB
PHP
137 lines
3.4 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* This file is part of the phpBB Forum Software package.
|
|
*
|
|
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
|
* @license GNU General Public License, version 2 (GPL-2.0)
|
|
*
|
|
* For full copyright and license information, please see
|
|
* the docs/CREDITS.txt file.
|
|
*
|
|
*/
|
|
|
|
/**
|
|
* @group functional
|
|
*/
|
|
class phpbb_functional_fileupload_form_test extends phpbb_functional_test_case
|
|
{
|
|
private $path;
|
|
|
|
public function setUp()
|
|
{
|
|
parent::setUp();
|
|
$this->path = __DIR__ . '/fixtures/files/';
|
|
$this->add_lang('posting');
|
|
}
|
|
|
|
public function tearDown()
|
|
{
|
|
$iterator = new DirectoryIterator(__DIR__ . '/../../phpBB/files/');
|
|
foreach ($iterator as $fileinfo)
|
|
{
|
|
if (
|
|
$fileinfo->isDot()
|
|
|| $fileinfo->isDir()
|
|
|| $fileinfo->getFilename() === 'index.htm'
|
|
|| $fileinfo->getFilename() === '.htaccess'
|
|
)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
unlink($fileinfo->getPathname());
|
|
}
|
|
}
|
|
|
|
private function upload_file($filename, $mimetype)
|
|
{
|
|
$file = array(
|
|
'tmp_name' => $this->path . $filename,
|
|
'name' => $filename,
|
|
'type' => $mimetype,
|
|
'size' => filesize($this->path . $filename),
|
|
'error' => UPLOAD_ERR_OK,
|
|
);
|
|
|
|
$crawler = self::$client->request(
|
|
'POST',
|
|
'posting.php?mode=reply&f=2&t=1&sid=' . $this->sid,
|
|
array('add_file' => $this->lang('ADD_FILE')),
|
|
array('fileupload' => $file)
|
|
);
|
|
|
|
return $crawler;
|
|
}
|
|
|
|
public function test_empty_file()
|
|
{
|
|
$this->login();
|
|
|
|
$crawler = $this->upload_file('empty.png', 'image/png');
|
|
$this->assertEquals($this->lang('EMPTY_FILEUPLOAD'), $crawler->filter('p.error')->text());
|
|
}
|
|
|
|
public function test_invalid_extension()
|
|
{
|
|
$this->login();
|
|
|
|
$crawler = $this->upload_file('illegal-extension.bif', 'application/octet-stream');
|
|
$this->assertEquals($this->lang('DISALLOWED_EXTENSION', 'bif'), $crawler->filter('p.error')->text());
|
|
}
|
|
|
|
public function test_disallowed_content()
|
|
{
|
|
$this->login();
|
|
|
|
$crawler = $this->upload_file('disallowed.jpg', 'image/jpeg');
|
|
$this->assertEquals($this->lang('DISALLOWED_CONTENT'), $crawler->filter('p.error')->text());
|
|
}
|
|
|
|
public function test_disallowed_content_no_check()
|
|
{
|
|
$this->login();
|
|
$this->admin_login();
|
|
$this->add_lang('ucp');
|
|
$crawler = self::request('GET', 'adm/index.php?sid=' . $this->sid . '&i=acp_attachments&mode=attach');
|
|
|
|
$form = $crawler->selectButton('Submit')->form();
|
|
$values = $form->getValues();
|
|
|
|
$values["config[check_attachment_content]"] = 0;
|
|
$form->setValues($values);
|
|
$crawler = self::submit($form);
|
|
|
|
// Request index for correct URL
|
|
$crawler = self::request('GET', 'index.php?sid=' . $this->sid);
|
|
|
|
$crawler = $this->upload_file('disallowed.jpg', 'image/jpeg');
|
|
|
|
// Hitting the UNABLE_GET_IMAGE_SIZE error means we passed the
|
|
// DISALLOWED_CONTENT check
|
|
$this->assertContainsLang('UNABLE_GET_IMAGE_SIZE', $crawler->text());
|
|
}
|
|
|
|
public function test_too_large()
|
|
{
|
|
$this->create_user('fileupload');
|
|
$this->login('fileupload');
|
|
|
|
$crawler = $this->upload_file('too-large.png', 'image/png');
|
|
$this->assertEquals($this->lang('WRONG_FILESIZE', '256', 'KiB'), $crawler->filter('p.error')->text());
|
|
}
|
|
|
|
public function test_valid_file()
|
|
{
|
|
$this->login();
|
|
|
|
$crawler = $this->upload_file('valid.jpg', 'image/jpeg');
|
|
|
|
// Ensure there was no error message rendered
|
|
$this->assertNotContains('<h2>' . $this->lang('INFORMATION') . '</h2>', $this->get_content());
|
|
|
|
// Also the file name should be in the first row of the files table
|
|
$this->assertEquals('valid.jpg', $crawler->filter('span.file-name')->eq(1)->text());
|
|
}
|
|
}
|