public function testClearQueue() { $time = time(); $uTime = microtime(true); $queue = new UniqueQueue($this->redis, 'test', [UniqueQueue::OPT_DEL_MAX_CHUNK_SIZE => 2, Base::OPT_SLAVES_SYNC_ENABLED => true, Base::OPT_SLAVES_SYNC_REQUIRED_COUNT => 5]); $this->redis->lpush('test', [1, 5, 3]); $this->redis->sadd('test-unique', [1, 5, 3]); $processingQueue1 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time - 15); $this->redis->lpush($processingQueue1, [1, 8, 4]); $this->redis->hset('test-timeouts', $processingQueue1, $uTime - 15); $processingQueue2 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time - 10); $this->redis->lpush($processingQueue2, [2, 6, 7]); $this->redis->hset('test-timeouts', $processingQueue2, $uTime - 10); try { $queue->clearQueue(); } catch (\PhpRQ\Exception\NotEnoughSlavesSynced $e) { } $this->assertKeys([]); }
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([]); }