diff options
| -rw-r--r-- | phpBB/phpbb/console/command/cache/purge.php | 4 | ||||
| -rw-r--r-- | tests/console/cache/fixtures/config.xml | 8 | ||||
| -rw-r--r-- | tests/console/cache/purge_test.php | 103 | 
3 files changed, 113 insertions, 2 deletions
| diff --git a/phpBB/phpbb/console/command/cache/purge.php b/phpBB/phpbb/console/command/cache/purge.php index ec8229200c..d0c2ef6f72 100644 --- a/phpBB/phpbb/console/command/cache/purge.php +++ b/phpBB/phpbb/console/command/cache/purge.php @@ -26,7 +26,7 @@ class purge extends \phpbb\console\command\command  	/** @var \phpbb\auth\auth */  	protected $auth; -	/** @var \phpbb\log\log */ +	/** @var \phpbb\log\log_interface */  	protected $log;  	/** @var \phpbb\config\config */ @@ -42,7 +42,7 @@ class purge extends \phpbb\console\command\command  	* @param \phpbb\log\log							$log	Logger instance  	* @param \phpbb\config\config					$config	Config instance  	*/ -	public function __construct(\phpbb\user $user, \phpbb\cache\driver\driver_interface $cache, \phpbb\db\driver\driver_interface $db, \phpbb\auth\auth $auth, \phpbb\log\log $log, \phpbb\config\config $config) +	public function __construct(\phpbb\user $user, \phpbb\cache\driver\driver_interface $cache, \phpbb\db\driver\driver_interface $db, \phpbb\auth\auth $auth, \phpbb\log\log_interface $log, \phpbb\config\config $config)  	{  		$this->cache = $cache;  		$this->db = $db; diff --git a/tests/console/cache/fixtures/config.xml b/tests/console/cache/fixtures/config.xml new file mode 100644 index 0000000000..2cb683d409 --- /dev/null +++ b/tests/console/cache/fixtures/config.xml @@ -0,0 +1,8 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<dataset> +	<table name="phpbb_config"> +		<column>config_name</column> +		<column>config_value</column> +		<column>is_dynamic</column> +	</table> +</dataset> diff --git a/tests/console/cache/purge_test.php b/tests/console/cache/purge_test.php new file mode 100644 index 0000000000..7fc9c97ca9 --- /dev/null +++ b/tests/console/cache/purge_test.php @@ -0,0 +1,103 @@ +<?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. +* +*/ + +use Symfony\Component\Console\Application; +use Symfony\Component\Console\Tester\CommandTester; +use phpbb\console\command\cache\purge; + +require_once dirname(__FILE__) . '/../../../phpBB/includes/functions_admin.php'; + +class phpbb_console_command_cache_purge_test extends phpbb_database_test_case +{ +	protected $cache_dir; +	protected $cache; +	protected $command_name; +	protected $db; +	protected $config; + +	public function __construct() +	{ +		$this->cache_dir = dirname(__FILE__) . 'tmp/cache/'; +	} + +	public function getDataSet() +	{ +		return $this->createXMLDataSet(dirname(__FILE__) . '/fixtures/config.xml'); +	} + +	protected function setUp() +	{ +		parent::setUp(); + +		if (file_exists($this->cache_dir)) +		{ +			// cache directory possibly left after aborted +			// or failed run earlier +			$this->remove_cache_dir(); +		} +		$this->create_cache_dir(); + +		$this->cache = new \phpbb\cache\driver\file($this->cache_dir); + +		$this->db = $this->new_dbal(); + +		$this->config = new \phpbb\config\config(array('assets_version' => 1)); +	} + +	public function test_purge() +	{ +		$this->cache->put('test_key', 'test_value'); + +		$this->assertEquals( +			'test_value', +			$this->cache->get('test_key'), +			'File ACM put and get' +		); + +		$command_tester = $this->get_command_tester(); +		$exit_status = $command_tester->execute(array('command' => $this->command_name)); + +		$this->assertSame(false, $this->cache->get('test_key')); +		$this->assertSame(2, $this->config['assets_version']); +	} + +	private function create_cache_dir() +	{ +		$this->get_test_case_helpers()->makedirs($this->cache_dir); +	} + +	private function remove_cache_dir() +	{ +		$iterator = new DirectoryIterator($this->cache_dir); +		foreach ($iterator as $file) +		{ +			if ($file != '.' && $file != '..') +			{ +				unlink($this->cache_dir . '/' . $file); +			} +		} +		rmdir($this->cache_dir); +	} + +	public function get_command_tester() +	{ +		global $phpbb_root_path, $phpEx; + +		$application = new Application(); +		$application->add(new purge($this->cache, $this->db, $this->getMock('\phpbb\auth\auth'), new \phpbb\log\null(), $this->getMock('\phpbb\user'), $this->config)); + +		$command = $application->find('cache:purge'); +		$this->command_name = $command->getName(); +		return new CommandTester($command); +	} +} | 
