Add new automatic action: Move task to another column when the category is changed
This commit is contained in:
parent
0dc247dca1
commit
d577c73e46
|
|
@ -222,12 +222,17 @@ abstract class Base extends \Core\Base
|
|||
}
|
||||
|
||||
$data = $event->getAll();
|
||||
$result = false;
|
||||
|
||||
if ($this->isExecutable($data)) {
|
||||
$this->called = true;
|
||||
return $this->doAction($data);
|
||||
$result = $this->doAction($data);
|
||||
}
|
||||
|
||||
return false;
|
||||
if (DEBUG) {
|
||||
$this->container['logger']->debug(get_called_class().' => '.($result ? 'true' : 'false'));
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -22,6 +22,7 @@ class TaskMoveColumnAssigned extends Base
|
|||
{
|
||||
return array(
|
||||
Task::EVENT_ASSIGNEE_CHANGE,
|
||||
Task::EVENT_UPDATE,
|
||||
);
|
||||
}
|
||||
|
||||
|
|
@ -85,6 +86,6 @@ class TaskMoveColumnAssigned extends Base
|
|||
*/
|
||||
public function hasRequiredCondition(array $data)
|
||||
{
|
||||
return $data['column_id'] == $this->getParam('src_column_id') && $data['owner_id'];
|
||||
return $data['column_id'] == $this->getParam('src_column_id') && $data['owner_id'] > 0;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -0,0 +1,89 @@
|
|||
<?php
|
||||
|
||||
namespace Action;
|
||||
|
||||
use Model\Task;
|
||||
|
||||
/**
|
||||
* Move a task to another column when the category is changed
|
||||
*
|
||||
* @package action
|
||||
* @author Francois Ferrand
|
||||
*/
|
||||
class TaskMoveColumnCategoryChange extends Base
|
||||
{
|
||||
/**
|
||||
* Get the list of compatible events
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getCompatibleEvents()
|
||||
{
|
||||
return array(
|
||||
Task::EVENT_UPDATE,
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the required parameter for the action (defined by the user)
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getActionRequiredParameters()
|
||||
{
|
||||
return array(
|
||||
'dest_column_id' => t('Destination column'),
|
||||
'category_id' => t('Category'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the required parameter for the event
|
||||
*
|
||||
* @access public
|
||||
* @return string[]
|
||||
*/
|
||||
public function getEventRequiredParameters()
|
||||
{
|
||||
return array(
|
||||
'task_id',
|
||||
'column_id',
|
||||
'project_id',
|
||||
'category_id',
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Execute the action (move the task to another column)
|
||||
*
|
||||
* @access public
|
||||
* @param array $data Event data dictionary
|
||||
* @return bool True if the action was executed or false when not executed
|
||||
*/
|
||||
public function doAction(array $data)
|
||||
{
|
||||
$original_task = $this->taskFinder->getById($data['task_id']);
|
||||
|
||||
return $this->taskPosition->movePosition(
|
||||
$data['project_id'],
|
||||
$data['task_id'],
|
||||
$this->getParam('dest_column_id'),
|
||||
$original_task['position'],
|
||||
$original_task['swimlane_id']
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the event data meet the action condition
|
||||
*
|
||||
* @access public
|
||||
* @param array $data Event data dictionary
|
||||
* @return bool
|
||||
*/
|
||||
public function hasRequiredCondition(array $data)
|
||||
{
|
||||
return $data['column_id'] != $this->getParam('dest_column_id') && $data['category_id'] == $this->getParam('category_id');
|
||||
}
|
||||
}
|
||||
|
|
@ -21,7 +21,8 @@ class TaskMoveColumnUnAssigned extends Base
|
|||
public function getCompatibleEvents()
|
||||
{
|
||||
return array(
|
||||
Task::EVENT_ASSIGNEE_CHANGE
|
||||
Task::EVENT_ASSIGNEE_CHANGE,
|
||||
Task::EVENT_UPDATE,
|
||||
);
|
||||
}
|
||||
|
||||
|
|
@ -85,6 +86,6 @@ class TaskMoveColumnUnAssigned extends Base
|
|||
*/
|
||||
public function hasRequiredCondition(array $data)
|
||||
{
|
||||
return $data['column_id'] == $this->getParam('src_column_id') && ! $data['owner_id'];
|
||||
return $data['column_id'] == $this->getParam('src_column_id') && $data['owner_id'] == 0;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -57,6 +57,7 @@ class Action extends Base
|
|||
'TaskAssignUser' => t('Change the assignee based on an external username'),
|
||||
'TaskAssignCategoryLabel' => t('Change the category based on an external label'),
|
||||
'TaskUpdateStartDate' => t('Automatically update the start date'),
|
||||
'TaskMoveColumnCategoryChange' => t('Move the task to another column when the category is changed'),
|
||||
);
|
||||
|
||||
asort($values);
|
||||
|
|
|
|||
|
|
@ -42,13 +42,19 @@ class TaskModification extends Base
|
|||
*/
|
||||
public function fireEvents(array $task, array $new_values)
|
||||
{
|
||||
$events = array();
|
||||
$event_data = array_merge($task, $new_values, array('task_id' => $task['id']));
|
||||
|
||||
if (isset($new_values['owner_id']) && $task['owner_id'] != $new_values['owner_id']) {
|
||||
$events = array(Task::EVENT_ASSIGNEE_CHANGE);
|
||||
// Values changed
|
||||
$event_data['changes'] = array_diff_assoc($new_values, $task);
|
||||
unset($event_data['changes']['date_modification']);
|
||||
|
||||
if ($this->isFieldModified('owner_id', $event_data['changes'])) {
|
||||
$events[] = Task::EVENT_ASSIGNEE_CHANGE;
|
||||
}
|
||||
else {
|
||||
$events = array(Task::EVENT_CREATE_UPDATE, Task::EVENT_UPDATE);
|
||||
$events[] = Task::EVENT_CREATE_UPDATE;
|
||||
$events[] = Task::EVENT_UPDATE;
|
||||
}
|
||||
|
||||
foreach ($events as $event) {
|
||||
|
|
@ -56,6 +62,19 @@ class TaskModification extends Base
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Return true if the field is the only modified value
|
||||
*
|
||||
* @access public
|
||||
* @param string $field
|
||||
* @param array $changes
|
||||
* @return boolean
|
||||
*/
|
||||
public function isFieldModified($field, array $changes)
|
||||
{
|
||||
return isset($changes[$field]) && count($changes) === 1;
|
||||
}
|
||||
|
||||
/**
|
||||
* Prepare data before task modification
|
||||
*
|
||||
|
|
|
|||
|
|
@ -0,0 +1,61 @@
|
|||
<?php
|
||||
|
||||
require_once __DIR__.'/Base.php';
|
||||
|
||||
use Event\GenericEvent;
|
||||
use Model\Task;
|
||||
use Model\TaskCreation;
|
||||
use Model\TaskFinder;
|
||||
use Model\Project;
|
||||
use Model\Category;
|
||||
use Integration\GithubWebhook;
|
||||
|
||||
class ActionTaskMoveColumnCategoryChangeTest extends Base
|
||||
{
|
||||
public function testExecute()
|
||||
{
|
||||
$action = new Action\TaskMoveColumnCategoryChange($this->container, 1, Task::EVENT_UPDATE);
|
||||
$action->setParam('dest_column_id', 3);
|
||||
$action->setParam('category_id', 1);
|
||||
|
||||
$this->assertEquals(3, $action->getParam('dest_column_id'));
|
||||
$this->assertEquals(1, $action->getParam('category_id'));
|
||||
|
||||
// We create a task in the first column
|
||||
$tc = new TaskCreation($this->container);
|
||||
$tf = new TaskFinder($this->container);
|
||||
$p = new Project($this->container);
|
||||
$c = new Category($this->container);
|
||||
|
||||
$this->assertEquals(1, $p->create(array('name' => 'test')));
|
||||
$this->assertEquals(1, $c->create(array('name' => 'bug', 'project_id' => 1)));
|
||||
$this->assertEquals(1, $tc->create(array('title' => 'test', 'project_id' => 1, 'column_id' => 1)));
|
||||
|
||||
// No category should be assigned + column_id=1
|
||||
$task = $tf->getById(1);
|
||||
$this->assertNotEmpty($task);
|
||||
$this->assertEmpty($task['category_id']);
|
||||
$this->assertEquals(1, $task['column_id']);
|
||||
|
||||
// We create an event to move the task to the 2nd column
|
||||
$event = array(
|
||||
'task_id' => 1,
|
||||
'column_id' => 1,
|
||||
'project_id' => 1,
|
||||
'category_id' => 1,
|
||||
);
|
||||
|
||||
// Our event should be executed
|
||||
$this->assertTrue($action->hasCompatibleEvent());
|
||||
$this->assertTrue($action->hasRequiredProject($event));
|
||||
$this->assertTrue($action->hasRequiredParameters($event));
|
||||
$this->assertTrue($action->hasRequiredCondition($event));
|
||||
$this->assertTrue($action->isExecutable($event));
|
||||
$this->assertTrue($action->execute(new GenericEvent($event)));
|
||||
|
||||
// Our task should be moved to the other column
|
||||
$task = $tf->getById(1);
|
||||
$this->assertNotEmpty($task);
|
||||
$this->assertEquals(3, $task['column_id']);
|
||||
}
|
||||
}
|
||||
|
|
@ -38,7 +38,7 @@ class ActionTaskUpdateStartDateTest extends Base
|
|||
// Our event should be executed
|
||||
$this->assertTrue($action->execute(new GenericEvent($event)));
|
||||
|
||||
// Our task should be closed
|
||||
// Our task should be updated
|
||||
$task = $tf->getById(1);
|
||||
$this->assertNotEmpty($task);
|
||||
$this->assertEquals(time(), $task['date_started'], '', 2);
|
||||
|
|
|
|||
Loading…
Reference in New Issue