Esempio n. 1
0
 /**
  * @param int $count
  */
 private function assertJobsAreQueued($count)
 {
     $uniqid = uniqid();
     for ($i = 1; $i <= $count; $i++) {
         $row = ['buffered_job_id' => "{$uniqid}-{$i}-id", 'queue_name' => 'default-worker', 'job_name' => "{$uniqid}-{$i}-name", 'job_params' => ["{$uniqid}-{$i}-params"], 'run_after' => date('c'), 'job_rank' => $i, 'mutex_id' => "{$uniqid}-{$i}-mutex"];
         $this->database->insert('buffered_jobs', "{$uniqid}-{$i}-id", $row);
     }
     $this->superqueue->queueJobsFromDatabaseToWorkerQueue();
     $confirmed_messages = 0;
     for ($i = 1; $i <= $count; $i++) {
         $mq_message = json_decode($this->message_bank->consumeMessage()->getContent(), true);
         if ("{$uniqid}-{$i}-name" === $mq_message['name'] && $this->database->has('queued_jobs', "{$uniqid}-{$i}-id")) {
             ++$confirmed_messages;
         }
     }
     $this->assertSame($count, $confirmed_messages);
 }
Esempio n. 2
0
 /**
  * @covers ::consumeMessage
  * @covers ::produceMessage
  * @covers ::acknowledgeMessage
  * @covers ::emulateReconnect
  */
 public function testOnlyAckedMessagesComeBackOnReconnect()
 {
     $message_bank = new MessageBank();
     $acked_message = 'a-' . uniqid();
     $unacked_message = 'b-' . uniqid();
     $message_bank->produceMessage($acked_message);
     $message_bank->produceMessage($unacked_message);
     $consumed_ack_message = $message_bank->consumeMessage();
     $this->assertSame($acked_message, $consumed_ack_message->getContent());
     $consumed_ack_message->acknowledge();
     $this->assertSame($unacked_message, $message_bank->consumeMessage()->getContent());
     $message_bank->emulateReconnect();
     $this->assertSame($unacked_message, $message_bank->consumeMessage()->getContent());
 }
Esempio n. 3
0
 /**
  * @param callable $callback
  */
 public function consumeMessage(callable $callback)
 {
     $message_adapter = $this->message_bank->consumeMessage();
     $incoming_message = new IncomingMessage($message_adapter);
     $callback($incoming_message);
 }