mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 13:16:14 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			133 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  *
 | |
|  * @package testing
 | |
|  * @copyright (c) 2012 phpBB Group
 | |
|  * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
 | |
|  *
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @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->assertEquals($this->lang('UNABLE_GET_IMAGE_SIZE'), $crawler->filter('p.error')->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());
 | |
| 	}
 | |
| }
 |