[ticket/12602] Add files to print the cron list and test files.

PHPBB3-12602
This commit is contained in:
Etienne Baroux 2014-06-02 12:17:37 +02:00
parent 48679eeff8
commit 58d7302b49
8 changed files with 251 additions and 0 deletions

View file

@ -46,6 +46,14 @@ services:
tags:
- { name: console.command }
console.command.cron.list:
class: phpbb\console\command\cron\cron_list
arguments:
- @cron.manager
- @user
tags:
- { name: console.command }
console.command.cron.run:
class: phpbb\console\command\cron\run
arguments:

View file

@ -223,6 +223,7 @@ $lang = array_merge($lang, array(
'BACK' => 'Back',
'CLI_DESCRIPTION_CRON_LIST' => 'Print the cron list.',
'CLI_DESCRIPTION_CRON_RUN' => 'Runs all ready cron tasks.',
'CLI_DESCRIPTION_CRON_RUN_ARGUMENT_1' => 'Name of the task to be run',

View file

@ -0,0 +1,80 @@
<?php
/**
*
* @package phpBB3
* @copyright (c) 2014 phpBB Group
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
*
*/
namespace phpbb\console\command\cron;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
class cron_list extends \phpbb\console\command\command
{
/** @var \phpbb\cron\manager */
protected $cron_manager;
/** @var \phpbb\user */
protected $user;
public function __construct(\phpbb\cron\manager $cron_manager, \phpbb\user $user)
{
$this->cron_manager = $cron_manager;
$this->user = $user;
parent::__construct();
}
protected function configure()
{
$this
->setName('cron:list')
->setDescription($this->user->lang('CLI_DESCR_CRON_LIST'))
;
}
protected function execute(InputInterface $input, OutputInterface $output)
{
$tasks = $this->cron_manager->get_tasks();
if (empty($tasks))
{
$output->writeln($this->user->lang('NO_TASK'));
return;
}
$ready_tasks = array();
$not_ready_tasks = array();
foreach ($tasks as $task)
{
if ($task->is_ready())
{
$ready_tasks[] = $task;
}
else
{
$not_ready_tasks[] = $task;
}
}
if (!empty($ready_tasks))
{
$output->writeln('<info>' . $this->user->lang('TASKS_READY') . '</info>');
foreach ($ready_tasks as $task)
{
$output->writeln($task->get_name());
}
$output->writeln('');
}
if (!empty($not_ready_tasks))
{
$output->writeln('<info>' . $this->user->lang('TASKS_NOT_READY') . '</info>');
foreach ($not_ready_tasks as $task)
{
$output->writeln($task->get_name());
}
}
}
}

View file

@ -0,0 +1,100 @@
<?php
/**
*
* @package testing
* @copyright (c) 2014 phpBB Group
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
*
*/
require_once dirname(__FILE__) . '/tasks/simple.php';
require_once dirname(__FILE__) . '/tasks/simple_not_ready.php';
use Symfony\Component\Console\Application;
use Symfony\Component\Console\Tester\CommandTester;
use phpbb\console\command\cron\cron_list;
class phpbb_console_command_cron_list_test extends phpbb_test_case
{
/** @var \phpbb\cron\manager */
protected $cron_manager;
/** @var \phpbb\user */
protected $user;
protected $command_name;
protected function setUp()
{
$this->user = $this->getMock('\phpbb\user');
$this->user->method('lang')->will($this->returnArgument(0));
}
public function test_no_task()
{
$tasks = array();
$this->get_cron_manager($tasks);
$command_tester = $this->get_command_tester();
$command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true));
$this->assertContains('NO_TASK', $command_tester->getDisplay());
}
public function test_only_ready()
{
$tasks = array(
new phpbb_cron_task_simple(),
new phpbb_cron_task_simple()
);
$this->get_cron_manager($tasks);
$command_tester = $this->get_command_tester();
$command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true));
$this->assertContains('TASKS_READYcommand1command2', preg_replace('/\s+/', '', $command_tester->getDisplay()));
}
public function test_only_not_ready()
{
$tasks = array(
new phpbb_cron_task_simple_not_ready(),
new phpbb_cron_task_simple_not_ready()
);
$this->get_cron_manager($tasks);
$command_tester = $this->get_command_tester();
$command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true));
$this->assertContains('TASKS_NOT_READYcommand1command2', preg_replace('/\s+/', '', $command_tester->getDisplay()));
}
public function test_both_ready()
{
$tasks = array(
new phpbb_cron_task_simple(),
new phpbb_cron_task_simple(),
new phpbb_cron_task_simple_not_ready(),
new phpbb_cron_task_simple_not_ready()
);
$this->get_cron_manager($tasks);
$command_tester = $this->get_command_tester();
$command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true));
$this->assertSame('TASKS_READYcommand1command2TASKS_NOT_READYcommand3command4', preg_replace('/\s+/', '', $command_tester->getDisplay()));
}
public function get_cron_manager(array $tasks)
{
global $pathEx, $phpbb_root_path;
$i = 1;
foreach ($tasks as $task)
{
$task->set_name('command' . $i);
$i++;
}
$this->cron_manager = new \phpbb\cron\manager($tasks, $phpbb_root_path, $pathEx);
}
public function get_command_tester()
{
$application = new Application();
$application->add(new cron_list($this->cron_manager, $this->user));
$command = $application->find('cron:list');
$this->command_name = $command->getName();
return new CommandTester($command);
}
}

View file

@ -0,0 +1,13 @@
<?php
class phpbb_cron_task_simple_not_ready extends \phpbb\cron\task\base
{
public function run()
{
}
public function should_run()
{
return false;
}
}

View file

@ -0,0 +1,18 @@
<?php
class phpbb_cron_task_core_simple_not_runnable extends \phpbb\cron\task\base
{
public function get_name()
{
return get_class($this);
}
public function run()
{
}
public function is_runnable()
{
return false;
}
}

View file

@ -0,0 +1,13 @@
<?php
class phpbb_cron_task_core_simple_ready extends \phpbb\cron\task\base
{
public function get_name()
{
return get_class($this);
}
public function run()
{
}
}

View file

@ -0,0 +1,18 @@
<?php
class phpbb_cron_task_core_simple_should_not_run extends \phpbb\cron\task\base
{
public function get_name()
{
return get_class($this);
}
public function run()
{
}
public function should_run()
{
return false;
}
}