mirror of
https://github.com/YunoHost-Apps/kanboard_ynh.git
synced 2024-09-03 19:36:17 +02:00
187 lines
7.8 KiB
PHP
187 lines
7.8 KiB
PHP
<?php
|
|
|
|
require_once __DIR__.'/Base.php';
|
|
|
|
use Model\Task;
|
|
use Model\Project;
|
|
|
|
class TaskTest extends Base
|
|
{
|
|
public function testFilter()
|
|
{
|
|
$t = new Task($this->db, $this->event);
|
|
$p = new Project($this->db, $this->event);
|
|
|
|
$this->assertEquals(1, $p->create(array('name' => 'test1')));
|
|
$this->assertEquals(1, $t->create(array('title' => 'test a', 'project_id' => 1, 'column_id' => 3, 'owner_id' => 1, 'description' => 'biloute')));
|
|
$this->assertEquals(2, $t->create(array('title' => 'test b', 'project_id' => 1, 'column_id' => 2, 'owner_id' => 2, 'description' => 'toto et titi sont dans un bateau')));
|
|
|
|
$tasks = $t->find(array(array('column' => 'project_id', 'operator' => 'eq', 'value' => '1')));
|
|
$this->assertNotFalse($tasks);
|
|
$this->assertEquals(2, count($tasks));
|
|
$this->assertEquals(1, $tasks[0]['id']);
|
|
$this->assertEquals(2, $tasks[1]['id']);
|
|
|
|
$tasks = $t->find(array(
|
|
array('column' => 'project_id', 'operator' => 'eq', 'value' => '1'),
|
|
array('column' => 'owner_id', 'operator' => 'eq', 'value' => '2'),
|
|
));
|
|
$this->assertEquals(1, count($tasks));
|
|
$this->assertEquals(2, $tasks[0]['id']);
|
|
|
|
$tasks = $t->find(array(
|
|
array('column' => 'project_id', 'operator' => 'eq', 'value' => '1'),
|
|
array('column' => 'title', 'operator' => 'like', 'value' => '%b%'),
|
|
));
|
|
$this->assertEquals(1, count($tasks));
|
|
$this->assertEquals(2, $tasks[0]['id']);
|
|
|
|
// Condition with OR
|
|
$search = 'bateau';
|
|
$filters = array(
|
|
array('column' => 'project_id', 'operator' => 'eq', 'value' => 1),
|
|
'or' => array(
|
|
array('column' => 'title', 'operator' => 'like', 'value' => '%'.$search.'%'),
|
|
array('column' => 'description', 'operator' => 'like', 'value' => '%'.$search.'%'),
|
|
)
|
|
);
|
|
|
|
$tasks = $t->find($filters);
|
|
$this->assertEquals(1, count($tasks));
|
|
$this->assertEquals(2, $tasks[0]['id']);
|
|
|
|
$search = 'toto et titi';
|
|
$filters = array(
|
|
array('column' => 'project_id', 'operator' => 'eq', 'value' => 1),
|
|
'or' => array(
|
|
array('column' => 'title', 'operator' => 'like', 'value' => '%'.$search.'%'),
|
|
array('column' => 'description', 'operator' => 'like', 'value' => '%'.$search.'%'),
|
|
)
|
|
);
|
|
|
|
$tasks = $t->find($filters);
|
|
$this->assertEquals(1, count($tasks));
|
|
$this->assertEquals(2, $tasks[0]['id']);
|
|
|
|
$search = 'john';
|
|
$filters = array(
|
|
array('column' => 'project_id', 'operator' => 'eq', 'value' => 1),
|
|
'or' => array(
|
|
array('column' => 'title', 'operator' => 'like', 'value' => '%'.$search.'%'),
|
|
array('column' => 'description', 'operator' => 'like', 'value' => '%'.$search.'%'),
|
|
)
|
|
);
|
|
|
|
$tasks = $t->find($filters);
|
|
$this->assertEquals(0, count($tasks));
|
|
}
|
|
|
|
public function testDateFormat()
|
|
{
|
|
$t = new Task($this->db, $this->event);
|
|
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->getValidDate('2014-03-05', 'Y-m-d')));
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->getValidDate('2014_03_05', 'Y_m_d')));
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->getValidDate('05/03/2014', 'd/m/Y')));
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->getValidDate('03/05/2014', 'm/d/Y')));
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->getValidDate('3/5/2014', 'm/d/Y')));
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->getValidDate('5/3/2014', 'd/m/Y')));
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->getValidDate('5/3/14', 'd/m/y')));
|
|
$this->assertEquals(0, $t->getValidDate('5/3/14', 'd/m/Y'));
|
|
$this->assertEquals(0, $t->getValidDate('5-3-2014', 'd/m/Y'));
|
|
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->parseDate('2014-03-05')));
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->parseDate('2014_03_05')));
|
|
$this->assertEquals('2014-03-05', date('Y-m-d', $t->parseDate('03/05/2014')));
|
|
}
|
|
|
|
public function testDuplicateTask()
|
|
{
|
|
$t = new Task($this->db, $this->event);
|
|
$p = new Project($this->db, $this->event);
|
|
|
|
// We create a task and a project
|
|
$this->assertEquals(1, $p->create(array('name' => 'test1')));
|
|
$this->assertEquals(1, $t->create(array('title' => 'test', 'project_id' => 1, 'column_id' => 3, 'owner_id' => 1, 'category_id' => 2)));
|
|
|
|
$task = $t->getById(1);
|
|
$this->assertNotEmpty($task);
|
|
$this->assertEquals(0, $task['position']);
|
|
|
|
// We duplicate our task
|
|
$this->assertEquals(2, $t->duplicate(1));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_CREATE));
|
|
|
|
// Check the values of the duplicated task
|
|
$task = $t->getById(2);
|
|
$this->assertNotEmpty($task);
|
|
$this->assertEquals(Task::STATUS_OPEN, $task['is_active']);
|
|
$this->assertEquals(1, $task['project_id']);
|
|
$this->assertEquals(1, $task['owner_id']);
|
|
$this->assertEquals(1, $task['position']);
|
|
$this->assertEquals(2, $task['category_id']);
|
|
}
|
|
|
|
public function testDuplicateToAnotherProject()
|
|
{
|
|
$t = new Task($this->db, $this->event);
|
|
$p = new Project($this->db, $this->event);
|
|
|
|
// We create 2 projects
|
|
$this->assertEquals(1, $p->create(array('name' => 'test1')));
|
|
$this->assertEquals(2, $p->create(array('name' => 'test2')));
|
|
|
|
// We create a task
|
|
$this->assertEquals(1, $t->create(array('title' => 'test', 'project_id' => 1, 'column_id' => 1, 'owner_id' => 1, 'category_id' => 1)));
|
|
|
|
// We duplicate our task to the 2nd project
|
|
$this->assertEquals(2, $t->duplicateToAnotherProject(1, 2));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_CREATE));
|
|
|
|
// Check the values of the duplicated task
|
|
$task = $t->getById(2);
|
|
$this->assertNotEmpty($task);
|
|
$this->assertEquals(0, $task['owner_id']);
|
|
$this->assertEquals(0, $task['category_id']);
|
|
$this->assertEquals(2, $task['project_id']);
|
|
$this->assertEquals('test', $task['title']);
|
|
}
|
|
|
|
public function testEvents()
|
|
{
|
|
$t = new Task($this->db, $this->event);
|
|
$p = new Project($this->db, $this->event);
|
|
|
|
// We create a project
|
|
$this->assertEquals(1, $p->create(array('name' => 'test')));
|
|
|
|
// We create task
|
|
$this->assertEquals(1, $t->create(array('title' => 'test', 'project_id' => 1, 'column_id' => 1)));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_CREATE));
|
|
|
|
// We update a task
|
|
$this->assertTrue($t->update(array('title' => 'test2', 'id' => 1)));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_UPDATE));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_CREATE_UPDATE));
|
|
|
|
// We close our task
|
|
$this->assertTrue($t->close(1));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_CLOSE));
|
|
|
|
// We open our task
|
|
$this->assertTrue($t->open(1));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_OPEN));
|
|
|
|
// We change the column of our task
|
|
$this->assertTrue($t->move(1, 2, 1));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_MOVE_COLUMN));
|
|
|
|
// We change the position of our task
|
|
$this->assertTrue($t->move(1, 2, 2));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_MOVE_POSITION));
|
|
|
|
// We change the column and the position of our task
|
|
$this->assertTrue($t->move(1, 1, 3));
|
|
$this->assertTrue($this->event->isEventTriggered(Task::EVENT_MOVE_COLUMN));
|
|
}
|
|
}
|