From e5990f431dc76649173495bc204035a01c569cfd Mon Sep 17 00:00:00 2001 From: Andy Miller Date: Fri, 5 Jan 2024 12:31:53 +0000 Subject: [PATCH] Revert "Added 'outdated' option to scheduler command (#3771)" This reverts commit a71403f158cd55ccfbe03f6fbbb4c6bf84a71d95. # Conflicts: # tests/unit/Grav/Common/Scheduler/SchedulerTest.php --- system/src/Grav/Common/Scheduler/Job.php | 22 ----- .../src/Grav/Common/Scheduler/Scheduler.php | 12 +-- tests/unit/Grav/Common/Scheduler/JobTest.php | 82 ------------------- 3 files changed, 2 insertions(+), 114 deletions(-) delete mode 100644 tests/unit/Grav/Common/Scheduler/JobTest.php diff --git a/system/src/Grav/Common/Scheduler/Job.php b/system/src/Grav/Common/Scheduler/Job.php index e687406c6..3b119f434 100644 --- a/system/src/Grav/Common/Scheduler/Job.php +++ b/system/src/Grav/Common/Scheduler/Job.php @@ -200,28 +200,6 @@ class Job return $this->executionTime->isDue($date); } - /** - * Check if the Job should have run previously. - * - * @param DateTime|null $date - * @return bool - */ - public function isOverdue(?DateTime $date = null, ?DateTime $lastRun = null) - { - // If the time elapsed since the creation is inferior to the interval, it's not overdue - if ($this->creationTime > $this->executionTime->getPreviousRunDate($date)) { - return false; - } - // Else, if the job has never run, it's overdue - if (null === $lastRun) { - return true; - } - $date = $date ?? new DateTime('now'); - - // Else if the last run time is inferior to the previous scheduled time, it's overdue - return $lastRun < $this->executionTime->getPreviousRunDate($date); - } - /** * Check if the Job is overlapping. * diff --git a/system/src/Grav/Common/Scheduler/Scheduler.php b/system/src/Grav/Common/Scheduler/Scheduler.php index 46e6e703b..d3cefb0f3 100644 --- a/system/src/Grav/Common/Scheduler/Scheduler.php +++ b/system/src/Grav/Common/Scheduler/Scheduler.php @@ -188,7 +188,7 @@ class Scheduler * @param DateTime|null $runTime Optional, run at specific moment * @param bool $force force run even if not due */ - public function run(DateTime $runTime = null, $force = false, $overdue = false) + public function run(DateTime $runTime = null, $force = false) { $this->loadSavedJobs(); @@ -199,17 +199,9 @@ class Scheduler $runTime = new DateTime('now'); } - if ($overdue) { - $lastRuns = []; - foreach ($this->getJobStates()->content() as $id => $state) { - $timestamp = $state['last-run'] ?? time(); - $lastRuns[$id] = DateTime::createFromFormat('U',$timestamp); - } - } - // Star processing jobs foreach ($alljobs as $job) { - if ($job->isDue($runTime) || $force || ($overdue && $job->isOverdue($runTime, $lastRuns[$job->getId()] ?? null))) { + if ($job->isDue($runTime) || $force) { $job->run(); $this->jobs_run[] = $job; } diff --git a/tests/unit/Grav/Common/Scheduler/JobTest.php b/tests/unit/Grav/Common/Scheduler/JobTest.php deleted file mode 100644 index f28319688..000000000 --- a/tests/unit/Grav/Common/Scheduler/JobTest.php +++ /dev/null @@ -1,82 +0,0 @@ -assertEquals($expected, $job->isOverdue($date, $lastRun)); - } - - public function dataProviderForTestIsOverdue() - { - return [ - 'New Job' => [ - 'job' => (new Job('ls'))->at('* * * * *'), - 'date' => null, - 'lastRun' => null, - 'expected' => false - ], - 'New Job created 1 hour ago' => [ - 'job' => (new Job('ls'))->at('* * * * *'), - 'date' => new \DateTime('+1 hour'), - 'lastRun' => null, - 'expected' => true - ], - 'New Job created 1 minute ago' => [ - 'job' => (new Job('ls'))->at('* * * * *'), - 'date' => new \DateTime('+1 minute'), - 'lastRun' => null, - 'expected' => false - ], - 'New Job created 2 minutes ago' => [ - 'job' => (new Job('ls'))->at('* * * * *'), - 'date' => new \DateTime('+2 minutes'), - 'lastRun' => null, - 'expected' => true - ], - 'Job created 1 hour ago and last run 1 mn ago' => [ - 'job' => (new Job('ls'))->at('* * * * *'), - 'date' => new \DateTime('+1 hour'), - 'lastRun' => new \DateTime('+1 minutes'), - 'expected' => true - ], - 'Job created 1 hour ago and last run 30 mn ago' => [ - 'job' => (new Job('ls'))->at('* * * * *'), - 'date' => new \DateTime('+1 hour'), - 'lastRun' => new \DateTime('+30 minutes'), - 'expected' => true - ], - 'Job created 30 minutes ago and last run 1 hour ago' => [ - 'job' => (new Job('ls'))->at('* * * * *'), - 'date' => new \DateTime('+30 minutes'), - 'lastRun' => new \DateTime('+1 hour'), - 'expected' => false - ], - 'New hourly Job' => [ - 'job' => (new Job('ls'))->at('0 * * * *'), - 'date' => null, - 'lastRun' => null, - 'expected' => false - ], - 'New hourly Job created at 2 hours ago' => [ - 'job' => (new Job('ls'))->at('0 * * * *'), - 'date' => new \DateTime('+2 hours'), - 'lastRun' => null, - 'expected' => true - ], - 'Hourly Job created 1 hour ago and last run 30 mn ago' => [ - 'job' => (new Job('ls'))->at('0 * * * *'), - 'date' => new \DateTime('+1 hour'), - 'lastRun' => new \DateTime('+30 minutes'), - 'expected' => true - ], - ]; - } -}