aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorDavid King <imkingdavid@gmail.com>2012-02-19 15:26:20 -0500
committerDavid King <imkingdavid@gmail.com>2012-03-19 09:12:32 -0400
commit401de113f9a0cec57c9648a079303d30fdb23666 (patch)
treea3f9f9cc3c187dd4f999123d844d8970dae9da72 /tests
parente5ce9646567e6b3441c21ab960f8a77f1281c72b (diff)
downloadforums-401de113f9a0cec57c9648a079303d30fdb23666.tar
forums-401de113f9a0cec57c9648a079303d30fdb23666.tar.gz
forums-401de113f9a0cec57c9648a079303d30fdb23666.tar.bz2
forums-401de113f9a0cec57c9648a079303d30fdb23666.tar.xz
forums-401de113f9a0cec57c9648a079303d30fdb23666.zip
[ticket/10586] test stuff. does not work yet, still need to put phpBB objects in bootstrap.php
Diffstat (limited to 'tests')
-rw-r--r--tests/functional/extension_controller_test.php96
1 files changed, 96 insertions, 0 deletions
diff --git a/tests/functional/extension_controller_test.php b/tests/functional/extension_controller_test.php
new file mode 100644
index 0000000000..7f0bccc485
--- /dev/null
+++ b/tests/functional/extension_controller_test.php
@@ -0,0 +1,96 @@
+<?php
+/**
+*
+* @package testing
+* @copyright (c) 2011 phpBB Group
+* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
+*
+*/
+
+/**
+* @group functional
+*/
+class phpbb_functional_extension_controller_test extends phpbb_functional_test_case
+{
+ public function setUp()
+ {
+ global $db, $cache;
+ $phpbb_extension_manager = new phpbb_extension_manager($db, 'phpbb_ext', '.php', $cache, '_cache');
+
+ $phpbb_extension_manager->enable('foobar');
+ $phpbb_extension_manager->enable('foo_bar');
+ $phpbb_extension_manager->enable('error_class');
+ $phpbb_extension_manager->enable('error_classtype');
+ }
+
+ public function tearDown()
+ {
+ global $db, $cache;
+ $phpbb_extension_manager = new phpbb_extension_manager($db, 'phpbb_ext', '.php', $cache, '_cache');
+
+ $phpbb_extension_manager->purge('foobar');
+ $phpbb_extension_manager->purge('foo_bar');
+ $phpbb_extension_manager->purge('error_class');
+ $phpbb_extension_manager->purge('error_classtype');
+ }
+
+ /**
+ * Check an extension at ./ext/foobar/ which should have the class
+ * phpbb_ext_foobar_controller
+ */
+ public function test_foobar()
+ {
+ $crawler = $this->request('GET', 'index.php?ext=foobar');
+ $this->assertGreaterThan(0, $crawler->filter('#welcome')->count());
+ }
+
+ /**
+ * Check an extension at ./ext/foo/bar/ which should have the class
+ * phpbb_ext_foo_bar_controller
+ */
+ public function test_foo_bar()
+ {
+ $crawler = $this->request('GET', 'index.php?ext=foo/bar');
+ $this->assertGreaterThan(0, $crawler->filter('#welcome')->count());
+ }
+
+ /**
+ * Check the error produced by extension at ./ext/error/class which has class
+ * phpbb_ext_foobar_controller
+ */
+ public function test_error_class_name()
+ {
+ $crawler = $this->request('GET', 'index.php?ext=error/class');
+ $this->assertGreaterThan(0, $crawler->filter('html:contains("The extension <strong>error_class</strong> is missing a controller class and cannot be accessed through the front-end.")')->count());
+ }
+
+ /**
+ * Check the error produced by extension at ./ext/error/classtype which has class
+ * phpbb_ext_error_classtype_controller but does not implement phpbb_extension_controller_interface
+ */
+ public function test_error_class_type()
+ {
+ $crawler = $this->request('GET', 'index.php?ext=error/classtype');
+ $this->assertGreaterThan(0, $crawler->filter('html:contains("The extension controller class <strong>phpbb_ext_error_classtype_controller</strong> is not an instance of the phpbb_extension_controller_interface.")')->count());
+ }
+
+ /**
+ * Check the error produced by extension at ./ext/error/disabled that is (obviously)
+ * a disabled extension
+ */
+ public function test_error_ext_disabled()
+ {
+ $crawler = $this->request('GET', 'index.php?ext=error/disabled');
+ $this->assertGreaterThan(0, $crawler->filter('html:contains("The extension <strong>error_classtype</strong> is not enabled.")')->count());
+ }
+
+ /**
+ * Check the error produced by extension at ./ext/error/404 that is (obviously)
+ * not existant
+ */
+ public function test_error_ext_missing()
+ {
+ $crawler = $this->request('GET', 'index.php?ext=error/404');
+ $this->assertGreaterThan(0, $crawler->filter('html:contains("The extension <strong>error_404</strong> does not exist.")')->count());
+ }
+}