mirror of
https://github.com/chylex/Lightning-Tracker.git
synced 2024-11-24 22:42:50 +01:00
138 lines
3.7 KiB
PHP
138 lines
3.7 KiB
PHP
<?php
|
|
declare(strict_types = 1);
|
|
|
|
namespace Helper;
|
|
|
|
// here you can define custom actions
|
|
// all public methods declared in helper class will be available in $I
|
|
|
|
use AcceptanceTester;
|
|
use Codeception\Module;
|
|
use Database\DB;
|
|
use FilesystemIterator;
|
|
use PDO;
|
|
use RecursiveDirectoryIterator;
|
|
use RecursiveIteratorIterator;
|
|
|
|
class Acceptance extends Module{
|
|
private static PDO $db;
|
|
|
|
public static function getDB(): PDO{
|
|
if (isset(self::$db)){
|
|
return self::$db;
|
|
}
|
|
|
|
define('DB_DRIVER', 'mysql');
|
|
define('DB_NAME', 'tracker_test');
|
|
define('DB_HOST', 'localhost');
|
|
define('DB_USER', 'lt');
|
|
define('DB_PASSWORD', 'test');
|
|
|
|
require __DIR__.'/../../../src/Database/DB.php';
|
|
return self::$db = DB::get();
|
|
}
|
|
|
|
public static function isInGroup(string $group): bool{
|
|
$argv = $_SERVER['argv'];
|
|
$k = array_search('-g', $argv, true);
|
|
|
|
if ($k === false){
|
|
array_search('--group', $argv, true);
|
|
}
|
|
|
|
return $k !== false && $argv[$k + 1] === $group;
|
|
}
|
|
|
|
public static function getProjectId(AcceptanceTester $I, string $url): int{
|
|
$stmt = self::getDB()->prepare('SELECT id FROM projects WHERE url = ?');
|
|
$stmt->execute([$url]);
|
|
|
|
$id = $stmt->fetchColumn();
|
|
$I->assertNotFalse($id);
|
|
$I->assertIsNumeric($id);
|
|
|
|
return (int)$id;
|
|
}
|
|
|
|
public static function getIssueId(AcceptanceTester $I, string $project, string $title): int{
|
|
$stmt = self::getDB()->prepare('SELECT issue_id FROM issues WHERE title = ? AND project_id = (SELECT p.id FROM projects p WHERE p.url = ?)');
|
|
$stmt->execute([$title, $project]);
|
|
|
|
$id = $stmt->fetchColumn();
|
|
$I->assertNotFalse($id);
|
|
$I->assertIsNumeric($id);
|
|
|
|
return (int)$id;
|
|
}
|
|
|
|
public static function assignUser3Role(string $project, ?string $role): void{
|
|
$db = self::getDB();
|
|
|
|
if ($role === null){
|
|
$db->exec(<<<SQL
|
|
UPDATE project_members
|
|
SET role_id = NULL
|
|
WHERE user_id = 'user3test' AND project_id = (SELECT p.id FROM projects p WHERE p.url = '$project')
|
|
SQL
|
|
);
|
|
}
|
|
else{
|
|
$db->exec(<<<SQL
|
|
UPDATE project_members
|
|
SET role_id = (SELECT pr.role_id FROM project_roles pr WHERE pr.title = '$role' AND pr.project_id = (SELECT p.id FROM projects p WHERE p.url = '$project'))
|
|
WHERE user_id = 'user3test' AND project_id = (SELECT p.id FROM projects p WHERE p.url = '$project')
|
|
SQL
|
|
);
|
|
}
|
|
}
|
|
|
|
public function _beforeSuite($settings = []): void{
|
|
$db = self::getDB();
|
|
|
|
$tables = [
|
|
'system_roles',
|
|
'system_role_permissions',
|
|
'users',
|
|
'user_logins',
|
|
'projects',
|
|
'project_roles',
|
|
'project_role_permissions',
|
|
'project_members',
|
|
'milestones',
|
|
'issue_weights',
|
|
'issues',
|
|
'project_user_settings',
|
|
];
|
|
|
|
foreach(array_reverse($tables) as $file => $table){
|
|
$db->exec('DROP TABLE IF EXISTS '.$table);
|
|
}
|
|
}
|
|
|
|
public function _afterSuite(): void{
|
|
$dir_backup = __DIR__.'/../../../server/www-backup';
|
|
$dir_www = __DIR__.'/../../../server/www';
|
|
$dir_tmp = $dir_www.'-tmp';
|
|
$dir_c3 = $dir_www.'/tests/_output/c3tmp';
|
|
|
|
if (is_dir($dir_backup) && !is_dir($dir_c3)){
|
|
$delete = new RecursiveDirectoryIterator($dir_www, FilesystemIterator::SKIP_DOTS);
|
|
|
|
foreach(new RecursiveIteratorIterator($delete, RecursiveIteratorIterator::CHILD_FIRST) as $path){
|
|
if ($path->isFile()){
|
|
unlink($path->getPathname());
|
|
}
|
|
else{
|
|
rmdir($path->getPathname());
|
|
}
|
|
}
|
|
|
|
// replacing the folder immediately breaks on Windows for some reason...
|
|
rename($dir_www, $dir_tmp);
|
|
rmdir($dir_tmp);
|
|
|
|
rename($dir_backup, $dir_www);
|
|
}
|
|
}
|
|
}
|