mirror of
https://github.com/vitodeploy/vito.git
synced 2025-04-20 02:11:36 +00:00
109 lines
2.9 KiB
PHP
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();
|
|
}
|
|
}
|