summaryrefslogtreecommitdiff
path: root/tests/units/Model/ProjectPermissionTest.php
diff options
context:
space:
mode:
authorFrederic Guillot <fred@kanboard.net>2015-09-05 23:30:56 -0400
committerFrederic Guillot <fred@kanboard.net>2015-09-05 23:30:56 -0400
commit710f2c7bb046b43ec9878ae795a181101f6d7515 (patch)
treeb62723b6b49c3b6bf2b3ca41a772f552464a9031 /tests/units/Model/ProjectPermissionTest.php
parent94b38dd94bd819168163003beec8ef693f9d9839 (diff)
Improve unit tests
Diffstat (limited to 'tests/units/Model/ProjectPermissionTest.php')
-rw-r--r--tests/units/Model/ProjectPermissionTest.php287
1 files changed, 287 insertions, 0 deletions
diff --git a/tests/units/Model/ProjectPermissionTest.php b/tests/units/Model/ProjectPermissionTest.php
new file mode 100644
index 00000000..475dd013
--- /dev/null
+++ b/tests/units/Model/ProjectPermissionTest.php
@@ -0,0 +1,287 @@
+<?php
+
+require_once __DIR__.'/../Base.php';
+
+use Model\Project;
+use Model\ProjectPermission;
+use Model\User;
+
+class ProjectPermissionTest extends Base
+{
+ public function testAllowEverybody()
+ {
+ $user = new User($this->container);
+ $this->assertNotFalse($user->create(array('username' => 'unittest#1', 'password' => 'unittest')));
+ $this->assertNotFalse($user->create(array('username' => 'unittest#2', 'password' => 'unittest')));
+
+ $p = new Project($this->container);
+ $pp = new ProjectPermission($this->container);
+
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
+ $this->assertFalse($pp->isEverybodyAllowed(1));
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertFalse($pp->isUserAllowed(1, 2));
+ $this->assertFalse($pp->isUserAllowed(1, 3));
+ $this->assertEquals(array(), $pp->getMembers(1));
+ $this->assertEquals(array('Unassigned'), $pp->getMemberList(1));
+
+ $this->assertEmpty($pp->getMemberProjects(1));
+ $this->assertEmpty($pp->getMemberProjects(2));
+ $this->assertEmpty($pp->getMemberProjects(3));
+
+ $this->assertEmpty($pp->getMemberProjectIds(1));
+ $this->assertEmpty($pp->getMemberProjectIds(2));
+ $this->assertEmpty($pp->getMemberProjectIds(3));
+
+ $this->assertEmpty($pp->getActiveMemberProjectIds(1));
+ $this->assertEmpty($pp->getActiveMemberProjectIds(2));
+ $this->assertEmpty($pp->getActiveMemberProjectIds(3));
+
+ $this->assertEmpty($pp->getActiveMemberProjects(1));
+ $this->assertEmpty($pp->getActiveMemberProjects(2));
+ $this->assertEmpty($pp->getActiveMemberProjects(3));
+
+ $this->assertTrue($p->update(array('id' => 1, 'is_everybody_allowed' => 1)));
+ $this->assertTrue($pp->isEverybodyAllowed(1));
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertTrue($pp->isUserAllowed(1, 2));
+ $this->assertTrue($pp->isUserAllowed(1, 3));
+ $this->assertEquals(array('1' => 'admin', '2' => 'unittest#1', '3' => 'unittest#2'), $pp->getMembers(1));
+ $this->assertEquals(array('Unassigned', '1' => 'admin', '2' => 'unittest#1', '3' => 'unittest#2'), $pp->getMemberList(1));
+
+ $this->assertNotEmpty($pp->getMemberProjects(1));
+ $this->assertNotEmpty($pp->getMemberProjects(2));
+ $this->assertNotEmpty($pp->getMemberProjects(3));
+
+ $this->assertNotEmpty($pp->getMemberProjectIds(1));
+ $this->assertNotEmpty($pp->getMemberProjectIds(2));
+ $this->assertNotEmpty($pp->getMemberProjectIds(3));
+
+ $this->assertNotEmpty($pp->getActiveMemberProjectIds(1));
+ $this->assertNotEmpty($pp->getActiveMemberProjectIds(2));
+ $this->assertNotEmpty($pp->getActiveMemberProjectIds(3));
+
+ $this->assertNotEmpty($pp->getActiveMemberProjects(1));
+ $this->assertNotEmpty($pp->getActiveMemberProjects(2));
+ $this->assertNotEmpty($pp->getActiveMemberProjects(3));
+
+ $this->assertTrue($p->disable(1));
+
+ $this->assertEmpty($pp->getActiveMemberProjectIds(1));
+ $this->assertEmpty($pp->getActiveMemberProjectIds(2));
+ $this->assertEmpty($pp->getActiveMemberProjectIds(3));
+
+ $this->assertEmpty($pp->getActiveMemberProjects(1));
+ $this->assertEmpty($pp->getActiveMemberProjects(2));
+ $this->assertEmpty($pp->getActiveMemberProjects(3));
+ }
+
+ public function testDisallowEverybody()
+ {
+ // We create a regular user
+ $user = new User($this->container);
+ $user->create(array('username' => 'unittest', 'password' => 'unittest'));
+
+ $p = new Project($this->container);
+ $pp = new ProjectPermission($this->container);
+
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
+
+ $this->assertEmpty($pp->getMembers(1)); // Nobody is specified for the given project
+ $this->assertTrue($pp->isUserAllowed(1, 1)); // Admin should be allowed
+ $this->assertFalse($pp->isUserAllowed(1, 2)); // Regular user should be denied
+ }
+
+ public function testAllowUser()
+ {
+ $p = new Project($this->container);
+ $pp = new ProjectPermission($this->container);
+ $user = new User($this->container);
+
+ $this->assertNotFalse($user->create(array('username' => 'unittest', 'password' => 'unittest')));
+
+ // We create a project
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
+
+ $this->assertEmpty($pp->getMemberProjects(1));
+ $this->assertEmpty($pp->getMemberProjects(2));
+
+ $this->assertEmpty($pp->getMemberProjectIds(1));
+ $this->assertEmpty($pp->getMemberProjectIds(2));
+
+ $this->assertEmpty($pp->getActiveMemberProjectIds(1));
+ $this->assertEmpty($pp->getActiveMemberProjectIds(2));
+
+ $this->assertEmpty($pp->getActiveMemberProjects(1));
+ $this->assertEmpty($pp->getActiveMemberProjects(2));
+
+ // We allow the admin user
+ $this->assertTrue($pp->addMember(1, 1));
+ $this->assertTrue($pp->addMember(1, 2));
+
+ // Non-existant project
+ $this->assertFalse($pp->addMember(50, 1));
+
+ // Non-existant user
+ $this->assertFalse($pp->addMember(1, 50));
+
+ // Both users should be allowed
+ $this->assertEquals(array('1' => 'admin', '2' => 'unittest'), $pp->getMembers(1));
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertTrue($pp->isUserAllowed(1, 2));
+
+ $this->assertNotEmpty($pp->getMemberProjects(1));
+ $this->assertNotEmpty($pp->getMemberProjects(2));
+
+ $this->assertNotEmpty($pp->getMemberProjectIds(1));
+ $this->assertNotEmpty($pp->getMemberProjectIds(2));
+
+ $this->assertNotEmpty($pp->getActiveMemberProjectIds(1));
+ $this->assertNotEmpty($pp->getActiveMemberProjectIds(2));
+
+ $this->assertNotEmpty($pp->getActiveMemberProjects(1));
+ $this->assertNotEmpty($pp->getActiveMemberProjects(2));
+ }
+
+ public function testRevokeUser()
+ {
+ $p = new Project($this->container);
+ $pp = new ProjectPermission($this->container);
+ $user = new User($this->container);
+
+ $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->revokeMember(1, 1));
+
+ // We should have nobody in the users list
+ $this->assertEmpty($pp->getMembers(1));
+
+ // Only admin is allowed
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertFalse($pp->isUserAllowed(1, 2));
+
+ // We allow only the regular user
+ $this->assertTrue($pp->addMember(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->getMembers(1));
+
+ // We allow our admin, we should have both in the list
+ $this->assertTrue($pp->addMember(1, 1));
+ $this->assertEquals(array('1' => 'admin', '2' => 'unittest'), $pp->getMembers(1));
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertTrue($pp->isUserAllowed(1, 2));
+
+ // We revoke the regular user
+ $this->assertTrue($pp->revokeMember(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->getMembers(1));
+
+ // We revoke the admin user
+ $this->assertTrue($pp->revokeMember(1, 1));
+ $this->assertEmpty($pp->getMembers(1));
+
+ // Only admin should be allowed again
+ $this->assertTrue($pp->isUserAllowed(1, 1));
+ $this->assertFalse($pp->isUserAllowed(1, 2));
+ }
+
+ public function testManager()
+ {
+ $p = new Project($this->container);
+ $pp = new ProjectPermission($this->container);
+ $u = new User($this->container);
+
+ $this->assertEquals(2, $u->create(array('username' => 'unittest', 'password' => 'unittest')));
+
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest1')));
+ $this->assertFalse($pp->isMember(1, 2));
+ $this->assertFalse($pp->isManager(1, 2));
+
+ $this->assertEquals(2, $p->create(array('name' => 'UnitTest2'), 1, true));
+ $this->assertFalse($pp->isMember(2, 2));
+ $this->assertFalse($pp->isManager(2, 2));
+
+ $this->assertEquals(3, $p->create(array('name' => 'UnitTest3'), 2, true));
+ $this->assertTrue($pp->isMember(3, 2));
+ $this->assertTrue($pp->isManager(3, 2));
+
+ $this->assertEquals(4, $p->create(array('name' => 'UnitTest4')));
+
+ $this->assertTrue($pp->addManager(4, 2));
+ $this->assertTrue($pp->isMember(4, 2));
+ $this->assertTrue($pp->isManager(4, 2));
+
+ $this->assertEquals(5, $p->create(array('name' => 'UnitTest5')));
+ $this->assertTrue($pp->addMember(5, 2));
+ $this->assertTrue($pp->changeRole(5, 2, 1));
+ $this->assertTrue($pp->isMember(5, 2));
+ $this->assertTrue($pp->isManager(5, 2));
+ $this->assertTrue($pp->changeRole(5, 2, 0));
+ $this->assertTrue($pp->isMember(5, 2));
+ $this->assertFalse($pp->isManager(5, 2));
+ }
+
+ public function testUsersList()
+ {
+ $p = new Project($this->container);
+ $pp = new ProjectPermission($this->container);
+
+ $user = new User($this->container);
+ $this->assertNotFalse($user->create(array('username' => 'unittest', 'password' => 'unittest')));
+
+ // We create project
+ $this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
+
+ // No restriction, we should have no body
+ $this->assertEquals(
+ array('Unassigned'),
+ $pp->getMemberList(1)
+ );
+
+ // We allow only the regular user
+ $this->assertTrue($pp->addMember(1, 2));
+
+ $this->assertEquals(
+ array(0 => 'Unassigned', 2 => 'unittest'),
+ $pp->getMemberList(1)
+ );
+
+ // We allow the admin user
+ $this->assertTrue($pp->addMember(1, 1));
+
+ $this->assertEquals(
+ array(0 => 'Unassigned', 1 => 'admin', 2 => 'unittest'),
+ $pp->getMemberList(1)
+ );
+
+ // We revoke only the regular user
+ $this->assertTrue($pp->revokeMember(1, 2));
+
+ $this->assertEquals(
+ array(0 => 'Unassigned', 1 => 'admin'),
+ $pp->getMemberList(1)
+ );
+
+ // We revoke only the admin user, we should have everybody
+ $this->assertTrue($pp->revokeMember(1, 1));
+
+ $this->assertEquals(
+ array(0 => 'Unassigned'),
+ $pp->getMemberList(1)
+ );
+ }
+}