aboutsummaryrefslogtreecommitdiffstats
path: root/tests/request/request_test.php
diff options
context:
space:
mode:
authorIgor Wiedler <igor@wiedler.ch>2011-01-10 00:26:48 +0100
committerIgor Wiedler <igor@wiedler.ch>2011-01-10 00:37:47 +0100
commitb5c8349f4a3399750b13463db8ad54f1aadfe178 (patch)
treefd20263038d3d49d5ed06d45a7ee4d2a6be2c468 /tests/request/request_test.php
parent95c683056b85399200e2caaa9aa65edc6843c16f (diff)
parentd7299f5071d461e6bf77df8c96b19bcd1bf027db (diff)
downloadforums-b5c8349f4a3399750b13463db8ad54f1aadfe178.tar
forums-b5c8349f4a3399750b13463db8ad54f1aadfe178.tar.gz
forums-b5c8349f4a3399750b13463db8ad54f1aadfe178.tar.bz2
forums-b5c8349f4a3399750b13463db8ad54f1aadfe178.tar.xz
forums-b5c8349f4a3399750b13463db8ad54f1aadfe178.zip
Merge branch 'develop-olympus' into develop
This merge commit includes ascraeus-specific renames and adjustments.
Diffstat (limited to 'tests/request/request_test.php')
-rw-r--r--tests/request/request_test.php77
1 files changed, 77 insertions, 0 deletions
diff --git a/tests/request/request_test.php b/tests/request/request_test.php
new file mode 100644
index 0000000000..203c9fd880
--- /dev/null
+++ b/tests/request/request_test.php
@@ -0,0 +1,77 @@
+<?php
+/**
+*
+* @package testing
+* @version $Id$
+* @copyright (c) 2009 phpBB Group
+* @license http://opensource.org/licenses/gpl-license.php GNU Public License
+*
+*/
+
+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'] = '';
+
+ $this->type_cast_helper = $this->getMock('phpbb_request_type_cast_helper_interface');
+
+ $this->request = new phpbb_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');
+
+ $_POST['x'] = 2;
+ $this->assertEquals($_POST, $GLOBALS['_POST'], 'Checking whether $_POST can still be accessed via $GLOBALS[\'_POST\']');
+ }
+
+ /**
+ * 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_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();
+ }
+}