mirror of
https://github.com/vitodeploy/vito.git
synced 2025-04-19 09:51:37 +00:00
105 lines
2.7 KiB
PHP
105 lines
2.7 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature;
|
|
|
|
use App\Enums\DatabaseUserStatus;
|
|
use App\Facades\SSH;
|
|
use App\Models\DatabaseUser;
|
|
use Illuminate\Foundation\Testing\RefreshDatabase;
|
|
use Tests\TestCase;
|
|
|
|
class DatabaseUserTest extends TestCase
|
|
{
|
|
use RefreshDatabase;
|
|
|
|
public function test_create_database_user(): void
|
|
{
|
|
$this->actingAs($this->user);
|
|
|
|
SSH::fake();
|
|
|
|
$this->post(route('servers.databases.users.store', $this->server), [
|
|
'username' => 'user',
|
|
'password' => 'password',
|
|
])->assertSessionDoesntHaveErrors();
|
|
|
|
$this->assertDatabaseHas('database_users', [
|
|
'username' => 'user',
|
|
'status' => DatabaseUserStatus::READY,
|
|
]);
|
|
}
|
|
|
|
public function test_create_database_user_with_remote(): void
|
|
{
|
|
$this->actingAs($this->user);
|
|
|
|
SSH::fake();
|
|
|
|
$this->post(route('servers.databases.users.store', $this->server), [
|
|
'username' => 'user',
|
|
'password' => 'password',
|
|
'remote' => 'on',
|
|
'host' => '%',
|
|
])->assertSessionDoesntHaveErrors();
|
|
|
|
$this->assertDatabaseHas('database_users', [
|
|
'username' => 'user',
|
|
'host' => '%',
|
|
'status' => DatabaseUserStatus::READY,
|
|
]);
|
|
}
|
|
|
|
public function test_see_database_users_list(): void
|
|
{
|
|
$this->actingAs($this->user);
|
|
|
|
$databaseUser = DatabaseUser::factory()->create([
|
|
'server_id' => $this->server,
|
|
]);
|
|
|
|
$this->get(route('servers.databases', $this->server))
|
|
->assertSuccessful()
|
|
->assertSee($databaseUser->username);
|
|
}
|
|
|
|
public function test_delete_database_user(): void
|
|
{
|
|
$this->actingAs($this->user);
|
|
|
|
SSH::fake();
|
|
|
|
$databaseUser = DatabaseUser::factory()->create([
|
|
'server_id' => $this->server,
|
|
]);
|
|
|
|
$this->delete(route('servers.databases.users.destroy', [$this->server, $databaseUser]))
|
|
->assertSessionDoesntHaveErrors();
|
|
|
|
$this->assertDatabaseMissing('database_users', [
|
|
'id' => $databaseUser->id,
|
|
]);
|
|
}
|
|
|
|
public function test_unlink_database(): void
|
|
{
|
|
$this->actingAs($this->user);
|
|
|
|
SSH::fake();
|
|
|
|
$databaseUser = DatabaseUser::factory()->create([
|
|
'server_id' => $this->server,
|
|
]);
|
|
|
|
$this->post(route('servers.databases.users.link', [
|
|
'server' => $this->server,
|
|
'databaseUser' => $databaseUser,
|
|
]), [])
|
|
->assertSessionDoesntHaveErrors();
|
|
|
|
$this->assertDatabaseHas('database_users', [
|
|
'username' => $databaseUser->username,
|
|
'databases' => json_encode([]),
|
|
]);
|
|
}
|
|
}
|