aboutsummaryrefslogtreecommitdiffstats
path: root/tests/console/cron
diff options
context:
space:
mode:
authorEtienne Baroux <barouxe@phelma.grenoble-inp.fr>2014-06-02 12:17:37 +0200
committerEtienne Baroux <barouxe@phelma.grenoble-inp.fr>2014-06-02 12:17:37 +0200
commit58d7302b495783edd6e0826c100ffa93acb0693d (patch)
tree0bf3968c3f4d636e34ea7aa7847af10f0d44f20b /tests/console/cron
parent48679eeff884ce564f7a5ceb7db1b6c64e5dcb67 (diff)
downloadforums-58d7302b495783edd6e0826c100ffa93acb0693d.tar
forums-58d7302b495783edd6e0826c100ffa93acb0693d.tar.gz
forums-58d7302b495783edd6e0826c100ffa93acb0693d.tar.bz2
forums-58d7302b495783edd6e0826c100ffa93acb0693d.tar.xz
forums-58d7302b495783edd6e0826c100ffa93acb0693d.zip
[ticket/12602] Add files to print the cron list and test files.
PHPBB3-12602
Diffstat (limited to 'tests/console/cron')
-rw-r--r--tests/console/cron/cron_list_test.php100
-rw-r--r--tests/console/cron/tasks/simple_not_ready.php13
-rw-r--r--tests/console/cron/tasks/simple_not_runnable.php18
-rw-r--r--tests/console/cron/tasks/simple_ready.php13
-rw-r--r--tests/console/cron/tasks/simple_should_not_run.php18
5 files changed, 162 insertions, 0 deletions
diff --git a/tests/console/cron/cron_list_test.php b/tests/console/cron/cron_list_test.php
new file mode 100644
index 0000000000..12fac4a832
--- /dev/null
+++ b/tests/console/cron/cron_list_test.php
@@ -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);
+ }
+}
diff --git a/tests/console/cron/tasks/simple_not_ready.php b/tests/console/cron/tasks/simple_not_ready.php
new file mode 100644
index 0000000000..887768e5fe
--- /dev/null
+++ b/tests/console/cron/tasks/simple_not_ready.php
@@ -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;
+ }
+}
diff --git a/tests/console/cron/tasks/simple_not_runnable.php b/tests/console/cron/tasks/simple_not_runnable.php
new file mode 100644
index 0000000000..4951b5b4b9
--- /dev/null
+++ b/tests/console/cron/tasks/simple_not_runnable.php
@@ -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;
+ }
+}
diff --git a/tests/console/cron/tasks/simple_ready.php b/tests/console/cron/tasks/simple_ready.php
new file mode 100644
index 0000000000..245d9ba738
--- /dev/null
+++ b/tests/console/cron/tasks/simple_ready.php
@@ -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()
+ {
+ }
+}
diff --git a/tests/console/cron/tasks/simple_should_not_run.php b/tests/console/cron/tasks/simple_should_not_run.php
new file mode 100644
index 0000000000..7bd9df31b6
--- /dev/null
+++ b/tests/console/cron/tasks/simple_should_not_run.php
@@ -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;
+ }
+}