mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-02 14:36:17 +00:00
tests
This commit is contained in:
@ -10,10 +10,18 @@
|
||||
use App\Enums\ServiceStatus;
|
||||
use App\Enums\Webserver;
|
||||
use App\Facades\SSH;
|
||||
use App\Models\Server;
|
||||
use App\NotificationChannels\Email\NotificationMail;
|
||||
use App\Web\Pages\Servers\Index;
|
||||
use App\Web\Pages\Servers\Settings;
|
||||
use App\Web\Pages\Servers\Widgets\ServerDetails;
|
||||
use App\Web\Pages\Servers\Widgets\ServerSummary;
|
||||
use App\Web\Pages\Servers\Widgets\UpdateServerInfo;
|
||||
use Filament\Notifications\Notification;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Illuminate\Support\Facades\Http;
|
||||
use Illuminate\Support\Facades\Mail;
|
||||
use Livewire\Livewire;
|
||||
use Tests\TestCase;
|
||||
|
||||
class ServerTest extends TestCase
|
||||
@ -26,17 +34,19 @@ public function test_create_regular_server(): void
|
||||
|
||||
SSH::fake('Active: active'); // fake output for service installations
|
||||
|
||||
$this->post(route('servers.create'), [
|
||||
'type' => ServerType::REGULAR,
|
||||
'provider' => ServerProvider::CUSTOM,
|
||||
'name' => 'test',
|
||||
'ip' => '1.1.1.1',
|
||||
'port' => '22',
|
||||
'os' => OperatingSystem::UBUNTU22,
|
||||
'webserver' => Webserver::NGINX,
|
||||
'database' => Database::MYSQL80,
|
||||
'php' => '8.2',
|
||||
])->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(Index::class)
|
||||
->callAction('create', [
|
||||
'type' => ServerType::REGULAR,
|
||||
'provider' => ServerProvider::CUSTOM,
|
||||
'name' => 'test',
|
||||
'ip' => '1.1.1.1',
|
||||
'port' => '22',
|
||||
'os' => OperatingSystem::UBUNTU22,
|
||||
'webserver' => Webserver::NGINX,
|
||||
'database' => Database::MYSQL80,
|
||||
'php' => '8.2',
|
||||
])
|
||||
->assertSuccessful();
|
||||
|
||||
$this->assertDatabaseHas('servers', [
|
||||
'name' => 'test',
|
||||
@ -82,17 +92,19 @@ public function test_create_database_server(): void
|
||||
|
||||
SSH::fake('Active: active'); // fake output for service installations
|
||||
|
||||
$this->post(route('servers.create'), [
|
||||
'type' => ServerType::DATABASE,
|
||||
'provider' => ServerProvider::CUSTOM,
|
||||
'name' => 'test',
|
||||
'ip' => '2.2.2.2',
|
||||
'port' => '22',
|
||||
'os' => OperatingSystem::UBUNTU22,
|
||||
'database' => Database::MYSQL80,
|
||||
])->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(Index::class)
|
||||
->callAction('create', [
|
||||
'type' => ServerType::DATABASE,
|
||||
'provider' => ServerProvider::CUSTOM,
|
||||
'name' => 'test',
|
||||
'ip' => '2.2.2.2',
|
||||
'port' => '22',
|
||||
'os' => OperatingSystem::UBUNTU22,
|
||||
'database' => Database::MYSQL80,
|
||||
])
|
||||
->assertSuccessful();
|
||||
|
||||
$server = \App\Models\Server::query()->where('ip', '2.2.2.2')->first();
|
||||
$server = Server::query()->where('ip', '2.2.2.2')->first();
|
||||
|
||||
$this->assertDatabaseHas('servers', [
|
||||
'name' => 'test',
|
||||
@ -138,8 +150,11 @@ public function test_delete_server(): void
|
||||
|
||||
SSH::fake();
|
||||
|
||||
$this->delete(route('servers.delete', $this->server))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(Settings::class, [
|
||||
'server' => $this->server,
|
||||
])->callAction('delete')
|
||||
->assertSuccessful()
|
||||
->assertRedirect(Index::getUrl());
|
||||
|
||||
$this->assertDatabaseMissing('servers', [
|
||||
'id' => $this->server->id,
|
||||
@ -172,8 +187,11 @@ public function test_cannot_delete_on_provider(): void
|
||||
],
|
||||
]);
|
||||
|
||||
$this->delete(route('servers.delete', $this->server))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(Settings::class, [
|
||||
'server' => $this->server,
|
||||
])->callAction('delete')
|
||||
->assertSuccessful()
|
||||
->assertRedirect(Index::getUrl());
|
||||
|
||||
$this->assertDatabaseMissing('servers', [
|
||||
'id' => $this->server->id,
|
||||
@ -190,8 +208,12 @@ public function test_check_connection_is_ready(): void
|
||||
|
||||
$this->server->update(['status' => ServerStatus::DISCONNECTED]);
|
||||
|
||||
$this->post(route('servers.settings.check-connection', $this->server))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(ServerSummary::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callInfolistAction('status', 'check-status')
|
||||
->assertSuccessful()
|
||||
->assertNotified('Server is '.ServerStatus::READY);
|
||||
|
||||
$this->assertDatabaseHas('servers', [
|
||||
'id' => $this->server->id,
|
||||
@ -207,8 +229,12 @@ public function test_connection_failed(): void
|
||||
|
||||
$this->server->update(['status' => ServerStatus::READY]);
|
||||
|
||||
$this->post(route('servers.settings.check-connection', $this->server))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(ServerSummary::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callInfolistAction('status', 'check-status')
|
||||
->assertSuccessful()
|
||||
->assertNotified('Server is '.ServerStatus::DISCONNECTED);
|
||||
|
||||
$this->assertDatabaseHas('servers', [
|
||||
'id' => $this->server->id,
|
||||
@ -222,8 +248,11 @@ public function test_reboot_server(): void
|
||||
|
||||
$this->actingAs($this->user);
|
||||
|
||||
$this->post(route('servers.settings.reboot', $this->server))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(Settings::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callAction('reboot')
|
||||
->assertSuccessful();
|
||||
|
||||
$this->assertDatabaseHas('servers', [
|
||||
'id' => $this->server->id,
|
||||
@ -233,11 +262,20 @@ public function test_reboot_server(): void
|
||||
|
||||
public function test_edit_server(): void
|
||||
{
|
||||
SSH::fake();
|
||||
|
||||
$this->actingAs($this->user);
|
||||
|
||||
$this->post(route('servers.settings.edit', $this->server), [
|
||||
'name' => 'new-name',
|
||||
])->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(UpdateServerInfo::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->fill([
|
||||
'name' => 'new-name',
|
||||
'ip' => $this->server->ip,
|
||||
'port' => $this->server->port,
|
||||
])
|
||||
->call('submit')
|
||||
->assertSuccessful();
|
||||
|
||||
$this->assertDatabaseHas('servers', [
|
||||
'id' => $this->server->id,
|
||||
@ -251,9 +289,16 @@ public function test_edit_server_ip_address(): void
|
||||
|
||||
$this->actingAs($this->user);
|
||||
|
||||
$this->post(route('servers.settings.edit', $this->server), [
|
||||
'ip' => '2.2.2.2',
|
||||
])->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(UpdateServerInfo::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->fill([
|
||||
'name' => $this->server->name,
|
||||
'ip' => '2.2.2.2',
|
||||
'port' => $this->server->port,
|
||||
])
|
||||
->call('submit')
|
||||
->assertSuccessful();
|
||||
|
||||
$this->assertDatabaseHas('servers', [
|
||||
'id' => $this->server->id,
|
||||
@ -268,10 +313,16 @@ public function test_edit_server_ip_address_and_disconnect(): void
|
||||
|
||||
$this->actingAs($this->user);
|
||||
|
||||
$this->post(route('servers.settings.edit', $this->server), [
|
||||
'ip' => '2.2.2.2',
|
||||
'port' => 2222,
|
||||
])->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(UpdateServerInfo::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->fill([
|
||||
'name' => $this->server->name,
|
||||
'ip' => '2.2.2.2',
|
||||
'port' => 2222,
|
||||
])
|
||||
->call('submit')
|
||||
->assertSuccessful();
|
||||
|
||||
$this->assertDatabaseHas('servers', [
|
||||
'id' => $this->server->id,
|
||||
@ -287,8 +338,17 @@ public function test_check_updates(): void
|
||||
|
||||
$this->actingAs($this->user);
|
||||
|
||||
$this->post(route('servers.settings.check-updates', $this->server))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(ServerDetails::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callInfolistAction('last_updated_check', 'check-update')
|
||||
->assertSuccessful()
|
||||
->assertNotified(
|
||||
Notification::make()
|
||||
->info()
|
||||
->title('Available updates:')
|
||||
->body(9)
|
||||
);
|
||||
|
||||
$this->server->refresh();
|
||||
$this->assertEquals(9, $this->server->updates);
|
||||
@ -300,8 +360,11 @@ public function test_update_server(): void
|
||||
|
||||
$this->actingAs($this->user);
|
||||
|
||||
$this->post(route('servers.settings.update', $this->server))
|
||||
->assertSessionDoesntHaveErrors();
|
||||
Livewire::test(ServerDetails::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callInfolistAction('updates', 'update-server')
|
||||
->assertSuccessful();
|
||||
|
||||
$this->server->refresh();
|
||||
|
||||
|
Reference in New Issue
Block a user