mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-02 22:46:16 +00:00
#591 - services
This commit is contained in:
@ -5,12 +5,10 @@
|
||||
use App\Enums\ServiceStatus;
|
||||
use App\Facades\SSH;
|
||||
use App\Models\Server;
|
||||
use App\Web\Pages\Servers\Services\Index;
|
||||
use App\Web\Pages\Servers\Services\Widgets\ServicesList;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Illuminate\Support\Facades\File;
|
||||
use Illuminate\Support\Facades\Http;
|
||||
use Livewire\Livewire;
|
||||
use Inertia\Testing\AssertableInertia;
|
||||
use Tests\TestCase;
|
||||
|
||||
class ServicesTest extends TestCase
|
||||
@ -21,14 +19,11 @@ public function test_see_services_list(): void
|
||||
{
|
||||
$this->actingAs($this->user);
|
||||
|
||||
$this->get(Index::getUrl(['server' => $this->server]))
|
||||
$this->get(route('services', [
|
||||
'server' => $this->server,
|
||||
]))
|
||||
->assertSuccessful()
|
||||
->assertSee('mysql')
|
||||
->assertSee('nginx')
|
||||
->assertSee('php')
|
||||
->assertSee('supervisor')
|
||||
->assertSee('redis')
|
||||
->assertSee('ufw');
|
||||
->assertInertia(fn (AssertableInertia $page) => $page->component('services/index'));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -44,11 +39,11 @@ public function test_restart_service(string $name): void
|
||||
|
||||
SSH::fake('Active: active');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.restart', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('restart', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -66,11 +61,11 @@ public function test_failed_to_restart_service(string $name): void
|
||||
|
||||
SSH::fake('Active: inactive');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.restart', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('restart', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -88,11 +83,11 @@ public function test_stop_service(string $name): void
|
||||
|
||||
SSH::fake('Active: inactive');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.stop', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('stop', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -110,11 +105,11 @@ public function test_failed_to_stop_service(string $name): void
|
||||
|
||||
SSH::fake('Active: active');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.stop', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('stop', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -134,11 +129,11 @@ public function test_start_service(string $name): void
|
||||
|
||||
SSH::fake('Active: active');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.start', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('start', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -156,11 +151,11 @@ public function test_failed_to_start_service(string $name): void
|
||||
|
||||
SSH::fake('Active: inactive');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.start', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('start', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -180,11 +175,11 @@ public function test_enable_service(string $name): void
|
||||
|
||||
SSH::fake('Active: active');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.enable', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('enable', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -202,11 +197,11 @@ public function test_failed_to_enable_service(string $name): void
|
||||
|
||||
SSH::fake('Active: inactive');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.enable', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('enable', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -224,11 +219,11 @@ public function test_disable_service(string $name): void
|
||||
|
||||
SSH::fake('Active: inactive');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.disable', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('disable', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -246,11 +241,11 @@ public function test_failed_to_disable_service(string $name): void
|
||||
|
||||
SSH::fake('Active: active');
|
||||
|
||||
Livewire::test(ServicesList::class, [
|
||||
$this->post(route('services.disable', [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callTableAction('disable', $service->id)
|
||||
->assertSuccessful();
|
||||
'service' => $service->id,
|
||||
]))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$service->refresh();
|
||||
|
||||
@ -281,14 +276,13 @@ public function test_install_service(string $name, string $type, string $version
|
||||
$server->provider()->generateKeyPair();
|
||||
}
|
||||
|
||||
Livewire::test(Index::class, [
|
||||
$this->post(route('services.store', [
|
||||
'server' => $server,
|
||||
]), [
|
||||
'name' => $name,
|
||||
'version' => $version,
|
||||
])
|
||||
->callAction('install', [
|
||||
'name' => $name,
|
||||
'version' => $version,
|
||||
])
|
||||
->assertSuccessful();
|
||||
->assertSessionDoesntHaveErrors();
|
||||
|
||||
$this->assertDatabaseHas('services', [
|
||||
'server_id' => $server->id,
|
||||
@ -298,13 +292,23 @@ public function test_install_service(string $name, string $type, string $version
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array<array<string>>
|
||||
*/
|
||||
public static function data(): array
|
||||
{
|
||||
return [
|
||||
['nginx'],
|
||||
['php'],
|
||||
['supervisor'],
|
||||
['redis'],
|
||||
['mysql'],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array<array<string>>
|
||||
*/
|
||||
public static function installData(): array
|
||||
{
|
||||
return [
|
||||
@ -313,6 +317,11 @@ public static function installData(): array
|
||||
'webserver',
|
||||
'latest',
|
||||
],
|
||||
[
|
||||
'caddy',
|
||||
'webserver',
|
||||
'latest',
|
||||
],
|
||||
[
|
||||
'php',
|
||||
'php',
|
||||
|
Reference in New Issue
Block a user