From 3011bbeb99facbe7fe551bdcdc0b8e42ad4df7e5 Mon Sep 17 00:00:00 2001 From: Simon Frings Date: Fri, 15 Oct 2021 12:14:46 +0200 Subject: [PATCH] php8: address ReflectionParameter::getClass deprecation --- tests/FunctionCheckTypehintTest.php | 85 ++++--------------- tests/fixtures/CallbackWithTypehintClass.php | 20 +++++ .../CallbackWithUnionTypehintClass.php | 21 +++++ .../fixtures/CallbackWithoutTypehintClass.php | 18 ++++ 4 files changed, 74 insertions(+), 70 deletions(-) create mode 100644 tests/fixtures/CallbackWithTypehintClass.php create mode 100644 tests/fixtures/CallbackWithUnionTypehintClass.php create mode 100644 tests/fixtures/CallbackWithoutTypehintClass.php diff --git a/tests/FunctionCheckTypehintTest.php b/tests/FunctionCheckTypehintTest.php index 2824c403..5c78ab36 100644 --- a/tests/FunctionCheckTypehintTest.php +++ b/tests/FunctionCheckTypehintTest.php @@ -23,22 +23,22 @@ public function shouldAcceptFunctionStringCallbackWithTypehint() /** @test */ public function shouldAcceptInvokableObjectCallbackWithTypehint() { - $this->assertTrue(_checkTypehint(new TestCallbackWithTypehintClass(), new \InvalidArgumentException())); - $this->assertfalse(_checkTypehint(new TestCallbackWithTypehintClass(), new \Exception())); + $this->assertTrue(_checkTypehint(new CallbackWithTypehintClass(), new \InvalidArgumentException())); + $this->assertfalse(_checkTypehint(new CallbackWithTypehintClass(), new \Exception())); } /** @test */ public function shouldAcceptObjectMethodCallbackWithTypehint() { - $this->assertTrue(_checkTypehint([new TestCallbackWithTypehintClass(), 'testCallback'], new \InvalidArgumentException())); - $this->assertfalse(_checkTypehint([new TestCallbackWithTypehintClass(), 'testCallback'], new \Exception())); + $this->assertTrue(_checkTypehint([new CallbackWithTypehintClass(), 'testCallback'], new \InvalidArgumentException())); + $this->assertfalse(_checkTypehint([new CallbackWithTypehintClass(), 'testCallback'], new \Exception())); } /** @test */ public function shouldAcceptStaticClassCallbackWithTypehint() { - $this->assertTrue(_checkTypehint(['React\Promise\TestCallbackWithTypehintClass', 'testCallbackStatic'], new \InvalidArgumentException())); - $this->assertfalse(_checkTypehint(['React\Promise\TestCallbackWithTypehintClass', 'testCallbackStatic'], new \Exception())); + $this->assertTrue(_checkTypehint([new CallbackWithTypehintClass(), 'testCallbackStatic'], new \InvalidArgumentException())); + $this->assertfalse(_checkTypehint([new CallbackWithTypehintClass(), 'testCallbackStatic'], new \Exception())); } /** @@ -60,8 +60,8 @@ public function shouldAcceptClosureCallbackWithUnionTypehint() */ public function shouldAcceptInvokableObjectCallbackWithUnionTypehint() { - self::assertTrue(_checkTypehint(new TestCallbackWithUnionTypehintClass(), new InvalidArgumentException())); - self::assertFalse(_checkTypehint(new TestCallbackWithUnionTypehintClass(), new Exception())); + self::assertTrue(_checkTypehint(new CallbackWithUnionTypehintClass(), new \InvalidArgumentException())); + self::assertFalse(_checkTypehint(new CallbackWithUnionTypehintClass(), new \Exception())); } /** @@ -70,8 +70,8 @@ public function shouldAcceptInvokableObjectCallbackWithUnionTypehint() */ public function shouldAcceptObjectMethodCallbackWithUnionTypehint() { - self::assertTrue(_checkTypehint([new TestCallbackWithUnionTypehintClass(), 'testCallback'], new InvalidArgumentException())); - self::assertFalse(_checkTypehint([new TestCallbackWithUnionTypehintClass(), 'testCallback'], new Exception())); + self::assertTrue(_checkTypehint([new CallbackWithUnionTypehintClass(), 'testCallback'], new \InvalidArgumentException())); + self::assertFalse(_checkTypehint([new CallbackWithUnionTypehintClass(), 'testCallback'], new \Exception())); } /** @@ -80,8 +80,8 @@ public function shouldAcceptObjectMethodCallbackWithUnionTypehint() */ public function shouldAcceptStaticClassCallbackWithUnionTypehint() { - self::assertTrue(_checkTypehint([TestCallbackWithUnionTypehintClass::class, 'testCallbackStatic'], new InvalidArgumentException())); - self::assertFalse(_checkTypehint([TestCallbackWithUnionTypehintClass::class, 'testCallbackStatic'], new Exception())); + self::assertTrue(_checkTypehint(['React\Promise\CallbackWithUnionTypehintClass', 'testCallbackStatic'], new \InvalidArgumentException())); + self::assertFalse(_checkTypehint(['React\Promise\CallbackWithUnionTypehintClass', 'testCallbackStatic'], new \Exception())); } /** @test */ @@ -100,19 +100,19 @@ public function shouldAcceptFunctionStringCallbackWithoutTypehint() /** @test */ public function shouldAcceptInvokableObjectCallbackWithoutTypehint() { - $this->assertTrue(_checkTypehint(new TestCallbackWithoutTypehintClass(), new \InvalidArgumentException())); + $this->assertTrue(_checkTypehint(new CallbackWithoutTypehintClass(), new \InvalidArgumentException())); } /** @test */ public function shouldAcceptObjectMethodCallbackWithoutTypehint() { - $this->assertTrue(_checkTypehint([new TestCallbackWithoutTypehintClass(), 'testCallback'], new \InvalidArgumentException())); + $this->assertTrue(_checkTypehint([new CallbackWithoutTypehintClass(), 'testCallback'], new \InvalidArgumentException())); } /** @test */ public function shouldAcceptStaticClassCallbackWithoutTypehint() { - $this->assertTrue(_checkTypehint(['React\Promise\TestCallbackWithoutTypehintClass', 'testCallbackStatic'], new \InvalidArgumentException())); + $this->assertTrue(_checkTypehint(['React\Promise\CallbackWithoutTypehintClass', 'testCallbackStatic'], new \InvalidArgumentException())); } } @@ -123,58 +123,3 @@ function testCallbackWithTypehint(\InvalidArgumentException $e) function testCallbackWithoutTypehint() { } - -class TestCallbackWithTypehintClass -{ - public function __invoke(\InvalidArgumentException $e) - { - - } - - public function testCallback(\InvalidArgumentException $e) - { - - } - - public static function testCallbackStatic(\InvalidArgumentException $e) - { - - } -} - -if (defined('PHP_MAJOR_VERSION') && (PHP_MAJOR_VERSION >= 8)) { - eval(<<