diff options
author | Frederic Guillot <fred@kanboard.net> | 2016-07-10 13:39:48 -0400 |
---|---|---|
committer | Frederic Guillot <fred@kanboard.net> | 2016-07-10 13:39:48 -0400 |
commit | 8a85550f92020286ed11ef8f663029e70a6fedd0 (patch) | |
tree | 11593e6bf26658e66608b5c01914341dd5a65153 | |
parent | 7dfd094ed4a50f08ba8ec02b6dd960c7394434d6 (diff) |
Added unit test for PR #2388
-rw-r--r-- | ChangeLog | 12 | ||||
-rw-r--r-- | tests/units/Action/TaskCloseNoActivityColumnTest.php | 49 |
2 files changed, 61 insertions, 0 deletions
@@ -1,3 +1,11 @@ +Version 1.0.32 (unreleased) +-------------- + +New features: + +* New automated action to close tasks without activity in a specific column +* Added the possibility to hide tasks in dashboard for a specific column + Version 1.0.31 -------------- @@ -32,6 +40,10 @@ Bug fixes: * Take default swimlane into consideration for SwimlaneModel::getFirstActiveSwimlane() * Fixed "due today" highlighting +Breaking changes: + +* Docker volume paths are changed to /var/www/app/{data,plugins} + Version 1.0.30 -------------- diff --git a/tests/units/Action/TaskCloseNoActivityColumnTest.php b/tests/units/Action/TaskCloseNoActivityColumnTest.php new file mode 100644 index 00000000..243d3359 --- /dev/null +++ b/tests/units/Action/TaskCloseNoActivityColumnTest.php @@ -0,0 +1,49 @@ +<?php + +require_once __DIR__.'/../Base.php'; + +use Kanboard\Action\TaskCloseNoActivityColumn; +use Kanboard\Event\TaskListEvent; +use Kanboard\Model\TaskCreationModel; +use Kanboard\Model\TaskFinderModel; +use Kanboard\Model\ProjectModel; +use Kanboard\Model\TaskModel; + +class TaskCloseNoActivityColumnTest extends Base +{ + public function testClose() + { + $projectModel = new ProjectModel($this->container); + $taskCreationModel = new TaskCreationModel($this->container); + $taskFinderModel = new TaskFinderModel($this->container); + + $this->assertEquals(1, $projectModel->create(array('name' => 'test1'))); + $this->assertEquals(1, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test'))); + $this->assertEquals(2, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test'))); + $this->assertEquals(3, $taskCreationModel->create(array('project_id' => 1, 'title' => 'test', 'column_id' => 2))); + + $this->container['db']->table(TaskModel::TABLE)->in('id', array(1, 3))->update(array('date_modification' => strtotime('-10days'))); + + $tasks = $taskFinderModel->getAll(1); + $event = new TaskListEvent(array('tasks' => $tasks, 'project_id' => 1)); + + $action = new TaskCloseNoActivityColumn($this->container); + $action->setProjectId(1); + $action->setParam('duration', 2); + $action->setParam('column_id', 2); + + $this->assertTrue($action->execute($event, TaskModel::EVENT_DAILY_CRONJOB)); + + $task = $taskFinderModel->getById(1); + $this->assertNotEmpty($task); + $this->assertEquals(1, $task['is_active']); + + $task = $taskFinderModel->getById(2); + $this->assertNotEmpty($task); + $this->assertEquals(1, $task['is_active']); + + $task = $taskFinderModel->getById(3); + $this->assertNotEmpty($task); + $this->assertEquals(0, $task['is_active']); + } +} |