From f6b0ddbbb14f0a5c6c89703866b73cc254990c99 Mon Sep 17 00:00:00 2001 From: Zombaya Date: Tue, 20 Sep 2022 14:59:04 +0200 Subject: [PATCH 1/3] Update image used in CI-tests from ubuntu-18.04 to ubuntu-22.04 --- .changes/nextrelease/ci-image-update | 7 +++++++ .github/workflows/tests.yml | 3 ++- 2 files changed, 9 insertions(+), 1 deletion(-) create mode 100644 .changes/nextrelease/ci-image-update diff --git a/.changes/nextrelease/ci-image-update b/.changes/nextrelease/ci-image-update new file mode 100644 index 0000000000..d6c173019b --- /dev/null +++ b/.changes/nextrelease/ci-image-update @@ -0,0 +1,7 @@ +[ + { + "type": "enhancement", + "category": "", + "description": "Update the image used in CI-jobs from ubuntu-18.04 to ubuntu-22.04." + } +] \ No newline at end of file diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 2d5ed13f1a..52e2dba954 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -12,12 +12,13 @@ permissions: jobs: run: - runs-on: ubuntu-18.04 + runs-on: ubuntu-22.04 strategy: #for each of the following versions of PHP, with and without --prefer-lowest matrix: php-versions: ['5.5', '5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0', '8.1'] composer-options: ['', '--prefer-lowest'] + #set the name for each job name: PHP ${{ matrix.php-versions }} ${{ matrix.composer-options }} #set up environment variables used by unit tests From cc743d1c31bd1948dc6322ca5dfc6c2bcd7977ca Mon Sep 17 00:00:00 2001 From: Zombaya Date: Tue, 20 Sep 2022 14:59:53 +0200 Subject: [PATCH 2/3] Change Aws\Test\CloudFront\SignerTest::testBadPrivateKeyPath() to support OpenSSL 3.x --- tests/CloudFront/SignerTest.php | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/tests/CloudFront/SignerTest.php b/tests/CloudFront/SignerTest.php index a8d03f4398..4357131b11 100644 --- a/tests/CloudFront/SignerTest.php +++ b/tests/CloudFront/SignerTest.php @@ -39,7 +39,14 @@ public function testBadPrivateKeyContents() { * Assert that the key file is parsed during construction */ public function testBadPrivateKeyPath() { - $this->expectExceptionMessageMatches("/PEM .*no start line/"); + preg_match('/OpenSSL (?\d+\.\d+\.\d+)/',OPENSSL_VERSION_TEXT,$matches); + // OpenSSL 1.* and 3.* do not return the same error-message + if (isset($matches['version']) && version_compare($matches['version'],'3.0','>=')) { + $this->expectExceptionMessageMatches("/error:1E08010C:DECODER routines::unsupported/"); + } else { + $this->expectExceptionMessageMatches("/PEM .*no start line/"); + } + $this->expectException(\InvalidArgumentException::class); $filename = tempnam(sys_get_temp_dir(), 'cloudfront-fake-key'); file_put_contents($filename, "Not a real private key"); From 5c697a4d804bfcd8dc425c2ed36d897d57d41fef Mon Sep 17 00:00:00 2001 From: Zombaya Date: Tue, 20 Sep 2022 22:53:08 +0200 Subject: [PATCH 3/3] Output more information about input resulting in failure in flaky Tests\Crypto\Polyfill\AesGcmTest::testCompat() --- tests/Crypto/Polyfill/AesGcmTest.php | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/tests/Crypto/Polyfill/AesGcmTest.php b/tests/Crypto/Polyfill/AesGcmTest.php index 9e44ce3758..641e26b8b7 100644 --- a/tests/Crypto/Polyfill/AesGcmTest.php +++ b/tests/Crypto/Polyfill/AesGcmTest.php @@ -2644,8 +2644,16 @@ public function testCompat() $aad, $tag2 ); - $this->assertSame(bin2hex($exp), bin2hex($got)); - $this->assertSame(bin2hex($tag1), bin2hex($tag2)); + + $failureMessage = sprintf("Failed with parameters:\n\tplaintext: %s\n\taad: %s\n\tkey: %s\n\tnonce: %s", + bin2hex($plaintext), + bin2hex($aad), + bin2hex($key), + bin2hex($nonce) + ); + + $this->assertSame(bin2hex($exp), bin2hex($got),$failureMessage); + $this->assertSame(bin2hex($tag1), bin2hex($tag2),$failureMessage); } } }