mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-24 21:26:24 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			172 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			4.3 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.
 | |
| *
 | |
| */
 | |
| 
 | |
| class phpbb_request_test extends phpbb_test_case
 | |
| {
 | |
| 	private $type_cast_helper;
 | |
| 	private $request;
 | |
| 
 | |
| 	protected function setUp()
 | |
| 	{
 | |
| 		// populate super globals
 | |
| 		$_POST['test'] = 1;
 | |
| 		$_GET['test'] = 2;
 | |
| 		$_COOKIE['test'] = 3;
 | |
| 		$_REQUEST['test'] = 3;
 | |
| 		$_GET['unset'] = '';
 | |
| 		$_FILES['test'] = array(
 | |
| 			'name' => 'file',
 | |
| 			'tmp_name' => 'tmp',
 | |
| 			'size' => 256,
 | |
| 			'type' => 'application/octet-stream',
 | |
| 			'error' => UPLOAD_ERR_OK,
 | |
| 		);
 | |
| 
 | |
| 		$_SERVER['HTTP_HOST'] = 'example.com';
 | |
| 		$_SERVER['HTTP_ACCEPT'] = 'application/json';
 | |
| 		$_SERVER['HTTP_SOMEVAR'] = '<value>';
 | |
| 
 | |
| 		$this->type_cast_helper = $this->getMock('\phpbb\request\type_cast_helper_interface');
 | |
| 		$this->request = new \phpbb\request\request($this->type_cast_helper);
 | |
| 	}
 | |
| 
 | |
| 	public function test_toggle_super_globals()
 | |
| 	{
 | |
| 		$this->assertTrue($this->request->super_globals_disabled(), 'Superglobals were not disabled');
 | |
| 
 | |
| 		$this->request->enable_super_globals();
 | |
| 
 | |
| 		$this->assertFalse($this->request->super_globals_disabled(), 'Superglobals were not enabled');
 | |
| 
 | |
| 		$this->assertEquals(1, $_POST['test'], 'Checking $_POST after enable_super_globals');
 | |
| 		$this->assertEquals(2, $_GET['test'], 'Checking $_GET after enable_super_globals');
 | |
| 		$this->assertEquals(3, $_COOKIE['test'], 'Checking $_COOKIE after enable_super_globals');
 | |
| 		$this->assertEquals(3, $_REQUEST['test'], 'Checking $_REQUEST after enable_super_globals');
 | |
| 		$this->assertEquals(256, $_FILES['test']['size']);
 | |
| 
 | |
| 		$_POST['x'] = 2;
 | |
| 		$this->assertEquals($_POST, $GLOBALS['_POST'], 'Checking whether $_POST can still be accessed via $GLOBALS[\'_POST\']');
 | |
| 	}
 | |
| 
 | |
| 	public function test_server()
 | |
| 	{
 | |
| 		$this->assertEquals('example.com', $this->request->server('HTTP_HOST'));
 | |
| 	}
 | |
| 
 | |
| 	public function test_server_escaping()
 | |
| 	{
 | |
| 		$this->type_cast_helper
 | |
| 			->expects($this->once())
 | |
| 			->method('recursive_set_var')
 | |
| 			->with(
 | |
| 				$this->anything(),
 | |
| 				'',
 | |
| 				true
 | |
| 			);
 | |
| 
 | |
| 		$this->request->server('HTTP_SOMEVAR');
 | |
| 	}
 | |
| 
 | |
| 	public function test_header()
 | |
| 	{
 | |
| 		$this->assertEquals('application/json', $this->request->header('Accept'));
 | |
| 	}
 | |
| 
 | |
| 	public function test_header_escaping()
 | |
| 	{
 | |
| 		$this->type_cast_helper
 | |
| 			->expects($this->once())
 | |
| 			->method('recursive_set_var')
 | |
| 			->with(
 | |
| 				$this->anything(),
 | |
| 				'',
 | |
| 				true
 | |
| 			);
 | |
| 
 | |
| 		$this->request->header('SOMEVAR');
 | |
| 	}
 | |
| 
 | |
| 	public function test_file()
 | |
| 	{
 | |
| 		$file = $this->request->file('test');
 | |
| 		$this->assertEquals('file', $file['name']);
 | |
| 		$this->assertEquals('tmp', $file['tmp_name']);
 | |
| 		$this->assertEquals(256, $file['size']);
 | |
| 		$this->assertEquals('application/octet-stream', $file['type']);
 | |
| 		$this->assertEquals(UPLOAD_ERR_OK, $file['error']);
 | |
| 	}
 | |
| 
 | |
| 	public function test_file_not_exists()
 | |
| 	{
 | |
| 		$file = $this->request->file('404');
 | |
| 		$this->assertTrue(is_array($file));
 | |
| 		$this->assertTrue(empty($file));
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Checks that directly accessing $_POST will trigger
 | |
| 	* an error.
 | |
| 	*/
 | |
| 	public function test_disable_post_super_global()
 | |
| 	{
 | |
| 		$this->setExpectedTriggerError(E_USER_ERROR);
 | |
| 		$_POST['test'] = 3;
 | |
| 	}
 | |
| 
 | |
| 	public function test_is_set_post()
 | |
| 	{
 | |
| 		$this->assertTrue($this->request->is_set_post('test'));
 | |
| 		$this->assertFalse($this->request->is_set_post('unset'));
 | |
| 	}
 | |
| 
 | |
| 	public function test_is_ajax_without_ajax()
 | |
| 	{
 | |
| 		$this->assertFalse($this->request->is_ajax());
 | |
| 	}
 | |
| 
 | |
| 	public function test_is_ajax_with_ajax()
 | |
| 	{
 | |
| 		$this->request->enable_super_globals();
 | |
| 		$_SERVER['HTTP_X_REQUESTED_WITH'] = 'XMLHttpRequest';
 | |
| 		$this->request = new \phpbb\request\request($this->type_cast_helper);
 | |
| 
 | |
| 		$this->assertTrue($this->request->is_ajax());
 | |
| 	}
 | |
| 
 | |
| 	public function test_is_secure()
 | |
| 	{
 | |
| 		$this->assertFalse($this->request->is_secure());
 | |
| 
 | |
| 		$this->request->enable_super_globals();
 | |
| 		$_SERVER['HTTPS'] = 'on';
 | |
| 		$this->request = new \phpbb\request\request($this->type_cast_helper);
 | |
| 
 | |
| 		$this->assertTrue($this->request->is_secure());
 | |
| 	}
 | |
| 
 | |
| 	public function test_variable_names()
 | |
| 	{
 | |
| 		$expected = array('test', 'unset');
 | |
| 		$result = $this->request->variable_names();
 | |
| 		$this->assertEquals($expected, $result);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Makes sure super globals work properly after these tests
 | |
| 	*/
 | |
| 	protected function tearDown()
 | |
| 	{
 | |
| 		$this->request->enable_super_globals();
 | |
| 	}
 | |
| }
 |