summaryrefslogtreecommitdiff
path: root/tests/ProjectTest.php
diff options
context:
space:
mode:
authorFrédéric Guillot <fred@kanboard.net>2014-06-20 15:41:05 -0300
committerFrédéric Guillot <fred@kanboard.net>2014-06-20 15:41:05 -0300
commit7c5b900bd83b6b9bdb5656eb169381ff46f8106a (patch)
tree39481ff2ee73d7479369655ba86d343f302e1499 /tests/ProjectTest.php
parentefdc959c555872677e599d2ff12e1263d719f3f2 (diff)
First API implementation
Diffstat (limited to 'tests/ProjectTest.php')
-rw-r--r--tests/ProjectTest.php162
1 files changed, 0 insertions, 162 deletions
diff --git a/tests/ProjectTest.php b/tests/ProjectTest.php
deleted file mode 100644
index 5ca8177c..00000000
--- a/tests/ProjectTest.php
+++ /dev/null
@@ -1,162 +0,0 @@
-<?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)
- );
- }
-}