mirror of
https://github.com/chylex/Lightning-Tracker.git
synced 2025-01-22 06:46:01 +01:00
172 lines
7.0 KiB
PHP
172 lines
7.0 KiB
PHP
<?php
|
|
declare(strict_types = 1);
|
|
|
|
namespace acceptance;
|
|
|
|
use AcceptanceTester;
|
|
use Helper\Acceptance;
|
|
|
|
class T124_MemberRemoval_Cest{
|
|
private array $members;
|
|
|
|
public function _before(AcceptanceTester $I): void{
|
|
if (!isset($this->members)){
|
|
$this->members = Acceptance::getDB()->query('SELECT * FROM project_members WHERE project_id = '.Acceptance::getProjectId($I, 'p1'))->fetchAll();
|
|
}
|
|
}
|
|
|
|
private function restoreMembers(): void{
|
|
$db = Acceptance::getDB();
|
|
|
|
foreach($this->members as $member){
|
|
$db->prepare('INSERT INTO project_members (project_id, user_id, role_id) VALUES (?, ?, ?) ON DUPLICATE KEY UPDATE role_id = VALUES(role_id)')
|
|
->execute([$member['project_id'], $member['user_id'], $member['role_id']]);
|
|
}
|
|
}
|
|
|
|
private function startRemovingAs(AcceptanceTester $I, string $editor, string $user): string{
|
|
$stmt = Acceptance::getDB()->prepare('SELECT id FROM users WHERE name = ?');
|
|
$stmt->execute([$user]);
|
|
|
|
$id = $stmt->fetchColumn();
|
|
$I->assertNotFalse($id);
|
|
|
|
$I->amLoggedIn($editor);
|
|
$I->amOnPage('/project/p1/members/'.$id.'/remove');
|
|
|
|
return $id;
|
|
}
|
|
|
|
private function ensureCanRemoveWithoutConfirmation(AcceptanceTester $I, string $editor, string $user): void{
|
|
$this->startRemovingAs($I, $editor, $user);
|
|
$I->dontSee('Permission Error', 'h2');
|
|
$I->seeCurrentUrlEquals('/project/p1/members');
|
|
}
|
|
|
|
private function ensureCanRemoveWithConfirmation(AcceptanceTester $I, string $editor, string $user): void{
|
|
$id = $this->startRemovingAs($I, $editor, $user);
|
|
$I->dontSee('Permission Error', 'h2');
|
|
$I->seeCurrentUrlEquals('/project/p1/members/'.$id.'/remove');
|
|
}
|
|
|
|
private function ensureCannotRemove(AcceptanceTester $I, string $editor, string $user): void{
|
|
$this->startRemovingAs($I, $editor, $user);
|
|
$I->see('Permission Error', 'h2');
|
|
}
|
|
|
|
private function removeRoleLessWithConfirmation(AcceptanceTester $I, string $reassign): string{
|
|
$id = $this->startRemovingAs($I, 'User1', 'RoleLess');
|
|
$I->see('1 issue assigned');
|
|
$I->selectOption('Reassign', $reassign);
|
|
$I->click('button[type="submit"]');
|
|
|
|
$I->seeTableRowOrder(['User1',
|
|
'Manager1',
|
|
'Manager2',
|
|
'User2',
|
|
'User3']);
|
|
|
|
return $id;
|
|
}
|
|
|
|
private function restoreRoleLessIssueAssignment(string $id): void{
|
|
Acceptance::getDB()->prepare('UPDATE issues SET assignee_id = ? WHERE title = \'Assigned Test Issue 8 (Feature)\' AND author_id = \'user1test\'')->execute([$id]);
|
|
}
|
|
|
|
public function nonExistentUser(AcceptanceTester $I): void{
|
|
$I->amLoggedIn('User1');
|
|
$I->amOnPage('/project/p1/members/000-000-000/remove');
|
|
$I->see('Member not found');
|
|
}
|
|
|
|
public function nonExistentMember(AcceptanceTester $I): void{
|
|
$this->startRemovingAs($I, 'User1', 'Admin');
|
|
$I->see('Member not found');
|
|
}
|
|
|
|
public function trackerAdminCanRemoveAllButOwnerRoleDespiteNotBeingAMember(AcceptanceTester $I): void{
|
|
$this->ensureCannotRemove($I, 'Admin', 'User1');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Admin', 'Manager1');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Admin', 'Manager2');
|
|
$this->ensureCanRemoveWithoutConfirmation($I, 'Admin', 'User2');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Admin', 'RoleLess');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Admin', 'User3');
|
|
$this->restoreMembers();
|
|
}
|
|
|
|
public function trackerModeratorCanRemoveAllButOwnerRoleDespiteNotBeingAMember(AcceptanceTester $I): void{
|
|
$this->ensureCannotRemove($I, 'Moderator', 'User1');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Moderator', 'Manager1');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Moderator', 'Manager2');
|
|
$this->ensureCanRemoveWithoutConfirmation($I, 'Moderator', 'User2');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Moderator', 'RoleLess');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Moderator', 'User3');
|
|
$this->restoreMembers();
|
|
}
|
|
|
|
public function ownerCanRemoveAllButSelf(AcceptanceTester $I): void{
|
|
$this->ensureCannotRemove($I, 'User1', 'User1');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'User1', 'Manager1');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'User1', 'Manager2');
|
|
$this->ensureCanRemoveWithoutConfirmation($I, 'User1', 'User2');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'User1', 'RoleLess');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'User1', 'User3');
|
|
$this->restoreMembers();
|
|
}
|
|
|
|
public function memberWithAdministratorRoleCanOnlyRemoveLowerRoles(AcceptanceTester $I): void{
|
|
$this->ensureCannotRemove($I, 'Manager1', 'User1');
|
|
$this->ensureCannotRemove($I, 'Manager1', 'Manager1');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Manager1', 'Manager2');
|
|
$this->ensureCanRemoveWithoutConfirmation($I, 'Manager1', 'User2');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Manager1', 'RoleLess');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Manager1', 'User3');
|
|
$this->restoreMembers();
|
|
}
|
|
|
|
public function memberWithModeratorRoleCanOnlyRemoveLowerRoles(AcceptanceTester $I): void{
|
|
$this->ensureCannotRemove($I, 'Manager2', 'User1');
|
|
$this->ensureCannotRemove($I, 'Manager2', 'Manager1');
|
|
$this->ensureCannotRemove($I, 'Manager2', 'Manager2');
|
|
$this->ensureCanRemoveWithoutConfirmation($I, 'Manager2', 'User2');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Manager2', 'RoleLess');
|
|
$this->ensureCanRemoveWithConfirmation($I, 'Manager2', 'User3');
|
|
$this->restoreMembers();
|
|
}
|
|
|
|
public function removeWithoutConfirmation(AcceptanceTester $I): void{
|
|
$this->startRemovingAs($I, 'User1', 'User2');
|
|
$I->seeCurrentUrlEquals('/project/p1/members');
|
|
|
|
$I->seeTableRowOrder(['User1',
|
|
'Manager1',
|
|
'Manager2',
|
|
'RoleLess',
|
|
'User3']);
|
|
|
|
$this->restoreMembers();
|
|
}
|
|
|
|
public function removeWithConfirmationKeepingAssignment(AcceptanceTester $I): void{
|
|
$id = $this->removeRoleLessWithConfirmation($I, '(Do Not Reassign)');
|
|
$I->seeInDatabase('issues', ['title' => 'Assigned Test Issue 8 (Feature)', 'author_id' => 'user1test', 'assignee_id' => $id]);
|
|
$this->restoreMembers();
|
|
}
|
|
|
|
public function removeWithConfirmationReassigningToNobody(AcceptanceTester $I): void{
|
|
$id = $this->removeRoleLessWithConfirmation($I, '(Reassign To Nobody)');
|
|
$I->seeInDatabase('issues', ['title' => 'Assigned Test Issue 8 (Feature)', 'author_id' => 'user1test', 'assignee_id' => null]);
|
|
$this->restoreMembers();
|
|
$this->restoreRoleLessIssueAssignment($id);
|
|
}
|
|
|
|
public function removeWithConfirmationReassigningToUser2(AcceptanceTester $I): void{
|
|
$id = $this->removeRoleLessWithConfirmation($I, 'User2');
|
|
$I->seeInDatabase('issues', ['title' => 'Assigned Test Issue 8 (Feature)', 'author_id' => 'user1test', 'assignee_id' => 'user2test']);
|
|
$this->restoreMembers();
|
|
$this->restoreRoleLessIssueAssignment($id);
|
|
}
|
|
}
|
|
|
|
?>
|