2017-03-29 23:41:05 -04:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
2017-03-31 13:24:00 -04:00
|
|
|
namespace JKingWeb\Arsse\Test\Database;
|
|
|
|
use JKingWeb\Arsse\Data;
|
|
|
|
use JKingWeb\Arsse\User\Driver as UserDriver;
|
2017-03-29 23:41:05 -04:00
|
|
|
use Phake;
|
|
|
|
|
2017-03-31 13:24:00 -04:00
|
|
|
trait SeriesUser {
|
2017-03-29 23:41:05 -04:00
|
|
|
function setUpSeries() {
|
|
|
|
$this->primeDatabase($this->data);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testCheckThatAUserExists() {
|
|
|
|
$this->assertTrue(Data::$db->userExists("jane.doe@example.com"));
|
|
|
|
$this->assertFalse(Data::$db->userExists("jane.doe@example.org"));
|
|
|
|
Phake::verify(Data::$user)->authorize("jane.doe@example.com", "userExists");
|
|
|
|
Phake::verify(Data::$user)->authorize("jane.doe@example.org", "userExists");
|
|
|
|
$this->compareExpectations($this->data);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testCheckThatAUserExistsWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userExists("jane.doe@example.com");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testGetAPassword() {
|
|
|
|
$hash = Data::$db->userPasswordGet("admin@example.net");
|
|
|
|
$this->assertSame('$2y$10$PbcG2ZR3Z8TuPzM7aHTF8.v61dtCjzjK78gdZJcp4UePE8T9jEgBW', $hash);
|
|
|
|
Phake::verify(Data::$user)->authorize("admin@example.net", "userPasswordGet");
|
|
|
|
$this->assertTrue(password_verify("secret", $hash));
|
|
|
|
}
|
|
|
|
|
|
|
|
function testGetAPasswordWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userPasswordGet("admin@example.net");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testAddANewUser() {
|
|
|
|
$this->assertSame("", Data::$db->userAdd("john.doe@example.org", ""));
|
|
|
|
Phake::verify(Data::$user)->authorize("john.doe@example.org", "userAdd");
|
|
|
|
$state = $this->primeExpectations($this->data, ['arsse_users' => ['id','name','rights']]);
|
2017-03-31 13:24:00 -04:00
|
|
|
$state['arsse_users']['rows'][] = ["john.doe@example.org", null, UserDriver::RIGHTS_NONE];
|
2017-03-29 23:41:05 -04:00
|
|
|
$this->compareExpectations($state);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testGetAPassword
|
|
|
|
* @depends testAddANewUser
|
|
|
|
*/
|
|
|
|
function testAddANewUserWithARandomPassword() {
|
|
|
|
$user1 = "john.doe@example.org";
|
|
|
|
$user2 = "john.doe@example.net";
|
|
|
|
$pass1 = Data::$db->userAdd($user1);
|
|
|
|
$pass2 = Data::$db->userAdd($user2);
|
|
|
|
$this->assertSame(Data::$conf->userTempPasswordLength, strlen($pass1));
|
|
|
|
$this->assertSame(Data::$conf->userTempPasswordLength, strlen($pass2));
|
|
|
|
$this->assertNotEquals($pass1, $pass2);
|
|
|
|
$hash1 = Data::$db->userPasswordGet($user1);
|
|
|
|
$hash2 = Data::$db->userPasswordGet($user2);
|
|
|
|
Phake::verify(Data::$user)->authorize($user1, "userAdd");
|
|
|
|
Phake::verify(Data::$user)->authorize($user2, "userAdd");
|
|
|
|
Phake::verify(Data::$user)->authorize($user1, "userPasswordGet");
|
|
|
|
Phake::verify(Data::$user)->authorize($user2, "userPasswordGet");
|
|
|
|
$this->assertTrue(password_verify($pass1, $hash1), "Failed verifying password of $user1 '$pass1' against hash '$hash1'.");
|
|
|
|
$this->assertTrue(password_verify($pass2, $hash2), "Failed verifying password of $user2 '$pass2' against hash '$hash2'.");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testAddAnExistingUser() {
|
|
|
|
$this->assertException("alreadyExists", "User");
|
|
|
|
Data::$db->userAdd("john.doe@example.com", "");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testAddANewUserWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userAdd("john.doe@example.org", "");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testRemoveAUser() {
|
|
|
|
$this->assertTrue(Data::$db->userRemove("admin@example.net"));
|
|
|
|
Phake::verify(Data::$user)->authorize("admin@example.net", "userRemove");
|
|
|
|
$state = $this->primeExpectations($this->data, ['arsse_users' => ['id']]);
|
|
|
|
array_shift($state['arsse_users']['rows']);
|
|
|
|
$this->compareExpectations($state);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testRemoveAMissingUser() {
|
|
|
|
$this->assertException("doesNotExist", "User");
|
|
|
|
Data::$db->userRemove("john.doe@example.org");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testRemoveAUserWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userRemove("admin@example.net");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testListAllUsers() {
|
|
|
|
$users = ["admin@example.net", "jane.doe@example.com", "john.doe@example.com"];
|
|
|
|
$this->assertSame($users, Data::$db->userList());
|
|
|
|
Phake::verify(Data::$user)->authorize("", "userList");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testListUsersOnADomain() {
|
|
|
|
$users = ["jane.doe@example.com", "john.doe@example.com"];
|
|
|
|
$this->assertSame($users, Data::$db->userList("example.com"));
|
|
|
|
Phake::verify(Data::$user)->authorize("@example.com", "userList");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testListAllUsersWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userList();
|
|
|
|
}
|
|
|
|
|
|
|
|
function testListUsersOnADomainWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userList("example.com");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testGetAPassword
|
|
|
|
*/
|
|
|
|
function testSetAPassword() {
|
|
|
|
$user = "john.doe@example.com";
|
|
|
|
$this->assertEquals("", Data::$db->userPasswordGet($user));
|
|
|
|
$pass = Data::$db->userPasswordSet($user, "secret");
|
|
|
|
$hash = Data::$db->userPasswordGet($user);
|
|
|
|
$this->assertNotEquals("", $hash);
|
|
|
|
Phake::verify(Data::$user)->authorize($user, "userPasswordSet");
|
|
|
|
$this->assertTrue(password_verify($pass, $hash), "Failed verifying password of $user '$pass' against hash '$hash'.");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testSetThePasswordOfAMissingUser() {
|
|
|
|
$this->assertException("doesNotExist", "User");
|
|
|
|
Data::$db->userPasswordSet("john.doe@example.org", "secret");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testSetAPasswordWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userPasswordSet("john.doe@example.com", "secret");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testGetUserProperties() {
|
|
|
|
$exp = [
|
|
|
|
'name' => 'Hard Lip Herbert',
|
2017-03-31 13:24:00 -04:00
|
|
|
'rights' => UserDriver::RIGHTS_GLOBAL_ADMIN,
|
2017-03-29 23:41:05 -04:00
|
|
|
];
|
|
|
|
$props = Data::$db->userPropertiesGet("admin@example.net");
|
|
|
|
Phake::verify(Data::$user)->authorize("admin@example.net", "userPropertiesGet");
|
|
|
|
$this->assertArraySubset($exp, $props);
|
|
|
|
$this->assertArrayNotHasKey("password", $props);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testGetThePropertiesOfAMissingUser() {
|
|
|
|
$this->assertException("doesNotExist", "User");
|
|
|
|
Data::$db->userPropertiesGet("john.doe@example.org");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testGetUserPropertiesWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userPropertiesGet("john.doe@example.com");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testSetUserProperties() {
|
|
|
|
$try = [
|
|
|
|
'name' => 'James Kirk', // only this should actually change
|
|
|
|
'password' => '000destruct0',
|
2017-03-31 13:24:00 -04:00
|
|
|
'rights' => UserDriver::RIGHTS_NONE,
|
2017-03-29 23:41:05 -04:00
|
|
|
'lifeform' => 'tribble',
|
|
|
|
];
|
|
|
|
$exp = [
|
|
|
|
'name' => 'James Kirk',
|
2017-03-31 13:24:00 -04:00
|
|
|
'rights' => UserDriver::RIGHTS_GLOBAL_ADMIN,
|
2017-03-29 23:41:05 -04:00
|
|
|
];
|
|
|
|
$props = Data::$db->userPropertiesSet("admin@example.net", $try);
|
|
|
|
Phake::verify(Data::$user)->authorize("admin@example.net", "userPropertiesSet");
|
|
|
|
$this->assertArraySubset($exp, $props);
|
|
|
|
$this->assertArrayNotHasKey("password", $props);
|
|
|
|
$state = $this->primeExpectations($this->data, ['arsse_users' => ['id','password','name','rights']]);
|
|
|
|
$state['arsse_users']['rows'][0][2] = "James Kirk";
|
|
|
|
$this->compareExpectations($state);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testSetThePropertiesOfAMissingUser() {
|
|
|
|
$try = ['name' => 'John Doe'];
|
|
|
|
$this->assertException("doesNotExist", "User");
|
|
|
|
Data::$db->userPropertiesSet("john.doe@example.org", $try);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testSetUserPropertiesWithoutAuthority() {
|
|
|
|
$try = ['name' => 'John Doe'];
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userPropertiesSet("john.doe@example.com", $try);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testGetUserRights() {
|
|
|
|
$user1 = "john.doe@example.com";
|
|
|
|
$user2 = "admin@example.net";
|
2017-03-31 13:24:00 -04:00
|
|
|
$this->assertSame(UserDriver::RIGHTS_NONE, Data::$db->userRightsGet($user1));
|
|
|
|
$this->assertSame(UserDriver::RIGHTS_GLOBAL_ADMIN, Data::$db->userRightsGet($user2));
|
2017-03-29 23:41:05 -04:00
|
|
|
Phake::verify(Data::$user)->authorize($user1, "userRightsGet");
|
|
|
|
Phake::verify(Data::$user)->authorize($user2, "userRightsGet");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testGetTheRightsOfAMissingUser() {
|
2017-03-31 13:24:00 -04:00
|
|
|
$this->assertSame(UserDriver::RIGHTS_NONE, Data::$db->userRightsGet("john.doe@example.org"));
|
2017-03-29 23:41:05 -04:00
|
|
|
Phake::verify(Data::$user)->authorize("john.doe@example.org", "userRightsGet");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testGetUserRightsWithoutAuthority() {
|
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userRightsGet("john.doe@example.com");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testSetUserRights() {
|
|
|
|
$user = "john.doe@example.com";
|
2017-03-31 13:24:00 -04:00
|
|
|
$rights = UserDriver::RIGHTS_GLOBAL_ADMIN;
|
2017-03-29 23:41:05 -04:00
|
|
|
$this->assertTrue(Data::$db->userRightsSet($user, $rights));
|
|
|
|
Phake::verify(Data::$user)->authorize($user, "userRightsSet", $rights);
|
|
|
|
$state = $this->primeExpectations($this->data, ['arsse_users' => ['id','rights']]);
|
|
|
|
$state['arsse_users']['rows'][2][1] = $rights;
|
|
|
|
$this->compareExpectations($state);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testSetTheRightsOfAMissingUser() {
|
2017-03-31 13:24:00 -04:00
|
|
|
$rights = UserDriver::RIGHTS_GLOBAL_ADMIN;
|
2017-03-29 23:41:05 -04:00
|
|
|
$this->assertException("doesNotExist", "User");
|
|
|
|
Data::$db->userRightsSet("john.doe@example.org", $rights);
|
|
|
|
}
|
|
|
|
|
|
|
|
function testSetUserRightsWithoutAuthority() {
|
2017-03-31 13:24:00 -04:00
|
|
|
$rights = UserDriver::RIGHTS_GLOBAL_ADMIN;
|
2017-03-29 23:41:05 -04:00
|
|
|
Phake::when(Data::$user)->authorize->thenReturn(false);
|
|
|
|
$this->assertException("notAuthorized", "User", "ExceptionAuthz");
|
|
|
|
Data::$db->userRightsSet("john.doe@example.com", $rights);
|
|
|
|
}
|
|
|
|
}
|