public function testDropTimedOutItems() { $time = time(); $uTime = microtime(true); $queue = new UniqueQueue($this->redis, 'test'); $processingQueue1 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time - 15); $this->redis->lpush($processingQueue1, [1, 5, 3]); $this->redis->hset('test-timeouts', $processingQueue1, $uTime - 15); $processingQueue2 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time - 10); $this->redis->lpush($processingQueue2, [1, 4, 6]); $this->redis->hset('test-timeouts', $processingQueue2, $uTime - 10); $processingQueue3 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time - 5); $this->redis->lpush($processingQueue3, [4, 7, 8]); $this->redis->hset('test-timeouts', $processingQueue3, $uTime - 5); $queue->dropTimedOutItems(7); $this->assertSame([], $this->redis->lrange('test', 0, 5)); $this->assertSame([], $this->redis->smembers('test-unique')); $this->assertSame(['8', '7', '4'], $this->redis->lrange($processingQueue3, 0, 5)); $this->assertSame([$processingQueue3 => (string) ($uTime - 5)], $this->redis->hgetall('test-timeouts')); $this->assertKeys(['test-timeouts', $processingQueue3]); $queue->dropTimedOutItems(0); $this->assertKeys([]); }
public function testDropTimedOutItems() { $time = time(); $uTime = microtime(true); $queue = new UniqueQueue($this->redis, 'test', [Base::OPT_SLAVES_SYNC_ENABLED => true, Base::OPT_SLAVES_SYNC_REQUIRED_COUNT => 5]); $processingQueue1 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time - 15); $this->redis->lpush($processingQueue1, [1, 5, 3]); $this->redis->hset('test-timeouts', $processingQueue1, $uTime - 15); $processingQueue2 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time - 10); $this->redis->lpush($processingQueue2, [1, 4, 6]); $this->redis->hset('test-timeouts', $processingQueue2, $uTime - 10); $processingQueue3 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), $time - 5); $this->redis->lpush($processingQueue3, [4, 7, 8]); $this->redis->hset('test-timeouts', $processingQueue3, $uTime - 5); try { $queue->dropTimedOutItems(7); } catch (\PhpRQ\Exception\NotEnoughSlavesSynced $e) { } $this->assertSame([], $this->redis->lrange('test', 0, 5)); $this->assertSame([], $this->redis->smembers('test-unique')); $this->assertSame(['8', '7', '4'], $this->redis->lrange($processingQueue3, 0, 5)); $this->assertSame([$processingQueue3 => (string) ($uTime - 5)], $this->redis->hgetall('test-timeouts')); $this->assertKeys(['test-timeouts', $processingQueue3]); }
public function testDropTimedOutItems() { $queue = new UniqueQueue($this->redis, 'test', [], $this->getTimeMock()); $processingQueue1 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), self::TIME_MOCK - 15); $this->redis->lpush($processingQueue1, [1, 5, 3]); $this->redis->hset('test-timeouts', $processingQueue1, self::MICRO_TIME_MOCK - 15); $processingQueue2 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), self::TIME_MOCK - 10); $this->redis->lpush($processingQueue2, [1, 4, 6]); $this->redis->hset('test-timeouts', $processingQueue2, self::MICRO_TIME_MOCK - 10); $processingQueue3 = sprintf('test-processing-%s[%d][%d]', gethostname(), getmypid(), self::TIME_MOCK - 5); $this->redis->lpush($processingQueue3, [4, 7, 8]); $this->redis->hset('test-timeouts', $processingQueue3, self::MICRO_TIME_MOCK - 5); $queue->dropTimedOutItems(7); $this->assertSame([], $this->redis->lrange('test', 0, 5)); $this->assertSame([], $this->redis->smembers('test-unique')); $this->assertSame(['8', '7', '4'], $this->redis->lrange($processingQueue3, 0, 5)); $this->assertSame([$processingQueue3 => (string) (self::MICRO_TIME_MOCK - 5)], $this->redis->hgetall('test-timeouts')); $this->assertKeys(['test-timeouts', $processingQueue3]); $queue->dropTimedOutItems(0); $this->assertKeys([]); }