Add ClientConfig and ConnectionConfig, Feature Negotiation and Authentication
This commit is contained in:
@ -2,10 +2,12 @@
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
use Nsq\Config\ClientConfig;
|
||||
use Nsq\Consumer;
|
||||
use Nsq\Message;
|
||||
use Nsq\Producer;
|
||||
use Nsq\Subscriber;
|
||||
use Nyholm\NSA;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
|
||||
final class NsqTest extends TestCase
|
||||
@ -17,10 +19,13 @@ final class NsqTest extends TestCase
|
||||
|
||||
$consumer = new Consumer(
|
||||
address: 'tcp://localhost:4150',
|
||||
heartbeatInterval: 1000,
|
||||
clientConfig: new ClientConfig(
|
||||
heartbeatInterval: 1000,
|
||||
readTimeout: 1,
|
||||
),
|
||||
);
|
||||
$subscriber = new Subscriber($consumer);
|
||||
$generator = $subscriber->subscribe(__FUNCTION__, __FUNCTION__, 1);
|
||||
$generator = $subscriber->subscribe(__FUNCTION__, __FUNCTION__);
|
||||
|
||||
/** @var null|Message $message */
|
||||
$message = $generator->current();
|
||||
@ -65,8 +70,13 @@ final class NsqTest extends TestCase
|
||||
$message = $generator->current();
|
||||
self::assertNull($message);
|
||||
|
||||
$generator->send(Subscriber::CHANGE_TIMEOUT);
|
||||
$generator->send(10.0);
|
||||
NSA::setProperty(
|
||||
NSA::getProperty($consumer, 'clientConfig'),
|
||||
'readTimeout',
|
||||
10,
|
||||
);
|
||||
|
||||
$generator->next();
|
||||
|
||||
/** @var null|Message $message */
|
||||
$message = $generator->current();
|
||||
|
@ -1,45 +0,0 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
use Nsq\Consumer;
|
||||
use Nsq\Subscriber;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
|
||||
final class SubscriberTest extends TestCase
|
||||
{
|
||||
private Subscriber $subscriber;
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
$consumer = new Consumer(
|
||||
address: 'tcp://localhost:4150',
|
||||
);
|
||||
|
||||
$this->subscriber = new Subscriber($consumer);
|
||||
}
|
||||
|
||||
public function testChangeInterval(): void
|
||||
{
|
||||
$generator = $this->subscriber->subscribe(__FUNCTION__, __FUNCTION__, 0.1);
|
||||
|
||||
self::assertSame(0.1, $generator->send(Subscriber::TIMEOUT));
|
||||
$generator->next();
|
||||
|
||||
$generator->send(Subscriber::CHANGE_TIMEOUT);
|
||||
$generator->send(0.2);
|
||||
|
||||
self::assertSame(0.2, $generator->send(Subscriber::TIMEOUT));
|
||||
}
|
||||
|
||||
public function testInvalidChangeInterval(): void
|
||||
{
|
||||
$this->expectException(InvalidArgumentException::class);
|
||||
$this->expectExceptionMessage('Timeout must be float, "string" given.');
|
||||
|
||||
$generator = $this->subscriber->subscribe(__FUNCTION__, __FUNCTION__);
|
||||
$generator->send(Subscriber::CHANGE_TIMEOUT);
|
||||
// @phpstan-ignore-next-line
|
||||
$generator->send('bla');
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user