116 lines
3.9 KiB
PHP
116 lines
3.9 KiB
PHP
<?php
|
|
|
|
namespace Pterodactyl\Tests\Integration\Api\Client\Server\Schedule;
|
|
|
|
use Pterodactyl\Models\Schedule;
|
|
use Pterodactyl\Helpers\Utilities;
|
|
use Pterodactyl\Models\Permission;
|
|
use Pterodactyl\Tests\Integration\Api\Client\ClientApiIntegrationTestCase;
|
|
|
|
class UpdateServerScheduleTest extends ClientApiIntegrationTestCase
|
|
{
|
|
/**
|
|
* The data to use when updating a schedule.
|
|
*/
|
|
private array $updateData = [
|
|
'name' => 'Updated Schedule Name',
|
|
'minute' => '5',
|
|
'hour' => '*',
|
|
'day_of_week' => '*',
|
|
'month' => '*',
|
|
'day_of_month' => '*',
|
|
'is_active' => false,
|
|
];
|
|
|
|
/**
|
|
* Test that a schedule can be updated.
|
|
*
|
|
* @dataProvider permissionsDataProvider
|
|
*/
|
|
public function testScheduleCanBeUpdated(array $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->toAtomString(), $schedule->next_run_at->toAtomString());
|
|
}
|
|
|
|
/**
|
|
* 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->createServerModel(['owner_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 static function permissionsDataProvider(): array
|
|
{
|
|
return [[[]], [[Permission::ACTION_SCHEDULE_UPDATE]]];
|
|
}
|
|
}
|