예제 #1
0
 public function testRejectBatch()
 {
     $time = time();
     $queue = new UniqueQueue($this->redis, 'test', [Base::OPT_SLAVES_SYNC_ENABLED => true, Base::OPT_SLAVES_SYNC_REQUIRED_COUNT => 5]);
     $processingQueue = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time);
     $this->redis->lpush($processingQueue, [1, 5, 3, 6, 7]);
     $uTime = microtime(true);
     $this->redis->hset('test-timeouts', $processingQueue, $uTime);
     try {
         $queue->ackItem(3);
     } catch (\PhpRQ\Exception\NotEnoughSlavesSynced $e) {
     }
     try {
         $queue->rejectBatch();
     } catch (\PhpRQ\Exception\NotEnoughSlavesSynced $e) {
     }
     $this->assertSame(['7', '6', '5', '1'], $this->redis->lrange('test', 0, 10));
     $items = $this->redis->smembers('test-unique');
     $this->assertCount(4, $items);
     $this->assertTrue(in_array('1', $items, true));
     $this->assertTrue(in_array('5', $items, true));
     $this->assertTrue(in_array('6', $items, true));
     $this->assertTrue(in_array('7', $items, true));
     $this->assertKeys(['test', 'test-unique']);
 }
예제 #2
0
 public function testRealUseCaseExample2()
 {
     $message1 = new ExampleMessageObject();
     $message1->int = 1;
     $message1->float = 1.1;
     $message1->string = 'something1';
     $message1->bool = true;
     $message1Serialized = serialize($message1);
     $message2 = new ExampleMessageObject();
     $message2->int = 3;
     $message2->float = 3.3;
     $message2->string = 'something2';
     $message2->bool = false;
     $message2Serialized = serialize($message2);
     $message3 = new ExampleMessageObject();
     $message3->int = 4;
     $message3->float = 4.4;
     $message3->string = 'something3';
     $message3->bool = true;
     $message3Serialized = serialize($message3);
     $message4 = new ExampleMessageObject();
     $message4->int = 5;
     $message4->float = 5.5;
     $message4->string = 'something4';
     $message4->bool = false;
     $message4Serialized = serialize($message4);
     $message5 = new ExampleMessageObject();
     $message5->int = 6;
     $message5->float = 6.6;
     $message5->string = 'something5';
     $message5->bool = true;
     $message5Serialized = serialize($message5);
     $time = time();
     $queue = new UniqueQueue($this->redis, 'test');
     $processingQueue = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time);
     $queue->addItems([$message1, $message2, $message3, $message1, $message4, $message5]);
     $items = $queue->getItems(4);
     $this->assertSame([$message1Serialized, $message2Serialized, $message3Serialized, $message4Serialized], $items);
     $this->assertSame([$message5Serialized], $this->redis->lrange('test', 0, 5));
     $this->assertSame([$message5Serialized], $this->redis->smembers('test-unique'));
     $this->assertSame([$message4Serialized, $message3Serialized, $message2Serialized, $message1Serialized], $this->redis->lrange($processingQueue, 0, 10));
     $this->assertKeys(['test', 'test-unique', $processingQueue, 'test-timeouts']);
     $queue->ackItem($message1);
     $queue->ackItems([$message2, $message3]);
     $queue->rejectBatch();
     $this->assertSame([$message5Serialized, $message4Serialized], $this->redis->lrange('test', 0, 5));
     $items = $this->redis->smembers('test-unique');
     $this->assertCount(2, $items);
     $this->assertTrue(in_array($message4Serialized, $items, true));
     $this->assertTrue(in_array($message5Serialized, $items, true));
     $this->assertKeys(['test', 'test-unique']);
     $items = $queue->getItems(5);
     $this->assertSame([$message4Serialized, $message5Serialized], $items);
     $this->assertSame([$message5Serialized, $message4Serialized], $this->redis->lrange($processingQueue, 0, 5));
     $this->assertKeys([$processingQueue, 'test-timeouts']);
     $queue->ackItems([$message4Serialized, $message5Serialized]);
     $this->assertKeys([]);
 }