1
0
mirror of https://github.com/chylex/Lightning-Tracker.git synced 2025-01-22 06:46:01 +01:00
Lightning-Tracker/tests/acceptance/T034_UserDeletion_Cest.php

101 lines
3.7 KiB
PHP

<?php
declare(strict_types = 1);
namespace acceptance;
use AcceptanceTester;
use Helper\Acceptance;
class T034_UserDeletion_Cest{
private function startDeletingAs(AcceptanceTester $I, string $editor, string $user): void{
$stmt = Acceptance::getDB()->prepare('SELECT id FROM users WHERE name = ?');
$stmt->execute([$user]);
$id = $stmt->fetchColumn();
$I->assertNotFalse($id);
$I->amLoggedIn($editor);
$I->amOnPage('/users/'.$id.'/delete');
}
private function ensureCanDelete(AcceptanceTester $I, string $editor, string $user): void{
$this->startDeletingAs($I, $editor, $user);
$I->dontSee('Permission Error', 'h2');
}
private function ensureCannotDelete(AcceptanceTester $I, string $editor, string $user): void{
$this->startDeletingAs($I, $editor, $user);
$I->see('Permission Error', 'h2');
}
public function nonExistentUser(AcceptanceTester $I): void{
$I->amLoggedIn('Admin');
$I->amOnPage('/users/000-000-000/delete');
$I->see('User not found');
}
public function adminCanDeleteAllButSelf(AcceptanceTester $I): void{
$this->ensureCannotDelete($I, 'Admin', 'Admin');
$this->ensureCanDelete($I, 'Admin', 'Moderator');
$this->ensureCanDelete($I, 'Admin', 'Manager1');
$this->ensureCanDelete($I, 'Admin', 'Manager2');
$this->ensureCanDelete($I, 'Admin', 'User1');
$this->ensureCanDelete($I, 'Admin', 'RoleLess');
}
public function moderatorCanOnlyDeleteLowerRoles(AcceptanceTester $I): void{
$this->ensureCannotDelete($I, 'Moderator', 'Admin');
$this->ensureCannotDelete($I, 'Moderator', 'Moderator');
$this->ensureCanDelete($I, 'Moderator', 'Manager1');
$this->ensureCanDelete($I, 'Moderator', 'Manager2');
$this->ensureCanDelete($I, 'Moderator', 'User1');
$this->ensureCanDelete($I, 'Moderator', 'RoleLess');
}
public function manager1CanOnlyDeleteLowerRoles(AcceptanceTester $I): void{
$this->ensureCannotDelete($I, 'Manager1', 'Admin');
$this->ensureCannotDelete($I, 'Manager1', 'Moderator');
$this->ensureCannotDelete($I, 'Manager1', 'Manager1');
$this->ensureCanDelete($I, 'Manager1', 'Manager2');
$this->ensureCanDelete($I, 'Manager1', 'User1');
$this->ensureCanDelete($I, 'Manager1', 'RoleLess');
}
public function manager2CanOnlyDeleteLowerRoles(AcceptanceTester $I): void{
$this->ensureCannotDelete($I, 'Manager2', 'Admin');
$this->ensureCannotDelete($I, 'Manager2', 'Moderator');
$this->ensureCannotDelete($I, 'Manager2', 'Manager1');
$this->ensureCannotDelete($I, 'Manager2', 'Manager2');
$this->ensureCanDelete($I, 'Manager2', 'User1');
$this->ensureCanDelete($I, 'Manager2', 'RoleLess');
}
public function confirmationDoesNotMatch(AcceptanceTester $I): void{
$this->startDeletingAs($I, 'Admin', 'RoleLess');
$I->fillField('Name', 'NotRoleLess');
$I->click('button[type="submit"]');
$I->seeElement('input[name="Name"] + .error');
}
public function confirmationIsCaseSensitive(AcceptanceTester $I): void{
$this->startDeletingAs($I, 'Admin', 'RoleLess');
$I->fillField('Name', 'RoleLesS');
$I->click('button[type="submit"]');
$I->seeElement('input[name="Name"] + .error');
}
public function deleteTestUser(AcceptanceTester $I): void{
Acceptance::getDB()->exec('INSERT INTO users (id, name, email, password, role_id, date_registered) VALUES (\'aaabbbccc\', \'Test\', \'test@example.com\', \'\', NULL, NOW())');
$I->seeInDatabase('users', ['name' => 'Test']);
$this->startDeletingAs($I, 'Admin', 'Test');
$I->fillField('Name', 'Test');
$I->click('button[type="submit"]');
$I->seeCurrentUrlEquals('/users');
$I->dontSeeInDatabase('users', ['name' => 'Test']);
}
}
?>