/** * Transition a job to error state * * @access public * @param string $handle The worker's handle * @param DateTime $start * @param string $msg * @throws LaterJob\Exception when starting state fails */ public function error($handle, DateTime $when, $msg = '') { $current = $this->storage->getState(); if ($current !== QueueConfig::STATE_START) { throw new LaterJobException(sprintf('Can not transiton from %s to %s', $this->getCurrentState(), $this->config->getLiteral(QueueConfig::STATE_ERROR))); } # change the state on the storage $this->storage->setState(QueueConfig::STATE_ERROR); # set the timer for next retry $wait = clone $when; $t = $wait->getTimestamp(); $v = $this->config->getRetryTimer(); $wait->setTimestamp($t + $v); $this->storage->setRetryLast($wait); # remove one off recount $count = $this->storage->getRetryLeft(); if ($count > 0) { $this->storage->setRetryLeft($count - 1); } # create the transition entity $trans = new Transition(); $trans->setJob($this->getId()); $trans->setState(QueueConfig::STATE_ERROR); $trans->setOccured($when); $trans->setMessage(' Job ' . $this->getId() . ' ERROR :: ' . $msg); $trans->setProcessHandle($handle); # raise the error event $this->event->dispatch(JobEventsMap::STATE_ERROR, new JobTransitionEvent($this, $trans)); }
public function testJobProperties() { $id = 'a job'; $data = new \stdClass(); $mock_event = $this->getMock('Symfony\\Component\\EventDispatcher\\EventDispatcherInterface'); $mock_def = $this->getMock('LaterJob\\Config\\QueueConfig'); $storage = new Storage(); $storage->setJobId($id); $storage->setJobData($data); $storage->setState(QueueConfig::STATE_ADD); $storage->setRetryLeft(3); $job = new Job($storage, $mock_def, $mock_event); $this->assertEquals($mock_def, $job->getConfig()); $this->assertEquals($id, $job->getId()); $this->assertEquals($storage, $job->getStorage()); $this->assertEquals($data, $job->getData()); $this->assertEquals(3, $job->getRetryCount()); }
/** * Convert data array into entity * * @return mixed * @param array $data * @access public */ public function build($data) { $object = new Storage(); $object->setJobId($data['job_id']); $object->setRetryLeft($data['retry_count']); $object->setDateAdded($data['dte_add']); $object->setState($data['state_id']); $object->setJobData($data['job_data']); if ($data['lock_timeout'] instanceof DateTime) { $object->setLockoutTimer($data['lock_timeout']); } if ($data['retry_last'] instanceof DateTime) { $object->setRetryLast($data['lock_timeout']); } if ($data['handle'] !== null) { $object->setLockoutHandle($data['handle']); } return $object; }
/** * Add a job to the queue * * @access public * @return boolean true if job added * @throws LaterJob\Exception * @param DateTime $now * @param mixed $job_data */ public function send(DateTime $now, $job_data) { $uuid = $this['uuid']; $event = $this['dispatcher']; $queue_options = $this['config.queue']; $storage = new Storage(); # generate the uuid for job $storage->setJobId($uuid->v3($uuid->v4(), md5(json_encode($job_data)))); $storage->setDateAdded($now); $storage->setJobData($job_data); $storage->setState(QueueConfig::STATE_ADD); $storage->setRetryLeft($queue_options->getMaxRetry()); # raise the add event $event->dispatch(QueueEventsMap::QUEUE_REC, new QueueReceiveEvent($storage)); return true; }
public function testDemolish() { $storage = new Storage(); $builder = new StorageBuilder(); $dte_added = new DateTime(); $job_data = new \stdClass(); $job_id = '67b9a976-2edd-3e6e-adc3-22adeb5b3949'; $lockout_handle = md5($job_id); $lockout_timer = new DateTime(); $retry = 3; $state = 1; $retry_last = new DateTime(); $storage->setDateAdded($dte_added); $storage->setJobData($job_data); $storage->setJobId($job_id); $storage->setLockoutHandle($lockout_handle); $storage->setLockoutTimer($lockout_timer); $storage->setRetryLeft($retry); $storage->setRetryLast($retry_last); $storage->setState($state); $this->assertEquals(array('job_id' => $job_id, 'retry_count' => $retry, 'dte_add' => $dte_added, 'state_id' => $state, 'job_data' => $job_data, 'handle' => $lockout_handle, 'lock_timeout' => $lockout_timer, 'retry_last' => $retry_last), $builder->demolish($storage)); }
public function testReceiveHandlerDB() { $gateway = $this->getTableGateway(); $handler = new QueueSubscriber($gateway); $uuid = new UUID(new MersenneRandom(10000)); $job_name = 'test_job_1'; $added = new DateTime('01-01-2014 00:00:00'); # create the transition $storage = new Storage(); $jobID = $uuid->v3($uuid->v4(), $job_name); $storage->setJobId($jobID); $storage->setDateAdded($added); $storage->setJobData(new \stdClass()); $storage->setState(QueueConfig::STATE_ADD); $storage->setRetryLeft(3); $event = new QueueReceiveEvent($storage); $handler->onReceive($event); # assert save result set matches $resulting_table = $this->getConnection()->createQueryTable("later_job_queue", "SELECT * FROM later_job_queue ORDER BY dte_add"); $expected_table = $this->createXmlDataSet(__DIR__ . DIRECTORY_SEPARATOR . 'Fixture' . DIRECTORY_SEPARATOR . "receive_handler_result.xml")->getTable("later_job_queue"); $this->assertTablesEqual($expected_table, $resulting_table); }