mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-07 08:52:35 +00:00
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:
@ -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
|
@ -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',
|
85
tests/Unit/SSH/Services/Database/GetUsersTest.php
Normal file
85
tests/Unit/SSH/Services/Database/GetUsersTest.php
Normal 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
|
||||
],
|
||||
];
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user