diff options
Diffstat (limited to 'tests/extension/manager_test.php')
| -rw-r--r-- | tests/extension/manager_test.php | 102 | 
1 files changed, 102 insertions, 0 deletions
diff --git a/tests/extension/manager_test.php b/tests/extension/manager_test.php new file mode 100644 index 0000000000..0a689916c7 --- /dev/null +++ b/tests/extension/manager_test.php @@ -0,0 +1,102 @@ +<?php +/** +* +* @package testing +* @copyright (c) 2011 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +require_once dirname(__FILE__) . '/../mock/cache.php'; +require_once dirname(__FILE__) . '/ext/bar/ext.php'; +require_once dirname(__FILE__) . '/ext/foo/ext.php'; +require_once dirname(__FILE__) . '/ext/vendor/moo/ext.php'; + +class phpbb_extension_manager_test extends phpbb_database_test_case +{ +	protected $extension_manager; +	protected $class_loader; + +	public function getDataSet() +	{ +		return $this->createXMLDataSet(dirname(__FILE__) . '/fixtures/extensions.xml'); +	} + +	protected function setUp() +	{ +		parent::setUp(); + +		$this->extension_manager = new phpbb_extension_manager( +			$this->new_dbal(), +			'phpbb_ext', +			dirname(__FILE__) . '/', +			'.php', +			new phpbb_mock_cache +		); +	} + +	public function test_available() +	{ +		$this->assertEquals(array('bar', 'foo', 'vendor/moo'), array_keys($this->extension_manager->all_available())); +	} + +	public function test_enabled() +	{ +		$this->assertEquals(array('foo'), array_keys($this->extension_manager->all_enabled())); +	} + +	public function test_configured() +	{ +		$this->assertEquals(array('foo', 'vendor/moo'), array_keys($this->extension_manager->all_configured())); +	} + +	public function test_enable() +	{ +		phpbb_ext_bar_ext::$state = 0; + +		$this->assertEquals(array('foo'), array_keys($this->extension_manager->all_enabled())); +		$this->extension_manager->enable('bar'); +		$this->assertEquals(array('bar', 'foo'), array_keys($this->extension_manager->all_enabled())); +		$this->assertEquals(array('bar', 'foo', 'vendor/moo'), array_keys($this->extension_manager->all_configured())); + +		$this->assertEquals(4, phpbb_ext_bar_ext::$state); +	} + +	public function test_disable() +	{ +		phpbb_ext_foo_ext::$disabled = false; + +		$this->assertEquals(array('foo'), array_keys($this->extension_manager->all_enabled())); +		$this->extension_manager->disable('foo'); +		$this->assertEquals(array(), array_keys($this->extension_manager->all_enabled())); +		$this->assertEquals(array('foo', 'vendor/moo'), array_keys($this->extension_manager->all_configured())); + +		$this->assertTrue(phpbb_ext_foo_ext::$disabled); +	} + +	public function test_purge() +	{ +		phpbb_ext_vendor_moo_ext::$purged = false; + +		$this->assertEquals(array('foo'), array_keys($this->extension_manager->all_enabled())); +		$this->assertEquals(array('foo', 'vendor/moo'), array_keys($this->extension_manager->all_configured())); +		$this->extension_manager->purge('vendor/moo'); +		$this->assertEquals(array('foo'), array_keys($this->extension_manager->all_enabled())); +		$this->assertEquals(array('foo'), array_keys($this->extension_manager->all_configured())); + +		$this->assertTrue(phpbb_ext_vendor_moo_ext::$purged); +	} + +	public function test_enabled_no_cache() +	{ +		$extension_manager = new phpbb_extension_manager( +			$this->new_dbal(), +			'phpbb_ext', +			dirname(__FILE__) . '/', +			'.php' +		); + +		$this->assertEquals(array('foo'), array_keys($extension_manager->all_enabled())); +	} + +}  | 
