Added search in activity stream
This commit is contained in:
117
tests/units/Filter/ProjectActivityCreationDateFilterTest.php
Normal file
117
tests/units/Filter/ProjectActivityCreationDateFilterTest.php
Normal file
@@ -0,0 +1,117 @@
|
||||
<?php
|
||||
|
||||
use Kanboard\Filter\ProjectActivityCreationDateFilter;
|
||||
use Kanboard\Model\Project;
|
||||
use Kanboard\Model\ProjectActivity;
|
||||
use Kanboard\Model\TaskCreation;
|
||||
use Kanboard\Model\TaskFinder;
|
||||
use Kanboard\Model\Task;
|
||||
|
||||
require_once __DIR__.'/../Base.php';
|
||||
|
||||
class ProjectActivityCreationDateFilterTest extends Base
|
||||
{
|
||||
public function testWithToday()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreationDateFilter('today');
|
||||
$filter->setDateParser($this->container['dateParser']);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
}
|
||||
|
||||
public function testWithYesterday()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreationDateFilter('yesterday');
|
||||
$filter->setDateParser($this->container['dateParser']);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(0, $events);
|
||||
}
|
||||
|
||||
public function testWithIsoDate()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreationDateFilter(date('Y-m-d'));
|
||||
$filter->setDateParser($this->container['dateParser']);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
}
|
||||
|
||||
public function testWithOperatorAndIsoDate()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreationDateFilter('>='.date('Y-m-d'));
|
||||
$filter->setDateParser($this->container['dateParser']);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreationDateFilter('<'.date('Y-m-d'));
|
||||
$filter->setDateParser($this->container['dateParser']);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(0, $events);
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreationDateFilter('>'.date('Y-m-d'));
|
||||
$filter->setDateParser($this->container['dateParser']);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(0, $events);
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreationDateFilter('>='.date('Y-m-d'));
|
||||
$filter->setDateParser($this->container['dateParser']);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
}
|
||||
}
|
||||
91
tests/units/Filter/ProjectActivityCreatorFilterTest.php
Normal file
91
tests/units/Filter/ProjectActivityCreatorFilterTest.php
Normal file
@@ -0,0 +1,91 @@
|
||||
<?php
|
||||
|
||||
use Kanboard\Filter\ProjectActivityCreatorFilter;
|
||||
use Kanboard\Model\Project;
|
||||
use Kanboard\Model\ProjectActivity;
|
||||
use Kanboard\Model\TaskCreation;
|
||||
use Kanboard\Model\TaskFinder;
|
||||
use Kanboard\Model\Task;
|
||||
|
||||
require_once __DIR__.'/../Base.php';
|
||||
|
||||
class ProjectActivityCreatorFilterTest extends Base
|
||||
{
|
||||
public function testWithUsername()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreatorFilter('admin');
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
}
|
||||
|
||||
public function testWithAnotherUsername()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreatorFilter('John Doe');
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(0, $events);
|
||||
}
|
||||
|
||||
public function testWithCurrentUser()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreatorFilter('me');
|
||||
$filter->setCurrentUserId(1);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
}
|
||||
|
||||
public function testWithAnotherCurrentUser()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityCreatorFilter('me');
|
||||
$filter->setCurrentUserId(2);
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(0, $events);
|
||||
}
|
||||
}
|
||||
35
tests/units/Filter/ProjectActivityProjectNameFilterTest.php
Normal file
35
tests/units/Filter/ProjectActivityProjectNameFilterTest.php
Normal file
@@ -0,0 +1,35 @@
|
||||
<?php
|
||||
|
||||
use Kanboard\Filter\ProjectActivityProjectNameFilter;
|
||||
use Kanboard\Model\Project;
|
||||
use Kanboard\Model\ProjectActivity;
|
||||
use Kanboard\Model\TaskCreation;
|
||||
use Kanboard\Model\TaskFinder;
|
||||
use Kanboard\Model\Task;
|
||||
|
||||
require_once __DIR__.'/../Base.php';
|
||||
|
||||
class ProjectActivityProjectNameFilterTest extends Base
|
||||
{
|
||||
public function testFilterByProjectName()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
$query = $projectActivityModel->getQuery();
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
$this->assertEquals(2, $projectModel->create(array('name' => 'P2')));
|
||||
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertEquals(2, $taskCreation->create(array('title' => 'Test', 'project_id' => 2)));
|
||||
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(2, 2, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(2))));
|
||||
|
||||
$filter = new ProjectActivityProjectNameFilter('P1');
|
||||
$filter->withQuery($query)->apply();
|
||||
$this->assertCount(1, $query->findAll());
|
||||
}
|
||||
}
|
||||
49
tests/units/Filter/ProjectActivityTaskStatusFilterTest.php
Normal file
49
tests/units/Filter/ProjectActivityTaskStatusFilterTest.php
Normal file
@@ -0,0 +1,49 @@
|
||||
<?php
|
||||
|
||||
use Kanboard\Filter\ProjectActivityTaskStatusFilter;
|
||||
use Kanboard\Model\Project;
|
||||
use Kanboard\Model\ProjectActivity;
|
||||
use Kanboard\Model\TaskCreation;
|
||||
use Kanboard\Model\TaskFinder;
|
||||
use Kanboard\Model\Task;
|
||||
use Kanboard\Model\TaskStatus;
|
||||
|
||||
require_once __DIR__.'/../Base.php';
|
||||
|
||||
class ProjectActivityTaskStatusFilterTest extends Base
|
||||
{
|
||||
public function testFilterByTaskStatus()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$taskStatus = new TaskStatus($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
$this->assertEquals(2, $taskCreation->create(array('title' => 'Test', 'project_id' => 1)));
|
||||
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 2, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(2))));
|
||||
|
||||
$this->assertTrue($taskStatus->close(1));
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityTaskStatusFilter('open');
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
$this->assertEquals(2, $events[0]['task_id']);
|
||||
|
||||
$query = $projectActivityModel->getQuery();
|
||||
$filter = new ProjectActivityTaskStatusFilter('closed');
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
$this->assertEquals(1, $events[0]['task_id']);
|
||||
}
|
||||
}
|
||||
@@ -11,7 +11,7 @@ require_once __DIR__.'/../Base.php';
|
||||
|
||||
class ProjectActivityTaskTitleFilterTest extends Base
|
||||
{
|
||||
public function testFilterByTaskId()
|
||||
public function testWithFullTitle()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
@@ -31,4 +31,49 @@ class ProjectActivityTaskTitleFilterTest extends Base
|
||||
$filter->withQuery($query)->apply();
|
||||
$this->assertCount(1, $query->findAll());
|
||||
}
|
||||
|
||||
public function testWithPartialTitle()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
$query = $projectActivityModel->getQuery();
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test1', 'project_id' => 1)));
|
||||
$this->assertEquals(2, $taskCreation->create(array('title' => 'Test2', 'project_id' => 1)));
|
||||
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 2, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(2))));
|
||||
|
||||
$filter = new ProjectActivityTaskTitleFilter('test');
|
||||
$filter->withQuery($query)->apply();
|
||||
$this->assertCount(2, $query->findAll());
|
||||
}
|
||||
|
||||
public function testWithId()
|
||||
{
|
||||
$taskFinder = new TaskFinder($this->container);
|
||||
$taskCreation = new TaskCreation($this->container);
|
||||
$projectModel = new Project($this->container);
|
||||
$projectActivityModel = new ProjectActivity($this->container);
|
||||
$query = $projectActivityModel->getQuery();
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'P1')));
|
||||
|
||||
$this->assertEquals(1, $taskCreation->create(array('title' => 'Test1', 'project_id' => 1)));
|
||||
$this->assertEquals(2, $taskCreation->create(array('title' => 'Test2', 'project_id' => 1)));
|
||||
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 1, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(1))));
|
||||
$this->assertNotFalse($projectActivityModel->createEvent(1, 2, 1, Task::EVENT_CREATE, array('task' => $taskFinder->getById(2))));
|
||||
|
||||
$filter = new ProjectActivityTaskTitleFilter('#2');
|
||||
$filter->withQuery($query)->apply();
|
||||
|
||||
$events = $query->findAll();
|
||||
$this->assertCount(1, $events);
|
||||
$this->assertEquals(2, $events[0]['task_id']);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user