From 81c0ca9e043b46bf865d8c7c088a6309f94df05d Mon Sep 17 00:00:00 2001 From: Marcus Nyeholt Date: Wed, 2 Jun 2021 12:22:23 +1000 Subject: [PATCH] fix(QueuedJobDescriptor) Ensure that anything set to 'waiting' has Worker reset so it can be picked up by a worker --- src/DataObjects/QueuedJobDescriptor.php | 12 +++++++ tests/QueuedJobsTest.php | 48 +++++++++++++++++++++++++ 2 files changed, 60 insertions(+) diff --git a/src/DataObjects/QueuedJobDescriptor.php b/src/DataObjects/QueuedJobDescriptor.php index 911454e2..4127defe 100644 --- a/src/DataObjects/QueuedJobDescriptor.php +++ b/src/DataObjects/QueuedJobDescriptor.php @@ -252,6 +252,18 @@ public function cleanupJob() } } + public function onBeforeWrite() + { + // if a job is marked as 'waiting' for a restart, we need to reset the + // worker it was assigned to, otherwise it'll never pick up and go again if + // it was paused from the UI, or a worker stopping to release memory / other reason! + if ($this->JobStatus == QueuedJob::STATUS_WAIT) { + $this->Worker = null; + } + + parent::onBeforeWrite(); + } + public function onBeforeDelete() { parent::onBeforeDelete(); diff --git a/tests/QueuedJobsTest.php b/tests/QueuedJobsTest.php index 9cf21066..de342df8 100644 --- a/tests/QueuedJobsTest.php +++ b/tests/QueuedJobsTest.php @@ -290,6 +290,54 @@ public function testNextJob() $this->assertNotEquals((int) $job->ID, (int) $next->ID); } + /** + * @throws ValidationException + */ + public function testNextResumedJob() + { + $svc = $this->getService(); + $list = $svc->getJobList(); + + foreach ($list as $job) { + $job->delete(); + } + + $list = $svc->getJobList(); + $this->assertCount(0, $list); + + $job = new TestQueuedJob(); + $id1 = $svc->queueJob($job); + + // okay, lets get the first one and initialise it, then make sure that a subsequent init attempt fails + $job = $svc->getNextPendingJob(); + + $this->assertEquals($id1, $job->ID); + $svc->testInit($job); + + // assign job locking properties + $job->Worker = 'test worker'; + $job->WorkerCount = (int) $job->WorkerCount + 1; + $job->Expiry = '2016-01-01 16:00:01'; + $job->write(); + + $next = $svc->getNextPendingJob(); + + $this->assertNull($next); + + // okay now pause the job and resume it - it _should_ be the next one + $job->pause(true); + + $next = $svc->getNextPendingJob(); + $this->assertNull($next); + + $job->resume(true); + + $next = $svc->getNextPendingJob(); + $this->assertNotNull($next); + + $this->assertEquals($job->ID, $next->ID); + } + /** * Verify that broken jobs are correctly verified for health and restarted as necessary *