From c9485dd939e5c1209da937da8ecd9c85a048acc0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christian=20L=C3=BCck?= Date: Sun, 17 May 2020 16:39:39 +0200 Subject: [PATCH 1/2] Simplify Travis CI test matrix for Mac OS X setup --- .travis.yml | 21 +++++---------------- tests/FunctionalConnectorTest.php | 5 ++--- tests/TcpConnectorTest.php | 13 +++++-------- 3 files changed, 12 insertions(+), 27 deletions(-) diff --git a/.travis.yml b/.travis.yml index 396bc6f7..0ab25366 100644 --- a/.travis.yml +++ b/.travis.yml @@ -17,11 +17,12 @@ matrix: - php: 7.4 - php: hhvm-3.18 install: composer require phpunit/phpunit:^5 --dev --no-interaction # requires legacy phpunit - - os: osx + - name: Mac OS X + os: osx language: generic - php: 7.0 # just to look right on travis - env: - - PACKAGE: php70 + before_install: + - curl -s http://getcomposer.org/installer | php + - mv composer.phar /usr/local/bin/composer allow_failures: - php: hhvm-3.18 - os: osx @@ -29,18 +30,6 @@ matrix: sudo: false install: - # OSX install inspired by https://github.com/kiler129/TravisCI-OSX-PHP - - | - if [[ "${TRAVIS_OS_NAME}" == "osx" ]]; then - brew tap homebrew/homebrew-php - echo "Installing PHP ..." - brew install "${PACKAGE}" - brew install "${PACKAGE}"-xdebug - brew link "${PACKAGE}" - echo "Installing composer ..." - curl -s http://getcomposer.org/installer | php - mv composer.phar /usr/local/bin/composer - fi - composer install --no-interaction script: diff --git a/tests/FunctionalConnectorTest.php b/tests/FunctionalConnectorTest.php index bea825d0..be2e6240 100644 --- a/tests/FunctionalConnectorTest.php +++ b/tests/FunctionalConnectorTest.php @@ -22,17 +22,16 @@ public function connectionToTcpServerShouldSucceedWithLocalhost() $loop = Factory::create(); $server = new TcpServer(9998, $loop); - $server->on('connection', $this->expectCallableOnce()); - $server->on('connection', array($server, 'close')); $connector = new Connector($loop); $connection = Block\await($connector->connect('localhost:9998'), $loop, self::TIMEOUT); + $server->close(); + $this->assertInstanceOf('React\Socket\ConnectionInterface', $connection); $connection->close(); - $server->close(); } /** diff --git a/tests/TcpConnectorTest.php b/tests/TcpConnectorTest.php index dd10f9af..a4dbfe69 100644 --- a/tests/TcpConnectorTest.php +++ b/tests/TcpConnectorTest.php @@ -51,8 +51,6 @@ public function connectionToTcpServerShouldSucceed() $loop = Factory::create(); $server = new TcpServer(9999, $loop); - $server->on('connection', $this->expectCallableOnce()); - $server->on('connection', array($server, 'close')); $connector = new TcpConnector($loop); @@ -61,6 +59,7 @@ public function connectionToTcpServerShouldSucceed() $this->assertInstanceOf('React\Socket\ConnectionInterface', $connection); $connection->close(); + $server->close(); } /** @test */ @@ -69,7 +68,6 @@ public function connectionToTcpServerShouldSucceedWithRemoteAdressSameAsTarget() $loop = Factory::create(); $server = new TcpServer(9999, $loop); - $server->on('connection', array($server, 'close')); $connector = new TcpConnector($loop); @@ -79,6 +77,7 @@ public function connectionToTcpServerShouldSucceedWithRemoteAdressSameAsTarget() $this->assertEquals('tcp://127.0.0.1:9999', $connection->getRemoteAddress()); $connection->close(); + $server->close(); } /** @test */ @@ -87,7 +86,6 @@ public function connectionToTcpServerShouldSucceedWithLocalAdressOnLocalhost() $loop = Factory::create(); $server = new TcpServer(9999, $loop); - $server->on('connection', array($server, 'close')); $connector = new TcpConnector($loop); @@ -98,6 +96,7 @@ public function connectionToTcpServerShouldSucceedWithLocalAdressOnLocalhost() $this->assertNotEquals('tcp://127.0.0.1:9999', $connection->getLocalAddress()); $connection->close(); + $server->close(); } /** @test */ @@ -106,13 +105,13 @@ public function connectionToTcpServerShouldSucceedWithNullAddressesAfterConnecti $loop = Factory::create(); $server = new TcpServer(9999, $loop); - $server->on('connection', array($server, 'close')); $connector = new TcpConnector($loop); $connection = Block\await($connector->connect('127.0.0.1:9999'), $loop, self::TIMEOUT); /* @var $connection ConnectionInterface */ + $server->close(); $connection->close(); $this->assertNull($connection->getRemoteAddress()); @@ -165,9 +164,6 @@ public function connectionToIp6TcpServerShouldSucceed() $this->markTestSkipped('Unable to start IPv6 server socket (IPv6 not supported on this system?)'); } - $server->on('connection', $this->expectCallableOnce()); - $server->on('connection', array($server, 'close')); - $connector = new TcpConnector($loop); $connection = Block\await($connector->connect('[::1]:9999'), $loop, self::TIMEOUT); @@ -179,6 +175,7 @@ public function connectionToIp6TcpServerShouldSucceed() $this->assertNotEquals('tcp://[::1]:9999', $connection->getLocalAddress()); $connection->close(); + $server->close(); } /** @test */ From 8e2f1d7e35f4fd026aba92ffdc8265b85a3bbf19 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christian=20L=C3=BCck?= Date: Sun, 17 May 2020 21:40:54 +0200 Subject: [PATCH 2/2] Skip all TLS tests on legacy HHVM --- tests/FunctionalSecureServerTest.php | 4 ++-- tests/IntegrationTest.php | 16 ++++++++-------- tests/SecureConnectorTest.php | 4 ++-- tests/SecureIntegrationTest.php | 4 ++-- tests/SecureServerTest.php | 4 ++-- tests/ServerTest.php | 7 +++++-- 6 files changed, 21 insertions(+), 18 deletions(-) diff --git a/tests/FunctionalSecureServerTest.php b/tests/FunctionalSecureServerTest.php index f4507ca9..5dcadcbb 100644 --- a/tests/FunctionalSecureServerTest.php +++ b/tests/FunctionalSecureServerTest.php @@ -19,8 +19,8 @@ class FunctionalSecureServerTest extends TestCase public function setUp() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } } diff --git a/tests/IntegrationTest.php b/tests/IntegrationTest.php index f2913809..1af05791 100644 --- a/tests/IntegrationTest.php +++ b/tests/IntegrationTest.php @@ -36,8 +36,8 @@ public function gettingStuffFromGoogleShouldWork() /** @test */ public function gettingEncryptedStuffFromGoogleShouldWork() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } $loop = Factory::create(); @@ -55,8 +55,8 @@ public function gettingEncryptedStuffFromGoogleShouldWork() /** @test */ public function gettingEncryptedStuffFromGoogleShouldWorkIfHostIsResolvedFirst() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } $loop = Factory::create(); @@ -363,8 +363,8 @@ public function testConnectingFailsIfTimeoutIsTooSmall() public function testSelfSignedRejectsIfVerificationIsEnabled() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } $loop = Factory::create(); @@ -381,8 +381,8 @@ public function testSelfSignedRejectsIfVerificationIsEnabled() public function testSelfSignedResolvesIfVerificationIsDisabled() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } $loop = Factory::create(); diff --git a/tests/SecureConnectorTest.php b/tests/SecureConnectorTest.php index c4dd7a01..d272c79f 100644 --- a/tests/SecureConnectorTest.php +++ b/tests/SecureConnectorTest.php @@ -14,8 +14,8 @@ class SecureConnectorTest extends TestCase public function setUp() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } $this->loop = $this->getMockBuilder('React\EventLoop\LoopInterface')->getMock(); diff --git a/tests/SecureIntegrationTest.php b/tests/SecureIntegrationTest.php index c2fb94f2..1ef2f5de 100644 --- a/tests/SecureIntegrationTest.php +++ b/tests/SecureIntegrationTest.php @@ -24,8 +24,8 @@ class SecureIntegrationTest extends TestCase public function setUp() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } $this->loop = LoopFactory::create(); diff --git a/tests/SecureServerTest.php b/tests/SecureServerTest.php index 488f9f52..96a2dcee 100644 --- a/tests/SecureServerTest.php +++ b/tests/SecureServerTest.php @@ -10,8 +10,8 @@ class SecureServerTest extends TestCase { public function setUp() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } } diff --git a/tests/ServerTest.php b/tests/ServerTest.php index c1d3bc92..a091c01c 100644 --- a/tests/ServerTest.php +++ b/tests/ServerTest.php @@ -51,6 +51,9 @@ public function testConstructorCreatesExpectedTcpServer() public function testConstructorCreatesExpectedUnixServer() { + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); + } if (!in_array('unix', stream_get_transports())) { $this->markTestSkipped('Unix domain sockets (UDS) not supported on your platform (Windows?)'); } @@ -182,8 +185,8 @@ public function testEmitsConnectionWithInheritedContextOptions() public function testDoesNotEmitSecureConnectionForNewPlaintextConnectionThatIsIdle() { - if (!function_exists('stream_socket_enable_crypto')) { - $this->markTestSkipped('Not supported on your platform (outdated HHVM?)'); + if (defined('HHVM_VERSION')) { + $this->markTestSkipped('Not supported on legacy HHVM'); } $loop = Factory::create();