AppUsersTest.php 2.01 KB
Newer Older
Scott committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14
<?php
require_once QA_INCLUDE_DIR.'app/users.php';
require_once QA_INCLUDE_DIR.'app/options.php';

class AppUsersTest extends PHPUnit_Framework_TestCase
{
	/**
	 * Test logic of permissions function.
	 * User level values: QA_USER_LEVEL_* in app/users.php [BASIC..SUPER]
	 * Permission values: QA_PERMIT_* in app/options.php [ALL..SUPERS]
	 * User flag values: QA_USER_FLAGS_* in app/users.php
	 */
	public function test__qa_permit_value_error()
	{
Scott committed
15 16 17 18 19
		// set options cache to bypass database
		global $qa_options_cache;
		$qa_options_cache['confirm_user_emails'] = '1';
		$qa_options_cache['moderate_users'] = '0';

Scott committed
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
		$userFlags = QA_USER_FLAGS_EMAIL_CONFIRMED;
		$blockedFlags = QA_USER_FLAGS_EMAIL_CONFIRMED | QA_USER_FLAGS_USER_BLOCKED;

		// Admin trying to do Super stuff
		$error = qa_permit_value_error(QA_PERMIT_SUPERS, 1, QA_USER_LEVEL_ADMIN, $userFlags);
		$this->assertSame('level', $error);

		// Admin trying to do Admin stuff
		$error = qa_permit_value_error(QA_PERMIT_ADMINS, 1, QA_USER_LEVEL_ADMIN, $userFlags);
		$this->assertSame(false, $error);

		// Admin trying to do Editor stuff
		$error = qa_permit_value_error(QA_PERMIT_EDITORS, 1, QA_USER_LEVEL_ADMIN, $userFlags);
		$this->assertSame(false, $error);

		// Expert trying to do Moderator stuff
		$error = qa_permit_value_error(QA_PERMIT_MODERATORS, 1, QA_USER_LEVEL_EXPERT, $userFlags);
		$this->assertSame('level', $error);

		// Unconfirmed User trying to do Confirmed stuff
		$error = qa_permit_value_error(QA_PERMIT_CONFIRMED, 1, QA_USER_LEVEL_BASIC, 0);
		$this->assertSame('confirm', $error);

		// Blocked User trying to do anything
		$error = qa_permit_value_error(QA_PERMIT_ALL, 1, QA_USER_LEVEL_BASIC, $blockedFlags);
		$this->assertSame('userblock', $error);

		// Logged Out User trying to do User stuff
		$error = qa_permit_value_error(QA_PERMIT_USERS, null, null, 0);
		$this->assertSame('login', $error);

		// Logged Out User trying to do Moderator stuff
		$error = qa_permit_value_error(QA_PERMIT_MODERATORS, null, null, 0);
		$this->assertSame('level', $error);

	}
}