vito/tests/Feature/API/FirewallTest.php
2025-02-16 20:31:58 +01:00

109 lines
2.9 KiB
PHP

<?php
namespace Tests\Feature\API;
use App\Enums\FirewallRuleStatus;
use App\Facades\SSH;
use App\Models\FirewallRule;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Laravel\Sanctum\Sanctum;
use Tests\TestCase;
class FirewallTest extends TestCase
{
use RefreshDatabase;
public function test_create_firewall_rule(): void
{
SSH::fake();
Sanctum::actingAs($this->user, ['read', 'write']);
$this->json('POST', route('api.projects.servers.firewall-rules.create', [
'project' => $this->server->project,
'server' => $this->server,
]), [
'name' => 'Test',
'type' => 'allow',
'protocol' => 'tcp',
'port' => '1234',
'source' => '0.0.0.0',
'mask' => '1',
])
->assertSuccessful()
->assertJsonFragment([
'port' => 1234,
'status' => FirewallRuleStatus::CREATING,
]);
}
public function test_edit_firewall_rule(): void
{
SSH::fake();
Sanctum::actingAs($this->user, ['read', 'write']);
$rule = FirewallRule::factory()->create([
'server_id' => $this->server->id,
'port' => 1234,
]);
$this->json('PUT', route('api.projects.servers.firewall-rules.edit', [
'project' => $this->server->project,
'server' => $this->server,
'firewallRule' => $rule,
]), [
'name' => 'Test',
'type' => 'allow',
'protocol' => 'tcp',
'port' => '55',
'source' => null,
'mask' => null,
])
->assertSuccessful()
->assertJsonFragment([
'port' => 55,
'status' => FirewallRuleStatus::UPDATING,
]);
}
public function test_see_firewall_rules(): void
{
Sanctum::actingAs($this->user, ['read', 'write']);
/** @var FirewallRule $rule */
$rule = FirewallRule::factory()->create([
'server_id' => $this->server->id,
]);
$this->json('GET', route('api.projects.servers.firewall-rules', [
'project' => $this->server->project,
'server' => $this->server,
]))
->assertSuccessful()
->assertJsonFragment([
'source' => $rule->source,
'port' => $rule->port,
]);
}
public function test_delete_firewall_rule(): void
{
SSH::fake();
Sanctum::actingAs($this->user, ['read', 'write']);
/** @var FirewallRule $rule */
$rule = FirewallRule::factory()->create([
'server_id' => $this->server->id,
]);
$this->json('DELETE', route('api.projects.servers.firewall-rules.delete', [
'project' => $this->server->project,
'server' => $this->server,
'firewallRule' => $rule,
]))
->assertNoContent();
}
}