1
0
mirror of https://github.com/danog/dns.git synced 2024-12-11 17:09:50 +01:00
dns/test/TcpSocketTest.php

58 lines
1.6 KiB
PHP
Raw Normal View History

2017-06-29 12:36:09 +02:00
<?php
namespace Amp\Dns\Test;
use Amp\Delayed;
use Amp\Dns;
use Amp\Loop;
use Amp\Promise;
use LibDNS\Messages\Message;
use LibDNS\Messages\MessageTypes;
use LibDNS\Records\QuestionFactory;
use function Amp\Promise\wait;
2019-01-25 02:27:47 +01:00
class TcpSocketTest extends SocketTest
{
protected function connect(): Promise
{
2017-06-29 12:36:09 +02:00
return Dns\Internal\TcpSocket::connect("tcp://8.8.8.8:53");
}
2019-01-25 02:27:47 +01:00
public function testTimeout()
{
2017-06-29 12:36:09 +02:00
$this->expectException(Dns\TimeoutException::class);
wait(Dns\Internal\TcpSocket::connect("tcp://8.8.8.8:53", 0));
}
2019-01-25 02:27:47 +01:00
public function testInvalidUri()
{
$this->expectException(Dns\DnsException::class);
2017-06-29 12:36:09 +02:00
wait(Dns\Internal\TcpSocket::connect("tcp://8.8.8.8"));
}
2019-01-25 02:27:47 +01:00
public function testAfterConnectionTimedOut()
{
2017-06-29 12:36:09 +02:00
Loop::run(function () {
$question = (new QuestionFactory)->create(Dns\Record::A);
$question->setName("google.com");
/** @var Dns\Internal\Socket $socket */
$socket = yield $this->connect();
/** @var Message $result */
$result = yield $socket->ask($question, 3000);
$this->assertInstanceOf(Message::class, $result);
$this->assertSame(MessageTypes::RESPONSE, $result->getType());
// Google's DNS times out really fast
yield new Delayed(3000);
$this->expectException(Dns\DnsException::class);
$this->expectExceptionMessageRegExp("(Sending the request failed|Reading from the server failed)");
2017-06-29 12:36:09 +02:00
yield $socket->ask($question, 3000);
});
}
}