- Added `requiredPort` property to `ServiceApplicationView` to track the required port for services. - Introduced modal confirmation for removing required ports, including methods to confirm or cancel the action. - Enhanced `Service` model with `getRequiredPort` and `requiresPort` methods to retrieve port information from service templates. - Implemented `extractPortFromUrl` method in `ServiceApplication` to extract port from FQDN URLs. - Updated frontend views to display warnings when required ports are missing from domains. - Created unit tests for service port validation and extraction logic, ensuring correct behavior for various scenarios. - Added feature tests for Livewire component handling of domain submissions with required ports.
154 lines
5.7 KiB
PHP
154 lines
5.7 KiB
PHP
<?php
|
|
|
|
use App\Livewire\Project\Service\EditDomain;
|
|
use App\Models\Environment;
|
|
use App\Models\Project;
|
|
use App\Models\Server;
|
|
use App\Models\Service;
|
|
use App\Models\ServiceApplication;
|
|
use App\Models\StandaloneDocker;
|
|
use App\Models\Team;
|
|
use App\Models\User;
|
|
use Livewire\Livewire;
|
|
|
|
beforeEach(function () {
|
|
// Create user and team
|
|
$this->user = User::factory()->create();
|
|
$this->team = Team::factory()->create();
|
|
$this->user->teams()->attach($this->team, ['role' => 'owner']);
|
|
$this->actingAs($this->user);
|
|
|
|
// Create server
|
|
$this->server = Server::factory()->create([
|
|
'team_id' => $this->team->id,
|
|
]);
|
|
|
|
// Create standalone docker destination
|
|
$this->destination = StandaloneDocker::factory()->create([
|
|
'server_id' => $this->server->id,
|
|
]);
|
|
|
|
// Create project and environment
|
|
$this->project = Project::factory()->create([
|
|
'team_id' => $this->team->id,
|
|
]);
|
|
|
|
$this->environment = Environment::factory()->create([
|
|
'project_id' => $this->project->id,
|
|
]);
|
|
|
|
// Create service with a name that maps to a template with required port
|
|
$this->service = Service::factory()->create([
|
|
'name' => 'supabase-test123',
|
|
'server_id' => $this->server->id,
|
|
'destination_id' => $this->destination->id,
|
|
'destination_type' => $this->destination->getMorphClass(),
|
|
'environment_id' => $this->environment->id,
|
|
]);
|
|
|
|
// Create service application
|
|
$this->serviceApplication = ServiceApplication::factory()->create([
|
|
'service_id' => $this->service->id,
|
|
'fqdn' => 'http://example.com:8000',
|
|
]);
|
|
|
|
// Mock get_service_templates to return a service with required port
|
|
if (! function_exists('get_service_templates_mock')) {
|
|
function get_service_templates_mock()
|
|
{
|
|
return collect([
|
|
'supabase' => [
|
|
'name' => 'Supabase',
|
|
'port' => '8000',
|
|
'documentation' => 'https://supabase.com',
|
|
],
|
|
]);
|
|
}
|
|
}
|
|
});
|
|
|
|
it('loads the EditDomain component with required port', function () {
|
|
Livewire::test(EditDomain::class, ['applicationId' => $this->serviceApplication->id])
|
|
->assertSet('requiredPort', 8000)
|
|
->assertSet('fqdn', 'http://example.com:8000')
|
|
->assertOk();
|
|
});
|
|
|
|
it('shows warning modal when trying to remove required port', function () {
|
|
Livewire::test(EditDomain::class, ['applicationId' => $this->serviceApplication->id])
|
|
->set('fqdn', 'http://example.com') // Remove port
|
|
->call('submit')
|
|
->assertSet('showPortWarningModal', true)
|
|
->assertSet('requiredPort', 8000);
|
|
});
|
|
|
|
it('allows port removal when user confirms', function () {
|
|
Livewire::test(EditDomain::class, ['applicationId' => $this->serviceApplication->id])
|
|
->set('fqdn', 'http://example.com') // Remove port
|
|
->call('submit')
|
|
->assertSet('showPortWarningModal', true)
|
|
->call('confirmRemovePort')
|
|
->assertSet('showPortWarningModal', false);
|
|
|
|
// Verify the FQDN was updated in database
|
|
$this->serviceApplication->refresh();
|
|
expect($this->serviceApplication->fqdn)->toBe('http://example.com');
|
|
});
|
|
|
|
it('cancels port removal when user cancels', function () {
|
|
$originalFqdn = $this->serviceApplication->fqdn;
|
|
|
|
Livewire::test(EditDomain::class, ['applicationId' => $this->serviceApplication->id])
|
|
->set('fqdn', 'http://example.com') // Remove port
|
|
->call('submit')
|
|
->assertSet('showPortWarningModal', true)
|
|
->call('cancelRemovePort')
|
|
->assertSet('showPortWarningModal', false)
|
|
->assertSet('fqdn', $originalFqdn); // Should revert to original
|
|
});
|
|
|
|
it('allows saving when port is changed to different port', function () {
|
|
Livewire::test(EditDomain::class, ['applicationId' => $this->serviceApplication->id])
|
|
->set('fqdn', 'http://example.com:3000') // Change to different port
|
|
->call('submit')
|
|
->assertSet('showPortWarningModal', false); // Should not show warning
|
|
|
|
// Verify the FQDN was updated
|
|
$this->serviceApplication->refresh();
|
|
expect($this->serviceApplication->fqdn)->toBe('http://example.com:3000');
|
|
});
|
|
|
|
it('allows saving when all domains have ports (multiple domains)', function () {
|
|
Livewire::test(EditDomain::class, ['applicationId' => $this->serviceApplication->id])
|
|
->set('fqdn', 'http://example.com:8000,https://app.example.com:8080')
|
|
->call('submit')
|
|
->assertSet('showPortWarningModal', false); // Should not show warning
|
|
});
|
|
|
|
it('shows warning when at least one domain is missing port (multiple domains)', function () {
|
|
Livewire::test(EditDomain::class, ['applicationId' => $this->serviceApplication->id])
|
|
->set('fqdn', 'http://example.com:8000,https://app.example.com') // Second domain missing port
|
|
->call('submit')
|
|
->assertSet('showPortWarningModal', true);
|
|
});
|
|
|
|
it('does not show warning for services without required port', function () {
|
|
// Create a service without required port (e.g., cloudflared)
|
|
$serviceWithoutPort = Service::factory()->create([
|
|
'name' => 'cloudflared-test456',
|
|
'server_id' => $this->server->id,
|
|
'destination_id' => $this->destination->id,
|
|
'destination_type' => $this->destination->getMorphClass(),
|
|
'environment_id' => $this->environment->id,
|
|
]);
|
|
|
|
$appWithoutPort = ServiceApplication::factory()->create([
|
|
'service_id' => $serviceWithoutPort->id,
|
|
'fqdn' => 'http://example.com',
|
|
]);
|
|
|
|
Livewire::test(EditDomain::class, ['applicationId' => $appWithoutPort->id])
|
|
->set('fqdn', 'http://example.com') // No port
|
|
->call('submit')
|
|
->assertSet('showPortWarningModal', false); // Should not show warning
|
|
});
|