mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-01 05:56:16 +00:00
Isolate Users (#431)
* WIP to isolate users * Resolved issue with SSH AsUser Updated Isolated User Script to use Server User for Team Access Updated Path creation script to simplify for running as the isolated user * Included the server user * PHPMyAdmin script updated Wordpress Script Updated Updated Execute Script to support executing as isolated users * Issue Resolution & Resolved Failing Unit Tests * Fix for isolated_username vs user * Run the deploy as the isolated user * queue updates for isolated user * Support isolated users in cronjobs * script tests for isolated users * Queue tests for isolated users * Cronjob tests for isolated user * Removed default queue command for laravel apps * add default user to factory * laravel pint fixes * ensure echos are consistent * removed unneeded parameter * update * fix queues for isolated users * revert addslashes --------- Co-authored-by: Saeed Vaziry <mr.saeedvaziry@gmail.com>
This commit is contained in:
@ -48,13 +48,31 @@ public function test_create_site(array $inputs): void
|
||||
->assertHasNoActionErrors()
|
||||
->assertSuccessful();
|
||||
|
||||
$expectedUser = empty($inputs['user']) ? $this->server->getSshUser() : $inputs['user'];
|
||||
$this->assertDatabaseHas('sites', [
|
||||
'domain' => $inputs['domain'],
|
||||
'aliases' => json_encode($inputs['aliases'] ?? []),
|
||||
'status' => SiteStatus::READY,
|
||||
'user' => $expectedUser,
|
||||
'path' => '/home/'.$expectedUser.'/'.$inputs['domain'],
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider failure_create_data
|
||||
*/
|
||||
public function test_isolated_user_failure(array $inputs): void
|
||||
{
|
||||
SSH::fake();
|
||||
$this->actingAs($this->user);
|
||||
|
||||
Livewire::test(Index::class, [
|
||||
'server' => $this->server,
|
||||
])
|
||||
->callAction('create', $inputs)
|
||||
->assertHasActionErrors();
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider create_failure_data
|
||||
*/
|
||||
@ -247,6 +265,62 @@ public function test_see_logs(): void
|
||||
->assertSee('Logs');
|
||||
}
|
||||
|
||||
public static function failure_create_data(): array
|
||||
{
|
||||
return [
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHP_BLANK,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'web_directory' => 'public',
|
||||
'user' => 'a',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHP_BLANK,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'web_directory' => 'public',
|
||||
'user' => 'root',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHP_BLANK,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'web_directory' => 'public',
|
||||
'user' => 'vito',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHP_BLANK,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'web_directory' => 'public',
|
||||
'user' => '123',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHP_BLANK,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'web_directory' => 'public',
|
||||
'user' => 'qwertyuiopasdfghjklzxcvbnmqwertyu',
|
||||
],
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
public static function create_data(): array
|
||||
{
|
||||
return [
|
||||
@ -262,6 +336,19 @@ public static function create_data(): array
|
||||
'composer' => true,
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::LARAVEL,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com', 'www2.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'web_directory' => 'public',
|
||||
'repository' => 'test/test',
|
||||
'branch' => 'main',
|
||||
'composer' => true,
|
||||
'user' => 'example',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::WORDPRESS,
|
||||
@ -277,6 +364,22 @@ public static function create_data(): array
|
||||
'database_password' => 'password',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::WORDPRESS,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'title' => 'Example',
|
||||
'username' => 'example',
|
||||
'email' => 'email@example.com',
|
||||
'password' => 'password',
|
||||
'database' => 'example',
|
||||
'database_user' => 'example',
|
||||
'database_password' => 'password',
|
||||
'user' => 'example',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHP_BLANK,
|
||||
@ -286,6 +389,16 @@ public static function create_data(): array
|
||||
'web_directory' => 'public',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHP_BLANK,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'web_directory' => 'public',
|
||||
'user' => 'example',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHPMYADMIN,
|
||||
@ -295,6 +408,16 @@ public static function create_data(): array
|
||||
'version' => '5.1.2',
|
||||
],
|
||||
],
|
||||
[
|
||||
[
|
||||
'type' => SiteType::PHPMYADMIN,
|
||||
'domain' => 'example.com',
|
||||
'aliases' => ['www.example.com'],
|
||||
'php_version' => '8.2',
|
||||
'version' => '5.1.2',
|
||||
'user' => 'example',
|
||||
],
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user