From 3bcd1fcbb1dfbc256baf4d51f74b6f5c77288c37 Mon Sep 17 00:00:00 2001 From: Brent Shaffer Date: Fri, 12 Apr 2024 10:04:01 -0600 Subject: [PATCH] chore: drop support for PHP 7.4 (#538) --- .github/workflows/docs.yml | 4 ++-- .github/workflows/tests.yml | 6 +++--- composer.json | 15 +++++++------- src/Cache/Item.php | 1 + src/Cache/MemoryCacheItemPool.php | 3 +-- src/Cache/SysVCacheItemPool.php | 3 +-- tests/BaseTest.php | 9 --------- tests/Cache/ItemTest.php | 26 ++++++++----------------- tests/Cache/MemoryCacheItemPoolTest.php | 7 ++++--- tests/Cache/SysVCacheItemPoolTest.php | 7 ++++--- tests/Cache/sysv_cache_creator.php | 7 +------ 11 files changed, 33 insertions(+), 55 deletions(-) diff --git a/.github/workflows/docs.yml b/.github/workflows/docs.yml index 52981277c..59674b926 100644 --- a/.github/workflows/docs.yml +++ b/.github/workflows/docs.yml @@ -5,7 +5,7 @@ on: - main tags: - "*" - workflow_dispatch: + workflow_dispatch: jobs: docs: @@ -18,7 +18,7 @@ jobs: - name: Setup PHP uses: shivammathur/setup-php@v2 with: - php-version: 7.4 + php-version: 8.1 - name: Install Dependencies uses: nick-invision/retry@v3 with: diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index d0643c514..8251dda2f 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -3,7 +3,7 @@ on: push: branches: [ main ] pull_request: - + permissions: contents: read jobs: @@ -11,7 +11,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - php: [ "7.4", "8.0", "8.1", "8.2", "8.3" ] + php: [ "8.0", "8.1", "8.2", "8.3" ] name: PHP ${{matrix.php }} Unit Test steps: - uses: actions/checkout@v4 @@ -35,7 +35,7 @@ jobs: - name: Setup PHP uses: shivammathur/setup-php@v2 with: - php-version: "7.4" + php-version: "8.0" - name: Install Dependencies uses: nick-invision/retry@v3 with: diff --git a/composer.json b/composer.json index 88a698d7b..338e46f37 100644 --- a/composer.json +++ b/composer.json @@ -9,21 +9,22 @@ "docs": "https://googleapis.github.io/google-auth-library-php/main/" }, "require": { - "php": "^7.4||^8.0", + "php": "^8.0", "firebase/php-jwt": "^6.0", - "guzzlehttp/guzzle": "^6.5.8||^7.4.5", + "guzzlehttp/guzzle": "^7.4.5", "guzzlehttp/psr7": "^2.4.5", "psr/http-message": "^1.1||^2.0", - "psr/cache": "^1.0||^2.0||^3.0" + "psr/cache": "^2.0||^3.0" }, "require-dev": { "guzzlehttp/promises": "^2.0", "squizlabs/php_codesniffer": "^3.5", - "phpunit/phpunit": "^9.0.0", - "phpspec/prophecy-phpunit": "^2.0", + "phpunit/phpunit": "^9.6", + "phpspec/prophecy-phpunit": "^2.1", "sebastian/comparator": ">=1.2.3", - "phpseclib/phpseclib": "^3.0", - "kelvinmo/simplejwt": "0.7.1" + "phpseclib/phpseclib": "^3.0.35", + "kelvinmo/simplejwt": "0.7.1", + "webmozart/assert": "^1.11" }, "suggest": { "phpseclib/phpseclib": "May be used in place of OpenSSL for signing strings or for token management. Please require version ^2." diff --git a/src/Cache/Item.php b/src/Cache/Item.php index 8628c5480..ff85afa71 100644 --- a/src/Cache/Item.php +++ b/src/Cache/Item.php @@ -28,6 +28,7 @@ * * This class will be used by MemoryCacheItemPool and SysVCacheItemPool * on PHP 7.4 and below. It is compatible with psr/cache 1.0 and 2.0 (PSR-6). + * @deprecated * @see TypedItem for compatiblity with psr/cache 3.0. */ final class Item implements CacheItemInterface diff --git a/src/Cache/MemoryCacheItemPool.php b/src/Cache/MemoryCacheItemPool.php index 2c7a9d574..1917cf144 100644 --- a/src/Cache/MemoryCacheItemPool.php +++ b/src/Cache/MemoryCacheItemPool.php @@ -57,9 +57,8 @@ public function getItem($key): CacheItemInterface public function getItems(array $keys = []): iterable { $items = []; - $itemClass = \PHP_VERSION_ID >= 80000 ? TypedItem::class : Item::class; foreach ($keys as $key) { - $items[$key] = $this->hasItem($key) ? clone $this->items[$key] : new $itemClass($key); + $items[$key] = $this->hasItem($key) ? clone $this->items[$key] : new TypedItem($key); } return $items; diff --git a/src/Cache/SysVCacheItemPool.php b/src/Cache/SysVCacheItemPool.php index 39a8c30fd..7821d6b09 100644 --- a/src/Cache/SysVCacheItemPool.php +++ b/src/Cache/SysVCacheItemPool.php @@ -110,11 +110,10 @@ public function getItems(array $keys = []): iterable { $this->loadItems(); $items = []; - $itemClass = \PHP_VERSION_ID >= 80000 ? TypedItem::class : Item::class; foreach ($keys as $key) { $items[$key] = $this->hasItem($key) ? clone $this->items[$key] : - new $itemClass($key); + new TypedItem($key); } return $items; } diff --git a/tests/BaseTest.php b/tests/BaseTest.php index e38e3edf1..26b127dc1 100644 --- a/tests/BaseTest.php +++ b/tests/BaseTest.php @@ -41,13 +41,4 @@ public function getValidKeyName($key) { return preg_replace('|[^a-zA-Z0-9_\.! ]|', '', $key); } - - protected function getCacheItemClass() - { - if (\PHP_VERSION_ID >= 80000) { - return 'Google\Auth\Cache\TypedItem'; - } - - return 'Google\Auth\Cache\Item'; - } } diff --git a/tests/Cache/ItemTest.php b/tests/Cache/ItemTest.php index 8917f8b32..08902599c 100644 --- a/tests/Cache/ItemTest.php +++ b/tests/Cache/ItemTest.php @@ -17,31 +17,21 @@ namespace Google\Auth\Tests\Cache; -use Google\Auth\Cache\Item; use Google\Auth\Cache\TypedItem; use PHPUnit\Framework\TestCase; class ItemTest extends TestCase { - public function getItem($key) - { - if (\PHP_VERSION_ID >= 80000) { - return new TypedItem($key); - } - - return new Item($key); - } - public function testGetsKey() { - $key = 'item'; + $item = new TypedItem('item'); - $this->assertEquals($key, $this->getItem($key)->getKey()); + $this->assertEquals('item', $item->getKey()); } public function testGetsNull() { - $item = $this->getItem('item'); + $item = new TypedItem('item'); $this->assertNull($item->get()); $this->assertFalse($item->isHit()); @@ -50,7 +40,7 @@ public function testGetsNull() public function testGetsValue() { $value = 'value'; - $item = $this->getItem('item'); + $item = new TypedItem('item'); $item->set($value); $this->assertEquals('value', $item->get()); @@ -61,7 +51,7 @@ public function testGetsValue() */ public function testSetsValue($value) { - $item = $this->getItem('item'); + $item = new TypedItem('item'); $item->set($value); $this->assertEquals($value, $item->get()); @@ -82,7 +72,7 @@ public function values() public function testIsHit() { - $item = $this->getItem('item'); + $item = new TypedItem('item'); $this->assertFalse($item->isHit()); @@ -93,7 +83,7 @@ public function testIsHit() public function testExpiresAt() { - $item = $this->getItem('item'); + $item = new TypedItem('item'); $item->set('value'); $item->expiresAt(new \DateTime('now + 1 hour')); @@ -110,7 +100,7 @@ public function testExpiresAt() public function testExpiresAfter() { - $item = $this->getItem('item'); + $item = new TypedItem('item'); $item->set('value'); $item->expiresAfter(30); diff --git a/tests/Cache/MemoryCacheItemPoolTest.php b/tests/Cache/MemoryCacheItemPoolTest.php index 6a8aff038..6ae2a998c 100644 --- a/tests/Cache/MemoryCacheItemPoolTest.php +++ b/tests/Cache/MemoryCacheItemPoolTest.php @@ -18,6 +18,7 @@ namespace Google\Auth\Tests\Cache; use Google\Auth\Cache\MemoryCacheItemPool; +use Google\Auth\Cache\TypedItem; use Google\Auth\Tests\BaseTest; use Psr\Cache\InvalidArgumentException; @@ -43,7 +44,7 @@ public function testGetsFreshItem() { $item = $this->pool->getItem('item'); - $this->assertInstanceOf($this->getCacheItemClass(), $item); + $this->assertInstanceOf(TypedItem::class, $item); $this->assertNull($item->get()); $this->assertFalse($item->isHit()); } @@ -55,7 +56,7 @@ public function testGetsExistingItem() $this->saveItem($key, $value); $item = $this->pool->getItem($key); - $this->assertInstanceOf($this->getCacheItemClass(), $item); + $this->assertInstanceOf(TypedItem::class, $item); $this->assertEquals($value, $item->get()); $this->assertTrue($item->isHit()); } @@ -66,7 +67,7 @@ public function testGetsMultipleItems() $items = $this->pool->getItems($keys); $this->assertEquals($keys, array_keys($items)); - $this->assertContainsOnlyInstancesOf($this->getCacheItemClass(), $items); + $this->assertContainsOnlyInstancesOf(TypedItem::class, $items); } public function testHasItem() diff --git a/tests/Cache/SysVCacheItemPoolTest.php b/tests/Cache/SysVCacheItemPoolTest.php index 46f7812c1..2c2d5be2e 100644 --- a/tests/Cache/SysVCacheItemPoolTest.php +++ b/tests/Cache/SysVCacheItemPoolTest.php @@ -18,6 +18,7 @@ namespace Google\Auth\Tests\Cache; use Google\Auth\Cache\SysVCacheItemPool; +use Google\Auth\Cache\TypedItem; use Google\Auth\Tests\BaseTest; class SysVCacheItemPoolTest extends BaseTest @@ -48,7 +49,7 @@ public function testGetsFreshItem() { $item = $this->pool->getItem('item'); - $this->assertInstanceOf($this->getCacheItemClass(), $item); + $this->assertInstanceOf(TypedItem::class, $item); $this->assertNull($item->get()); $this->assertFalse($item->isHit()); } @@ -70,7 +71,7 @@ public function testGetsExistingItem() $this->saveItem($key, $value); $item = $this->pool->getItem($key); - $this->assertInstanceOf($this->getCacheItemClass(), $item); + $this->assertInstanceOf(TypedItem::class, $item); $this->assertEquals($value, $item->get()); $this->assertTrue($item->isHit()); } @@ -81,7 +82,7 @@ public function testGetsMultipleItems() $items = $this->pool->getItems($keys); $this->assertEquals($keys, array_keys($items)); - $this->assertContainsOnlyInstancesOf($this->getCacheItemClass(), $items); + $this->assertContainsOnlyInstancesOf(TypedItem::class, $items); } public function testHasItem() diff --git a/tests/Cache/sysv_cache_creator.php b/tests/Cache/sysv_cache_creator.php index 3231c4301..df1aa09f5 100644 --- a/tests/Cache/sysv_cache_creator.php +++ b/tests/Cache/sysv_cache_creator.php @@ -19,17 +19,12 @@ require_once __DIR__ . '/../../vendor/autoload.php'; -use Google\Auth\Cache\Item; use Google\Auth\Cache\SysVCacheItemPool; use Google\Auth\Cache\TypedItem; $value = $argv[1]; // Use the same variableKey in the test. $pool = new SysVCacheItemPool(['variableKey' => 99]); -if (\PHP_VERSION_ID >= 80000) { - $item = new TypedItem('separate-process-item'); -} else { - $item = new Item('separate-process-item'); -} +$item = new TypedItem('separate-process-item'); $item->set($value); $pool->save($item);