summaryrefslogtreecommitdiff
path: root/tests/unit/Security/TAuthManagerTest.php
blob: b61953e5a54927d8321c8b96b2880f39d664d747 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
<?php

use Prado\Exceptions\TConfigurationException;
use Prado\Exceptions\TInvalidOperationException;
use Prado\Security\TAuthManager;
use Prado\Security\TUserManager;
use Prado\TApplication;
use Prado\Xml\TXmlDocument;


/**
 * @package System.Security
 */
class TAuthManagerTest extends PHPUnit_Framework_TestCase {

	public static $app = null;
	public static $usrMgr = null;

	public function setUp() {
		ini_set('session.use_cookies',0);
		ini_set('session.cache_limiter', 'none');
		if(self::$app === null) {
			self::$app = new TApplication(dirname(__FILE__).'/app');
		}

		// Make a fake user manager module
		if (self::$usrMgr === null) {
			self::$usrMgr=new TUserManager ();
			$config=new TXmlDocument('1.0','utf8');
			$config->loadFromString('<users><user name="Joe" password="demo"/><user name="John" password="demo" /><role name="Administrator" users="John" /><role name="Writer" users="Joe,John" /></users>');
			self::$usrMgr->init($config);
			self::$app->setModule('users', self::$usrMgr);
		}
	}

	public function tearDown() {
	}

	public function testInit() {
		$authManager=new TAuthManager ();
		// Catch exception with null usermgr
		try {
			$authManager->init(null);
			self::fail ('Expected TConfigurationException not thrown');
		} catch (TConfigurationException $e) {}

		$authManager->setUserManager('users');
		$authManager->init (null);
		self::assertEquals(self::$usrMgr, $authManager->getUserManager());
	}

	public function testUserManager() {
		$authManager=new TAuthManager ();
		$authManager->setUserManager('users');
		$authManager->init(null);
		self::assertEquals(self::$usrMgr, $authManager->getUserManager());

		// test change
		try {
			$authManager->setUserManager('invalid');
			self::fail ('Expected TInvalidOperationException not thrown');
		} catch (TInvalidOperationException $e) {}

	}

	public function testLoginPage() {
		$authManager=new TAuthManager ();
		$authManager->setUserManager('users');
		$authManager->init(null);
		$authManager->setLoginPage ('LoginPage');
		self::assertEquals('LoginPage', $authManager->getLoginPage());
	}

	public function testDoAuthentication() {
		throw new PHPUnit_Framework_IncompleteTestError();
		// Not yet finished, Session won't start because of headers :( :(

		$authManager=new TAuthManager ();
		$authManager->setUserManager('users');
		$authManager->init(null);
		$authManager->setLoginPage ('LoginPage');
		self::$app->raiseEvent ('onAuthentication', self::$app, null);

	}

	public function testDoAuthorization() {
		throw new PHPUnit_Framework_IncompleteTestError();
	}

	public function testLeave() {
		throw new PHPUnit_Framework_IncompleteTestError();
	}

	public function testReturnUrl() {
		throw new PHPUnit_Framework_IncompleteTestError();
	}

	public function testOnAuthenticate() {
		throw new PHPUnit_Framework_IncompleteTestError();
	}

	public function testOnAuthorize() {
		throw new PHPUnit_Framework_IncompleteTestError();
	}

	public function testUpdateSessionUser() {
		throw new PHPUnit_Framework_IncompleteTestError();
	}

	public function testLogin() {
		throw new PHPUnit_Framework_IncompleteTestError();
	}

	public function testLogout() {
		throw new PHPUnit_Framework_IncompleteTestError();
	}

}