Exemplo n.º 1
0
 public function testAckItemSync()
 {
     $this->redis->zadd('test', [1 => self::TIME_MOCK - 10 + 600.1, 3 => self::TIME_MOCK - 5 + 600.1, 5 => self::TIME_MOCK - 2 + 600.1, 7 => self::TIME_MOCK + 600.1, 9 => self::TIME_MOCK + 5]);
     $pool = new Pool($this->redis, 'test', [Base::OPT_SLAVES_SYNC_ENABLED => true, Base::OPT_SLAVES_SYNC_REQUIRED_COUNT => 5], $this->getTimeMock());
     try {
         $pool->ackItem(1);
     } catch (\PhpRQ\Exception\NotEnoughSlavesSynced $e) {
     }
     $this->assertSame(5, $this->redis->zcard('test'));
     $this->assertSame(self::TIME_MOCK + 129600, (int) $this->redis->zscore('test', 1));
     $this->assertSame(round(self::TIME_MOCK - 5 + 600.1), round($this->redis->zscore('test', 3)));
     $this->assertSame(round(self::TIME_MOCK - 2 + 600.1), round($this->redis->zscore('test', 5)));
     $this->assertSame(round(self::TIME_MOCK + 600.1, 1), round($this->redis->zscore('test', 7), 1));
     $this->assertSame(self::TIME_MOCK + 5, (int) $this->redis->zscore('test', 9));
     $this->assertKeys(['test']);
 }
Exemplo n.º 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();
     $pool = new Pool($this->redis, 'test');
     $pool->addItems([$message1, $message2, $message3, $message4, $message5]);
     $this->assertSame(5, $this->redis->zcard('test'));
     $items = $this->redis->zrange('test', 0, 10);
     $this->assertTrue(in_array($message1Serialized, $items, true));
     $this->assertTrue(in_array($message2Serialized, $items, true));
     $this->assertTrue(in_array($message3Serialized, $items, true));
     $this->assertTrue(in_array($message4Serialized, $items, true));
     $this->assertTrue(in_array($message5Serialized, $items, true));
     $this->redis->zadd('test', [$message5Serialized => $time + 5]);
     $items = $pool->getItems(3);
     $this->assertSame([$message1Serialized, $message2Serialized, $message3Serialized], $items);
     $pool->ackItem($message1);
     $pool->ackItem($message3);
     $items = $pool->getItems(3);
     $this->assertSame([$message4Serialized], $items);
     $pool->ackItems([$message2Serialized]);
     $this->assertSame(5, $this->redis->zcard('test'));
     $this->assertSame($time + 129600, (int) $this->redis->zscore('test', $message1Serialized));
     $this->assertSame($time + 129600, (int) $this->redis->zscore('test', $message2Serialized));
     $this->assertSame($time + 129600, (int) $this->redis->zscore('test', $message3Serialized));
     $this->assertSame(round($time + 600.1, 1), round($this->redis->zscore('test', $message4Serialized), 1));
     $this->assertSame($time + 5, (int) $this->redis->zscore('test', $message5Serialized));
     $pool->removeItem($message5);
     $this->assertSame(5, $this->redis->zcard('test'));
     $pool->removeItem($message4);
     $this->assertSame(4, $this->redis->zcard('test'));
     $this->assertKeys(['test']);
 }