'Updated Schedule Name', 'minute' => '5', 'hour' => '*', 'day_of_week' => '*', 'month' => '*', 'day_of_month' => '*', 'is_active' => false, ]; /** * Test that a schedule can be updated. * * @param array $permissions * @dataProvider permissionsDataProvider */ public function testScheduleCanBeUpdated($permissions) { [$user, $server] = $this->generateTestAccount($permissions); /** @var \Pterodactyl\Models\Schedule $schedule */ $schedule = Schedule::factory()->create(['server_id' => $server->id]); $expected = Utilities::getScheduleNextRunDate('5', '*', '*', '*', '*'); $response = $this->actingAs($user) ->postJson("/api/client/servers/{$server->uuid}/schedules/{$schedule->id}", $this->updateData); $schedule = $schedule->refresh(); $response->assertOk(); $this->assertSame('Updated Schedule Name', $schedule->name); $this->assertFalse($schedule->is_active); $this->assertJsonTransformedWith($response->json('attributes'), $schedule); $this->assertSame($expected->toIso8601String(), $schedule->next_run_at->toIso8601String()); } /** * Test that an error is returned if the schedule exists but does not belong to this * specific server instance. */ public function testErrorIsReturnedIfScheduleDoesNotBelongToServer() { [$user, $server] = $this->generateTestAccount(); [, $server2] = $this->generateTestAccount(['user_id' => $user->id]); $schedule = Schedule::factory()->create(['server_id' => $server2->id]); $this->actingAs($user) ->postJson("/api/client/servers/{$server->uuid}/schedules/{$schedule->id}") ->assertNotFound(); } /** * Test that an error is returned if the subuser does not have permission to modify a * server schedule. */ public function testErrorIsReturnedIfSubuserDoesNotHavePermissionToModifySchedule() { [$user, $server] = $this->generateTestAccount([Permission::ACTION_SCHEDULE_CREATE]); $schedule = Schedule::factory()->create(['server_id' => $server->id]); $this->actingAs($user) ->postJson("/api/client/servers/{$server->uuid}/schedules/{$schedule->id}") ->assertForbidden(); } /** * Test that the "is_processing" field gets reset to false when the schedule is enabled * or disabled so that an invalid state can be more easily fixed. * * @see https://github.com/pterodactyl/panel/issues/2425 */ public function testScheduleIsProcessingIsSetToFalseWhenActiveStateChanges() { [$user, $server] = $this->generateTestAccount(); /** @var \Pterodactyl\Models\Schedule $schedule */ $schedule = Schedule::factory()->create([ 'server_id' => $server->id, 'is_active' => true, 'is_processing' => true, ]); $this->assertTrue($schedule->is_active); $this->assertTrue($schedule->is_processing); $response = $this->actingAs($user) ->postJson("/api/client/servers/{$server->uuid}/schedules/{$schedule->id}", $this->updateData); $schedule = $schedule->refresh(); $response->assertOk(); $this->assertFalse($schedule->is_active); $this->assertFalse($schedule->is_processing); } public function permissionsDataProvider(): array { return [[[]], [[Permission::ACTION_SCHEDULE_UPDATE]]]; } }