First API implementation
This commit is contained in:
112
tests/units/AclTest.php
Normal file
112
tests/units/AclTest.php
Normal file
@@ -0,0 +1,112 @@
|
||||
<?php
|
||||
|
||||
require_once __DIR__.'/Base.php';
|
||||
|
||||
use Model\Acl;
|
||||
|
||||
class AclTest extends Base
|
||||
{
|
||||
public function testAllowedAction()
|
||||
{
|
||||
$acl_rules = array(
|
||||
'controller1' => array('action1', 'action3'),
|
||||
);
|
||||
|
||||
$acl = new Acl($this->db, $this->event);
|
||||
$this->assertTrue($acl->isAllowedAction($acl_rules, 'controller1', 'action1'));
|
||||
$this->assertTrue($acl->isAllowedAction($acl_rules, 'controller1', 'action3'));
|
||||
$this->assertFalse($acl->isAllowedAction($acl_rules, 'controller1', 'action2'));
|
||||
$this->assertFalse($acl->isAllowedAction($acl_rules, 'controller2', 'action2'));
|
||||
$this->assertFalse($acl->isAllowedAction($acl_rules, 'controller2', 'action3'));
|
||||
}
|
||||
|
||||
public function testIsAdmin()
|
||||
{
|
||||
$acl = new Acl($this->db, $this->event);
|
||||
|
||||
$_SESSION = array();
|
||||
$this->assertFalse($acl->isAdminUser());
|
||||
|
||||
$_SESSION = array('user' => array());
|
||||
$this->assertFalse($acl->isAdminUser());
|
||||
|
||||
$_SESSION = array('user' => array('is_admin' => '1'));
|
||||
$this->assertFalse($acl->isAdminUser());
|
||||
|
||||
$_SESSION = array('user' => array('is_admin' => false));
|
||||
$this->assertFalse($acl->isAdminUser());
|
||||
|
||||
$_SESSION = array('user' => array('is_admin' => '2'));
|
||||
$this->assertFalse($acl->isAdminUser());
|
||||
|
||||
$_SESSION = array('user' => array('is_admin' => true));
|
||||
$this->assertTrue($acl->isAdminUser());
|
||||
}
|
||||
|
||||
public function testIsUser()
|
||||
{
|
||||
$acl = new Acl($this->db, $this->event);
|
||||
|
||||
$_SESSION = array();
|
||||
$this->assertFalse($acl->isRegularUser());
|
||||
|
||||
$_SESSION = array('user' => array());
|
||||
$this->assertFalse($acl->isRegularUser());
|
||||
|
||||
$_SESSION = array('user' => array('is_admin' => true));
|
||||
$this->assertFalse($acl->isRegularUser());
|
||||
|
||||
$_SESSION = array('user' => array('is_admin' => true));
|
||||
$this->assertFalse($acl->isRegularUser());
|
||||
|
||||
$_SESSION = array('user' => array('is_admin' => '2'));
|
||||
$this->assertFalse($acl->isRegularUser());
|
||||
|
||||
$_SESSION = array('user' => array('is_admin' => false));
|
||||
$this->assertTrue($acl->isRegularUser());
|
||||
}
|
||||
|
||||
public function testIsPageAllowed()
|
||||
{
|
||||
$acl = new Acl($this->db, $this->event);
|
||||
|
||||
// Public access
|
||||
$_SESSION = array();
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'create'));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'save'));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'remove'));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'confirm'));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('app', 'index'));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'index'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'login'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'check'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('task', 'add'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('board', 'readonly'));
|
||||
|
||||
// Regular user
|
||||
$_SESSION = array('user' => array('is_admin' => false));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'create'));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'save'));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'remove'));
|
||||
$this->assertFalse($acl->isPageAccessAllowed('user', 'confirm'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('app', 'index'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'index'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'login'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'check'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('task', 'add'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('board', 'readonly'));
|
||||
|
||||
// Admin user
|
||||
$_SESSION = array('user' => array('is_admin' => true));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'create'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'save'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'remove'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'confirm'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('app', 'index'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'index'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'login'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('user', 'check'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('task', 'add'));
|
||||
$this->assertTrue($acl->isPageAccessAllowed('board', 'readonly'));
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user