From e7a20b9d8f8d7c47173c59782c5bd24a0ba6cac9 Mon Sep 17 00:00:00 2001
From: Frédéric Guillot <fred@kanboard.net>
Date: Tue, 16 Sep 2014 19:30:18 +0200
Subject: Improve API calls for users

---
 tests/units/UserTest.php | 82 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 82 insertions(+)
 create mode 100644 tests/units/UserTest.php

(limited to 'tests/units/UserTest.php')

diff --git a/tests/units/UserTest.php b/tests/units/UserTest.php
new file mode 100644
index 00000000..cc0b7c44
--- /dev/null
+++ b/tests/units/UserTest.php
@@ -0,0 +1,82 @@
+<?php
+
+require_once __DIR__.'/Base.php';
+
+use Model\User;
+use Model\Task;
+use Model\Project;
+
+class UserTest extends Base
+{
+    public function testCreate()
+    {
+        $u = new User($this->registry);
+        $this->assertTrue($u->create(array('username' => 'toto', 'password' => '123456', 'name' => 'Toto')));
+        $this->assertTrue($u->create(array('username' => 'titi', 'is_ldap_user' => 1)));
+        $this->assertFalse($u->create(array('username' => 'toto')));
+
+        $user = $u->getById(1);
+        $this->assertNotFalse($user);
+        $this->assertTrue(is_array($user));
+        $this->assertEquals('admin', $user['username']);
+        $this->assertEquals('', $user['name']);
+        $this->assertEquals(1, $user['is_admin']);
+        $this->assertEquals(0, $user['is_ldap_user']);
+
+        $user = $u->getById(2);
+        $this->assertNotFalse($user);
+        $this->assertTrue(is_array($user));
+        $this->assertEquals('toto', $user['username']);
+        $this->assertEquals('Toto', $user['name']);
+        $this->assertEquals(0, $user['is_admin']);
+        $this->assertEquals(0, $user['is_ldap_user']);
+
+        $user = $u->getById(3);
+        $this->assertNotFalse($user);
+        $this->assertTrue(is_array($user));
+        $this->assertEquals('titi', $user['username']);
+        $this->assertEquals('', $user['name']);
+        $this->assertEquals(0, $user['is_admin']);
+        $this->assertEquals(1, $user['is_ldap_user']);
+    }
+
+    public function testUpdate()
+    {
+        $u = new User($this->registry);
+        $this->assertTrue($u->create(array('username' => 'toto', 'password' => '123456', 'name' => 'Toto')));
+        $this->assertTrue($u->update(array('id' => 2, 'username' => 'biloute')));
+
+        $user = $u->getById(2);
+        $this->assertNotFalse($user);
+        $this->assertTrue(is_array($user));
+        $this->assertEquals('biloute', $user['username']);
+        $this->assertEquals('Toto', $user['name']);
+        $this->assertEquals(0, $user['is_admin']);
+        $this->assertEquals(0, $user['is_ldap_user']);
+    }
+
+    public function testRemove()
+    {
+        $u = new User($this->registry);
+        $t = new Task($this->registry);
+        $p = new Project($this->registry);
+
+        $this->assertTrue($u->create(array('username' => 'toto', 'password' => '123456', 'name' => 'Toto')));
+        $this->assertEquals(1, $p->create(array('name' => 'Project #1')));
+        $this->assertEquals(1, $t->create(array('title' => 'Task #1', 'project_id' => 1, 'owner_id' => 2)));
+
+        $task = $t->getById(1);
+        $this->assertEquals(1, $task['id']);
+        $this->assertEquals(2, $task['owner_id']);
+
+        $this->assertTrue($u->remove(1));
+        $this->assertTrue($u->remove(2));
+        $this->assertFalse($u->remove(2));
+        $this->assertFalse($u->remove(55));
+
+        // Make sure that assigned tasks are unassigned after removing the user
+        $task = $t->getById(1);
+        $this->assertEquals(1, $task['id']);
+        $this->assertEquals(0, $task['owner_id']);
+    }
+}
-- 
cgit v1.2.3