mirror of
https://github.com/vitodeploy/vito.git
synced 2025-04-20 18:31:36 +00:00
175 lines
4.7 KiB
PHP
175 lines
4.7 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature\API;
|
|
|
|
use App\Enums\ServerProvider;
|
|
use Illuminate\Foundation\Testing\RefreshDatabase;
|
|
use Illuminate\Support\Facades\Http;
|
|
use Laravel\Sanctum\Sanctum;
|
|
use Tests\TestCase;
|
|
|
|
class ServerProvidersTest extends TestCase
|
|
{
|
|
use RefreshDatabase;
|
|
|
|
/**
|
|
* @dataProvider data
|
|
*/
|
|
public function test_connect_provider(string $provider, array $input): void
|
|
{
|
|
Sanctum::actingAs($this->user, ['read', 'write']);
|
|
|
|
Http::fake();
|
|
|
|
$data = array_merge(
|
|
[
|
|
'provider' => $provider,
|
|
'name' => 'profile',
|
|
],
|
|
$input
|
|
);
|
|
$this->json('POST', route('api.projects.server-providers.create', [
|
|
'project' => $this->user->current_project_id,
|
|
]), $data)
|
|
->assertSuccessful()
|
|
->assertJsonFragment([
|
|
'provider' => $provider,
|
|
'name' => 'profile',
|
|
'project_id' => isset($input['global']) ? null : $this->user->current_project_id,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider data
|
|
*/
|
|
public function test_cannot_connect_to_provider(string $provider, array $input): void
|
|
{
|
|
Sanctum::actingAs($this->user, ['read', 'write']);
|
|
|
|
Http::fake([
|
|
'*' => Http::response([], 401),
|
|
]);
|
|
|
|
$data = array_merge(
|
|
[
|
|
'provider' => $provider,
|
|
'name' => 'profile',
|
|
],
|
|
$input
|
|
);
|
|
$this->json('POST', route('api.projects.server-providers.create', [
|
|
'project' => $this->user->current_project_id,
|
|
]), $data)
|
|
->assertJsonValidationErrorFor('provider');
|
|
}
|
|
|
|
public function test_see_providers_list(): void
|
|
{
|
|
Sanctum::actingAs($this->user, ['read', 'write']);
|
|
|
|
/** @var \App\Models\ServerProvider $provider */
|
|
$provider = \App\Models\ServerProvider::factory()->create([
|
|
'user_id' => $this->user->id,
|
|
]);
|
|
|
|
$this->json('GET', route('api.projects.server-providers', [
|
|
'project' => $this->user->current_project_id,
|
|
]))
|
|
->assertSuccessful()
|
|
->assertJsonFragment([
|
|
'id' => $provider->id,
|
|
'provider' => $provider->provider,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider data
|
|
*/
|
|
public function test_delete_provider(string $provider): void
|
|
{
|
|
Sanctum::actingAs($this->user, ['read', 'write']);
|
|
|
|
/** @var \App\Models\ServerProvider $provider */
|
|
$provider = \App\Models\ServerProvider::factory()->create([
|
|
'user_id' => $this->user->id,
|
|
'provider' => $provider,
|
|
]);
|
|
|
|
$this->json('DELETE', route('api.projects.server-providers.delete', [
|
|
'project' => $this->user->current_project_id,
|
|
'serverProvider' => $provider->id,
|
|
]))
|
|
->assertNoContent();
|
|
}
|
|
|
|
/**
|
|
* @dataProvider data
|
|
*/
|
|
public function test_cannot_delete_provider(string $provider): void
|
|
{
|
|
Sanctum::actingAs($this->user, ['read', 'write']);
|
|
|
|
/** @var \App\Models\ServerProvider $provider */
|
|
$provider = \App\Models\ServerProvider::factory()->create([
|
|
'user_id' => $this->user->id,
|
|
'provider' => $provider,
|
|
]);
|
|
|
|
$this->server->update([
|
|
'provider_id' => $provider->id,
|
|
]);
|
|
|
|
$this->json('DELETE', route('api.projects.server-providers.delete', [
|
|
'project' => $this->user->current_project_id,
|
|
'serverProvider' => $provider->id,
|
|
]))
|
|
->assertJsonValidationErrors([
|
|
'provider' => 'This server provider is being used by a server.',
|
|
]);
|
|
}
|
|
|
|
public static function data(): array
|
|
{
|
|
return [
|
|
// [
|
|
// ServerProvider::AWS,
|
|
// [
|
|
// 'key' => 'key',
|
|
// 'secret' => 'secret',
|
|
// ],
|
|
// ],
|
|
[
|
|
ServerProvider::LINODE,
|
|
[
|
|
'token' => 'token',
|
|
],
|
|
],
|
|
[
|
|
ServerProvider::LINODE,
|
|
[
|
|
'token' => 'token',
|
|
'global' => 1,
|
|
],
|
|
],
|
|
[
|
|
ServerProvider::DIGITALOCEAN,
|
|
[
|
|
'token' => 'token',
|
|
],
|
|
],
|
|
[
|
|
ServerProvider::VULTR,
|
|
[
|
|
'token' => 'token',
|
|
],
|
|
],
|
|
[
|
|
ServerProvider::HETZNER,
|
|
[
|
|
'token' => 'token',
|
|
],
|
|
],
|
|
];
|
|
}
|
|
}
|