<?php
-/**
- * Plugin Manager tests
- */
+namespace Shaarli\Plugin;
-require_once 'application/PluginManager.php';
+use Shaarli\Config\ConfigManager;
/**
* Unit tests for Plugins
*/
-class PluginManagerTest extends PHPUnit_Framework_TestCase
+class PluginManagerTest extends \Shaarli\TestCase
{
/**
* Path to tests plugin.
- * @var string $_PLUGIN_PATH
+ * @var string $pluginPath
*/
- private static $_PLUGIN_PATH = 'tests/plugins';
+ private static $pluginPath = 'tests/plugins';
/**
* Test plugin.
- * @var string $_PLUGIN_NAME
+ * @var string $pluginName
*/
- private static $_PLUGIN_NAME = 'test';
+ private static $pluginName = 'test';
/**
- * Test plugin loading and hook execution.
- *
- * @return void
+ * @var PluginManager $pluginManager Plugin Mananger instance.
*/
- public function testPlugin()
+ protected $pluginManager;
+
+ public function setUp(): void
{
- $pluginManager = PluginManager::getInstance();
+ $conf = new ConfigManager('');
+ $this->pluginManager = new PluginManager($conf);
+ }
- PluginManager::$PLUGINS_PATH = self::$_PLUGIN_PATH;
- $pluginManager->load(array(self::$_PLUGIN_NAME));
+ /**
+ * Test plugin loading and hook execution.
+ */
+ public function testPlugin(): void
+ {
+ PluginManager::$PLUGINS_PATH = self::$pluginPath;
+ $this->pluginManager->load(array(self::$pluginName));
$this->assertTrue(function_exists('hook_test_random'));
- $data = array(0 => 'woot');
- $pluginManager->executeHooks('random', $data);
- $this->assertEquals('woot', $data[1]);
+ $data = [0 => 'woot'];
+ $this->pluginManager->executeHooks('random', $data);
+
+ static::assertCount(2, $data);
+ static::assertSame('woot', $data[1]);
+
+ $data = [0 => 'woot'];
+ $this->pluginManager->executeHooks('random', $data, array('target' => 'test'));
+
+ static::assertCount(2, $data);
+ static::assertSame('page test', $data[1]);
+
+ $data = [0 => 'woot'];
+ $this->pluginManager->executeHooks('random', $data, array('loggedin' => true));
- $data = array(0 => 'woot');
- $pluginManager->executeHooks('random', $data, array('target' => 'test'));
- $this->assertEquals('page test', $data[1]);
+ static::assertCount(2, $data);
+ static::assertEquals('loggedin', $data[1]);
- $data = array(0 => 'woot');
- $pluginManager->executeHooks('random', $data, array('loggedin' => true));
- $this->assertEquals('loggedin', $data[1]);
+ $data = [0 => 'woot'];
+ $this->pluginManager->executeHooks('random', $data, array('loggedin' => null));
+
+ static::assertCount(3, $data);
+ static::assertEquals('loggedin', $data[1]);
+ static::assertArrayHasKey(2, $data);
+ static::assertNull($data[2]);
+ }
+
+ /**
+ * Test plugin loading and hook execution with an error: raise an incompatibility error.
+ */
+ public function testPluginWithPhpError(): void
+ {
+ PluginManager::$PLUGINS_PATH = self::$pluginPath;
+ $this->pluginManager->load(array(self::$pluginName));
+
+ $this->assertTrue(function_exists('hook_test_error'));
+
+ $data = [];
+ $this->pluginManager->executeHooks('error', $data);
+
+ $this->assertRegExp(
+ '/test \[plugin incompatibility\]: Class [\'"]Unknown[\'"] not found/',
+ $this->pluginManager->getErrors()[0]
+ );
}
/**
* Test missing plugin loading.
- *
- * @return void
*/
- public function testPluginNotFound()
+ public function testPluginNotFound(): void
{
- $pluginManager = PluginManager::getInstance();
+ $this->pluginManager->load([]);
+ $this->pluginManager->load(['nope', 'renope']);
+ $this->addToAssertionCount(1);
+ }
- $pluginManager->load(array());
+ /**
+ * Test plugin metadata loading.
+ */
+ public function testGetPluginsMeta(): void
+ {
+ PluginManager::$PLUGINS_PATH = self::$pluginPath;
+ $this->pluginManager->load([self::$pluginName]);
- $pluginManager->load(array('nope', 'renope'));
+ $expectedParameters = [
+ 'pop' => [
+ 'value' => '',
+ 'desc' => 'pop description',
+ ],
+ 'hip' => [
+ 'value' => '',
+ 'desc' => '',
+ ],
+ ];
+ $meta = $this->pluginManager->getPluginsMeta();
+ $this->assertEquals('test plugin', $meta[self::$pluginName]['description']);
+ $this->assertEquals($expectedParameters, $meta[self::$pluginName]['parameters']);
}
-}
\ No newline at end of file
+}