From c58478c0abfb418048d2ee9c6297a30793f10f80 Mon Sep 17 00:00:00 2001 From: Frederic Guillot Date: Fri, 15 Jan 2016 21:03:19 -0500 Subject: Move analytic logic to separate classes --- .../Analytic/UserDistributionAnalyticTest.php | 83 ++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 tests/units/Analytic/UserDistributionAnalyticTest.php (limited to 'tests/units/Analytic/UserDistributionAnalyticTest.php') diff --git a/tests/units/Analytic/UserDistributionAnalyticTest.php b/tests/units/Analytic/UserDistributionAnalyticTest.php new file mode 100644 index 00000000..bdc136e1 --- /dev/null +++ b/tests/units/Analytic/UserDistributionAnalyticTest.php @@ -0,0 +1,83 @@ +container); + $projectUserRoleModel = new ProjectUserRole($this->container); + $userModel = new User($this->container); + $userDistributionModel = new UserDistributionAnalytic($this->container); + + $this->assertEquals(1, $projectModel->create(array('name' => 'test1'))); + $this->assertEquals(2, $projectModel->create(array('name' => 'test1'))); + + $this->assertEquals(2, $userModel->create(array('username' => 'user1'))); + $this->assertEquals(3, $userModel->create(array('username' => 'user2'))); + $this->assertEquals(4, $userModel->create(array('username' => 'user3'))); + $this->assertEquals(5, $userModel->create(array('username' => 'user4'))); + + $this->assertTrue($projectUserRoleModel->addUser(1, 2, Role::PROJECT_MEMBER)); + $this->assertTrue($projectUserRoleModel->addUser(1, 3, Role::PROJECT_MEMBER)); + $this->assertTrue($projectUserRoleModel->addUser(1, 4, Role::PROJECT_MEMBER)); + $this->assertTrue($projectUserRoleModel->addUser(1, 5, Role::PROJECT_MEMBER)); + + $this->createTasks(0, 10, 1); + $this->createTasks(2, 30, 1); + $this->createTasks(3, 40, 1); + $this->createTasks(4, 10, 1); + $this->createTasks(5, 10, 1); + + $expected = array( + array( + 'user' => 'Unassigned', + 'nb_tasks' => 10, + 'percentage' => 10.0, + ), + array( + 'user' => 'user1', + 'nb_tasks' => 30, + 'percentage' => 30.0, + ), + array( + 'user' => 'user2', + 'nb_tasks' => 40, + 'percentage' => 40.0, + ), + array( + 'user' => 'user3', + 'nb_tasks' => 10, + 'percentage' => 10.0, + ), + array( + 'user' => 'user4', + 'nb_tasks' => 10, + 'percentage' => 10.0, + ) + ); + + $this->assertEquals($expected, $userDistributionModel->build(1)); + } + + private function createTasks($user_id, $nb_active, $nb_inactive) + { + $taskCreationModel = new TaskCreation($this->container); + + for ($i = 0; $i < $nb_active; $i++) { + $this->assertNotFalse($taskCreationModel->create(array('project_id' => 1, 'title' => 'test', 'owner_id' => $user_id, 'is_active' => 1))); + } + + for ($i = 0; $i < $nb_inactive; $i++) { + $this->assertNotFalse($taskCreationModel->create(array('project_id' => 1, 'title' => 'test', 'owner_id' => $user_id, 'is_active' => 0))); + } + } +} -- cgit v1.2.3