Improve Automatic Actions plugin api
This commit is contained in:
49
tests/units/Action/TaskCreationTest.php
Normal file
49
tests/units/Action/TaskCreationTest.php
Normal file
@@ -0,0 +1,49 @@
|
||||
<?php
|
||||
|
||||
require_once __DIR__.'/../Base.php';
|
||||
|
||||
use Kanboard\Event\GenericEvent;
|
||||
use Kanboard\Model\TaskFinder;
|
||||
use Kanboard\Model\Project;
|
||||
use Kanboard\Action\TaskCreation as TaskCreationAction;
|
||||
|
||||
class TaskCreationActionTest extends Base
|
||||
{
|
||||
public function testSuccess()
|
||||
{
|
||||
$projectModel = new Project($this->container);
|
||||
$taskFinderModel = new TaskFinder($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'test1')));
|
||||
|
||||
$event = new GenericEvent(array('project_id' => 1, 'task_id' => 1, 'title' => 'test123', 'reference' => 'ref123', 'description' => 'test'));
|
||||
|
||||
$action = new TaskCreationAction($this->container);
|
||||
$action->setProjectId(1);
|
||||
$action->addEvent('test.event', 'Test Event');
|
||||
|
||||
$this->assertTrue($action->execute($event, 'test.event'));
|
||||
|
||||
$task = $taskFinderModel->getById(1);
|
||||
$this->assertNotEmpty($task);
|
||||
$this->assertEquals('test123', $task['title']);
|
||||
$this->assertEquals('ref123', $task['reference']);
|
||||
$this->assertEquals('test', $task['description']);
|
||||
}
|
||||
|
||||
public function testWithNoTitle()
|
||||
{
|
||||
$projectModel = new Project($this->container);
|
||||
$taskFinderModel = new TaskFinder($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'test1')));
|
||||
|
||||
$event = new GenericEvent(array('project_id' => 1, 'task_id' => 1, 'reference' => 'ref123', 'description' => 'test'));
|
||||
|
||||
$action = new TaskCreationAction($this->container);
|
||||
$action->setProjectId(1);
|
||||
$action->addEvent('test.event', 'Test Event');
|
||||
|
||||
$this->assertFalse($action->execute($event, 'test.event'));
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user