diff options
author | Frédéric Guillot <fred@kanboard.net> | 2014-06-20 15:41:05 -0300 |
---|---|---|
committer | Frédéric Guillot <fred@kanboard.net> | 2014-06-20 15:41:05 -0300 |
commit | 7c5b900bd83b6b9bdb5656eb169381ff46f8106a (patch) | |
tree | 39481ff2ee73d7479369655ba86d343f302e1499 /tests/units/ProjectTest.php | |
parent | efdc959c555872677e599d2ff12e1263d719f3f2 (diff) |
First API implementation
Diffstat (limited to 'tests/units/ProjectTest.php')
-rw-r--r-- | tests/units/ProjectTest.php | 162 |
1 files changed, 162 insertions, 0 deletions
diff --git a/tests/units/ProjectTest.php b/tests/units/ProjectTest.php new file mode 100644 index 00000000..5ca8177c --- /dev/null +++ b/tests/units/ProjectTest.php @@ -0,0 +1,162 @@ +<?php + +require_once __DIR__.'/Base.php'; + +use Model\Project; +use Model\User; +use Model\Task; +use Model\Acl; +use Model\Board; + +class ProjectTest extends Base +{ + public function testCreation() + { + $p = new Project($this->db, $this->event); + + $this->assertEquals(1, $p->create(array('name' => 'UnitTest'))); + $this->assertNotEmpty($p->getById(1)); + } + + public function testAllowEverybody() + { + // We create a regular user + $user = new User($this->db, $this->event); + $user->create(array('username' => 'unittest', 'password' => 'unittest')); + + $p = new Project($this->db, $this->event); + $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->db, $this->event); + $user = new User($this->db, $this->event); + $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->db, $this->event); + + $user = new User($this->db, $this->event); + $user->create(array('username' => 'unittest', 'password' => 'unittest')); + + // We create a project + $this->assertEquals(1, $p->create(array('name' => 'UnitTest'))); + + // We revoke our admin user + $this->assertTrue($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->db, $this->event); + + $user = new User($this->db, $this->event); + $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) + ); + } +} |