actingAs($this->user); SSH::fake(); $this->post(route('servers.databases.users.store', $this->server), [ 'username' => 'user', 'password' => 'password', ])->assertSessionDoesntHaveErrors(); $this->assertDatabaseHas('database_users', [ 'username' => 'user', 'status' => DatabaseUserStatus::READY, ]); } public function test_create_database_user_with_remote(): void { $this->actingAs($this->user); SSH::fake(); $this->post(route('servers.databases.users.store', $this->server), [ 'username' => 'user', 'password' => 'password', 'remote' => 'on', 'host' => '%', ])->assertSessionDoesntHaveErrors(); $this->assertDatabaseHas('database_users', [ 'username' => 'user', 'host' => '%', 'status' => DatabaseUserStatus::READY, ]); } public function test_see_database_users_list(): void { $this->actingAs($this->user); $databaseUser = DatabaseUser::factory()->create([ 'server_id' => $this->server, ]); $this->get(route('servers.databases', $this->server)) ->assertSuccessful() ->assertSee($databaseUser->username); } public function test_delete_database_user(): void { $this->actingAs($this->user); SSH::fake(); $databaseUser = DatabaseUser::factory()->create([ 'server_id' => $this->server, ]); $this->delete(route('servers.databases.users.destroy', [$this->server, $databaseUser])) ->assertSessionDoesntHaveErrors(); $this->assertDatabaseMissing('database_users', [ 'id' => $databaseUser->id, ]); } public function test_unlink_database(): void { $this->actingAs($this->user); SSH::fake(); $databaseUser = DatabaseUser::factory()->create([ 'server_id' => $this->server, ]); $this->post(route('servers.databases.users.link', [ 'server' => $this->server, 'databaseUser' => $databaseUser, ]), []) ->assertSessionDoesntHaveErrors(); $this->assertDatabaseHas('database_users', [ 'username' => $databaseUser->username, 'databases' => json_encode([]), ]); } }