Add database and database users sync (#537)

* Add database and database users sync

* get mysl users

* add mariadb and postgres

* fix phpstan
This commit is contained in:
Saeed Vaziry
2025-03-12 22:59:25 +01:00
committed by GitHub
parent 493cbb0849
commit 0f06d81aac
17 changed files with 383 additions and 65 deletions

View File

@ -6,7 +6,7 @@
use App\SSH\Services\Database\Database;
use Tests\TestCase;
class UpdateCharsetsTest extends TestCase
class GetCharsetsTest extends TestCase
{
protected static array $mysqlCharsets = [
'armscii8' => [
@ -46,15 +46,12 @@ public function test_update_charsets(string $name, string $version, string $outp
/** @var Database $databaseHandler */
$databaseHandler = $database->handler();
$databaseHandler->updateCharsets();
$charsets = $databaseHandler->getCharsets();
$database->refresh();
$this->assertEquals($expected, $database->type_data['charsets']);
$this->assertEquals($expected, $charsets['charsets']);
}
/**
* @TODO Add more test cases
*
* @return array[]
*/
public static function data(): array

View File

@ -6,12 +6,12 @@
use App\SSH\Services\Database\Database;
use Tests\TestCase;
class SyncDatabasesTest extends TestCase
class GetDatabasesTest extends TestCase
{
/**
* @dataProvider data
*/
public function test_sync_databases(string $name, string $version, string $output): void
public function test_get_databases(string $name, string $version, string $output): void
{
$database = $this->server->database();
$database->name = $name;
@ -22,17 +22,13 @@ public function test_sync_databases(string $name, string $version, string $outpu
/** @var Database $databaseHandler */
$databaseHandler = $database->handler();
$databaseHandler->syncDatabases();
$databases = $databaseHandler->getDatabases();
$this->assertDatabaseHas('databases', [
'server_id' => $this->server->id,
'name' => 'vito',
]);
$this->assertIsArray($databases);
$this->assertEquals('vito', $databases[0][0]);
}
/**
* @TODO Add more test cases
*
* @return array[]
*/
public static function data(): array
@ -62,6 +58,18 @@ public static function data(): array
vito utf8mb3 utf8mb3_general_ci
EOD
],
[
'mariadb',
'11.4',
<<<'EOD'
database_name charset collation
information_schema utf8mb3 utf8mb3_general_ci
mysql utf8mb4 utf8mb4_uca1400_ai_ci
performance_schema utf8mb3 utf8mb3_general_ci
sys utf8mb3 utf8mb3_general_ci
vito utf8mb3 utf8mb3_general_ci
EOD
],
[
'postgresql',
'16',

View File

@ -0,0 +1,85 @@
<?php
namespace Tests\Unit\SSH\Services\Database;
use App\Facades\SSH;
use App\SSH\Services\Database\Database;
use Tests\TestCase;
class GetUsersTest extends TestCase
{
/**
* @dataProvider data
*/
public function test_get_users(string $name, string $version, string $output): void
{
$database = $this->server->database();
$database->name = $name;
$database->version = $version;
$database->save();
SSH::fake($output);
/** @var Database $databaseHandler */
$databaseHandler = $database->handler();
$users = $databaseHandler->getUsers();
$this->assertIsArray($users);
$this->assertEquals('vito', $users[0][0]);
}
/**
* @return array[]
*/
public static function data(): array
{
return [
[
'mysql',
'8.0',
<<<'EOD'
User Host Privileges
vito localhost mydb,testdb
mysql.infoschema localhost NULL
mysql.session localhost performance_schema
mysql.sys localhost sys
root localhost NULL
EOD
],
[
'mysql',
'5.7',
<<<'EOD'
User Host Privileges
vito localhost mydb,testdb
mysql.infoschema localhost NULL
mysql.session localhost performance_schema
mysql.sys localhost sys
root localhost NULL
EOD
],
[
'mariadb',
'11.4',
<<<'EOD'
User Host Privileges
mariadb.sys localhost NULL
mysql localhost NULL
root localhost NULL
vito localhost NULL
EOD
],
[
'postgresql',
'16',
<<<'EOD'
username | host | databases
----------+------+------------------------------------------
postgres | | template1,template0,postgres,test,vitodb
vito | | template1,template0,postgres,test,vitodb
(2 rows)
EOD
],
];
}
}