summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/units/ProjectPermissionTest.php160
-rw-r--r--tests/units/ProjectTest.php142
-rw-r--r--tests/units/TaskTest.php4
3 files changed, 163 insertions, 143 deletions
diff --git a/tests/units/ProjectPermissionTest.php b/tests/units/ProjectPermissionTest.php
new file mode 100644
index 00000000..309fa63b
--- /dev/null
+++ b/tests/units/ProjectPermissionTest.php
@@ -0,0 +1,160 @@
+<?php
+
+require_once __DIR__.'/Base.php';
+
+use Model\Project;
+use Model\ProjectPermission;
+use Model\User;
+
+class ProjectPermissionTest extends Base
+{
+ public function testAllowEverybody()
+ {
+ // We create a regular user
+ $user = new User($this->registry);
+ $user->create(array('username' => 'unittest', 'password' => 'unittest'));
+
+ $p = new Project($this->registry);
+ $pp = new ProjectPermission($this->registry);
+
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
+
+ $this->assertEmpty($pp->getAllowedUsers(1)); // Nobody is specified for the given project
+ $this->assertTrue($pp->isUserAllowed(1, 1)); // Everybody should be allowed
+ $this->assertTrue($pp->isUserAllowed(1, 2)); // Everybody should be allowed
+ }
+
+ public function testAllowUser()
+ {
+ $p = new Project($this->registry);
+ $pp = new ProjectPermission($this->registry);
+ $user = new User($this->registry);
+
+ $user->create(array('username' => 'unittest', 'password' => 'unittest'));
+
+ // We create a project
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
+
+ // We allow the admin user
+ $this->assertTrue($pp->allowUser(1, 1));
+
+ // Non-existant project
+ $this->assertFalse($pp->allowUser(50, 1));
+
+ // Non-existant user
+ $this->assertFalse($pp->allowUser(1, 50));
+
+ // Our admin user should be allowed
+ $this->assertEquals(array('1' => 'admin'), $pp->getAllowedUsers(1));
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+
+ // Our regular user should be forbidden
+ $this->assertFalse($pp->isUserAllowed(1, 2));
+ }
+
+ public function testRevokeUser()
+ {
+ $p = new Project($this->registry);
+ $pp = new ProjectPermission($this->registry);
+ $user = new User($this->registry);
+
+ $user->create(array('username' => 'unittest', 'password' => 'unittest'));
+
+ // We create a project
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
+
+ // We revoke our admin user (not existing row)
+ $this->assertFalse($pp->revokeUser(1, 1));
+
+ // We should have nobody in the users list
+ $this->assertEmpty($pp->getAllowedUsers(1));
+
+ // Our admin user and our regular user should be allowed
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertTrue($pp->isUserAllowed(1, 2));
+
+ // We allow only the regular user
+ $this->assertTrue($pp->allowUser(1, 2));
+
+ // All users should be allowed (admin and regular)
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertTrue($pp->isUserAllowed(1, 2));
+
+ // However, we should have only our regular user in the list
+ $this->assertEquals(array('2' => 'unittest'), $pp->getAllowedUsers(1));
+
+ // We allow our admin, we should have both in the list
+ $this->assertTrue($pp->allowUser(1, 1));
+ $this->assertEquals(array('1' => 'admin', '2' => 'unittest'), $pp->getAllowedUsers(1));
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertTrue($pp->isUserAllowed(1, 2));
+
+ // We revoke the regular user
+ $this->assertTrue($pp->revokeUser(1, 2));
+
+ // Only admin should be allowed
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertFalse($pp->isUserAllowed(1, 2));
+
+ // We should have only admin in the list
+ $this->assertEquals(array('1' => 'admin'), $pp->getAllowedUsers(1));
+
+ // We revoke the admin user
+ $this->assertTrue($pp->revokeUser(1, 1));
+ $this->assertEmpty($pp->getAllowedUsers(1));
+
+ // Everybody should be allowed again
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertTrue($pp->isUserAllowed(1, 2));
+ }
+
+ public function testUsersList()
+ {
+ $p = new Project($this->registry);
+ $pp = new ProjectPermission($this->registry);
+
+ $user = new User($this->registry);
+ $user->create(array('username' => 'unittest', 'password' => 'unittest'));
+
+ // We create project
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
+
+ // No restriction, we should have everybody
+ $this->assertEquals(
+ array('Unassigned', 'admin', 'unittest'),
+ $pp->getUsersList(1)
+ );
+
+ // We allow only the regular user
+ $this->assertTrue($pp->allowUser(1, 2));
+
+ $this->assertEquals(
+ array(0 => 'Unassigned', 2 => 'unittest'),
+ $pp->getUsersList(1)
+ );
+
+ // We allow the admin user
+ $this->assertTrue($pp->allowUser(1, 1));
+
+ $this->assertEquals(
+ array(0 => 'Unassigned', 1 => 'admin', 2 => 'unittest'),
+ $pp->getUsersList(1)
+ );
+
+ // We revoke only the regular user
+ $this->assertTrue($pp->revokeUser(1, 2));
+
+ $this->assertEquals(
+ array(0 => 'Unassigned', 1 => 'admin'),
+ $pp->getUsersList(1)
+ );
+
+ // We revoke only the admin user, we should have everybody
+ $this->assertTrue($pp->revokeUser(1, 1));
+
+ $this->assertEquals(
+ array(0 => 'Unassigned', 1 => 'admin', 2 => 'unittest'),
+ $pp->getUsersList(1)
+ );
+ }
+}
diff --git a/tests/units/ProjectTest.php b/tests/units/ProjectTest.php
index dc71d5ae..be4267ca 100644
--- a/tests/units/ProjectTest.php
+++ b/tests/units/ProjectTest.php
@@ -136,146 +136,4 @@ class ProjectTest extends Base
$this->assertFalse($p->disablePublicAccess(123));
}
-
- public function testAllowEverybody()
- {
- // We create a regular user
- $user = new User($this->registry);
- $user->create(array('username' => 'unittest', 'password' => 'unittest'));
-
- $p = new Project($this->registry);
- $this->assertEmpty($p->getAllowedUsers(1)); // Nobody is specified for the given project
- $this->assertTrue($p->isUserAllowed(1, 1)); // Everybody should be allowed
- $this->assertTrue($p->isUserAllowed(1, 2)); // Everybody should be allowed
- }
-
- public function testAllowUser()
- {
- $p = new Project($this->registry);
- $user = new User($this->registry);
- $user->create(array('username' => 'unittest', 'password' => 'unittest'));
-
- // We create a project
- $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
-
- // We allow the admin user
- $this->assertTrue($p->allowUser(1, 1));
-
- // Non-existant project
- $this->assertFalse($p->allowUser(50, 1));
-
- // Non-existant user
- $this->assertFalse($p->allowUser(1, 50));
-
- // Our admin user should be allowed
- $this->assertEquals(array('1' => 'admin'), $p->getAllowedUsers(1));
- $this->assertTrue($p->isUserAllowed(1, 1));
-
- // Our regular user should be forbidden
- $this->assertFalse($p->isUserAllowed(1, 2));
- }
-
- public function testRevokeUser()
- {
- $p = new Project($this->registry);
-
- $user = new User($this->registry);
- $user->create(array('username' => 'unittest', 'password' => 'unittest'));
-
- // We create a project
- $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
-
- // We revoke our admin user (not existing row)
- $this->assertFalse($p->revokeUser(1, 1));
-
- // We should have nobody in the users list
- $this->assertEmpty($p->getAllowedUsers(1));
-
- // Our admin user and our regular user should be allowed
- $this->assertTrue($p->isUserAllowed(1, 1));
- $this->assertTrue($p->isUserAllowed(1, 2));
-
- // We allow only the regular user
- $this->assertTrue($p->allowUser(1, 2));
-
- // All users should be allowed (admin and regular)
- $this->assertTrue($p->isUserAllowed(1, 1));
- $this->assertTrue($p->isUserAllowed(1, 2));
-
- // However, we should have only our regular user in the list
- $this->assertEquals(array('2' => 'unittest'), $p->getAllowedUsers(1));
-
- // We allow our admin, we should have both in the list
- $this->assertTrue($p->allowUser(1, 1));
- $this->assertEquals(array('1' => 'admin', '2' => 'unittest'), $p->getAllowedUsers(1));
- $this->assertTrue($p->isUserAllowed(1, 1));
- $this->assertTrue($p->isUserAllowed(1, 2));
-
- // We revoke the regular user
- $this->assertTrue($p->revokeUser(1, 2));
-
- // Only admin should be allowed
- $this->assertTrue($p->isUserAllowed(1, 1));
- $this->assertFalse($p->isUserAllowed(1, 2));
-
- // We should have only admin in the list
- $this->assertEquals(array('1' => 'admin'), $p->getAllowedUsers(1));
-
- // We revoke the admin user
- $this->assertTrue($p->revokeUser(1, 1));
- $this->assertEmpty($p->getAllowedUsers(1));
-
- // Everybody should be allowed again
- $this->assertTrue($p->isUserAllowed(1, 1));
- $this->assertTrue($p->isUserAllowed(1, 2));
- }
-
- public function testUsersList()
- {
- $p = new Project($this->registry);
-
- $user = new User($this->registry);
- $user->create(array('username' => 'unittest', 'password' => 'unittest'));
-
- // We create project
- $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
-
- // No restriction, we should have everybody
- $this->assertEquals(
- array('Unassigned', 'admin', 'unittest'),
- $p->getUsersList(1)
- );
-
- // We allow only the regular user
- $this->assertTrue($p->allowUser(1, 2));
-
- $this->assertEquals(
- array(0 => 'Unassigned', 2 => 'unittest'),
- $p->getUsersList(1)
- );
-
- // We allow the admin user
- $this->assertTrue($p->allowUser(1, 1));
-
- $this->assertEquals(
- array(0 => 'Unassigned', 1 => 'admin', 2 => 'unittest'),
- $p->getUsersList(1)
- );
-
- // We revoke only the regular user
- $this->assertTrue($p->revokeUser(1, 2));
-
- $this->assertEquals(
- array(0 => 'Unassigned', 1 => 'admin'),
- $p->getUsersList(1)
- );
-
- // We revoke only the admin user, we should have everybody
- $this->assertTrue($p->revokeUser(1, 1));
-
- $this->assertEquals(
- array(0 => 'Unassigned', 1 => 'admin', 2 => 'unittest'),
- $p->getUsersList(1)
- );
- }
}
diff --git a/tests/units/TaskTest.php b/tests/units/TaskTest.php
index b5ba6c18..dee3accd 100644
--- a/tests/units/TaskTest.php
+++ b/tests/units/TaskTest.php
@@ -4,6 +4,7 @@ require_once __DIR__.'/Base.php';
use Model\Task;
use Model\Project;
+use Model\ProjectPermission;
use Model\Category;
use Model\User;
@@ -536,6 +537,7 @@ class TaskTest extends Base
{
$t = new Task($this->registry);
$p = new Project($this->registry);
+ $pp = new ProjectPermission($this->registry);
$user = new User($this->registry);
// We create a regular user
@@ -566,7 +568,7 @@ class TaskTest extends Base
$this->assertEquals('test', $task['title']);
// We allow only one user on the second project
- $this->assertTrue($p->allowUser(2, 2));
+ $this->assertTrue($pp->allowUser(2, 2));
// The owner should be reseted
$task = $t->getById(2);