From 88ae85931768efd3aaf3cce4cb9cb54c4d157d03 Mon Sep 17 00:00:00 2001 From: Thomas Calvet Date: Wed, 10 Jan 2024 14:23:04 +0100 Subject: [PATCH] Fix MockInterface::shouldHaveReceived() and MockInterface::shouldNotHaveReceived() stub methods --- stubs/MockInterface.stub | 4 ++-- tests/Mockery/MockeryBarTest.php | 24 +++++++++++++++++++----- tests/Mockery/data/Foo.php | 3 +++ 3 files changed, 24 insertions(+), 7 deletions(-) diff --git a/stubs/MockInterface.stub b/stubs/MockInterface.stub index d7f107a..7fcff49 100644 --- a/stubs/MockInterface.stub +++ b/stubs/MockInterface.stub @@ -41,14 +41,14 @@ interface LegacyMockInterface /** * @param null|string $method - * @param null|array $args + * @param null|array|\Closure $args * @return Expectation */ public function shouldHaveReceived($method, $args = null); /** * @param null|string $method - * @param null|array $args + * @param null|array|\Closure $args * @return Expectation */ public function shouldNotHaveReceived($method, $args = null); diff --git a/tests/Mockery/MockeryBarTest.php b/tests/Mockery/MockeryBarTest.php index 0c0ad15..91dd584 100644 --- a/tests/Mockery/MockeryBarTest.php +++ b/tests/Mockery/MockeryBarTest.php @@ -9,14 +9,18 @@ class MockeryBarTest extends MockeryTestCase { - /** @var MockInterface|Foo */ + /** @var MockInterface&Foo */ private $fooMock; + /** @var MockInterface&Foo */ + private $fooSpy; + protected function setUp(): void { parent::setUp(); $this->fooMock = Mockery::mock(Foo::class); + $this->fooSpy = Mockery::spy(Foo::class); } public function testFooIsCalled(): void @@ -53,14 +57,24 @@ public function testShouldReceive(): void public function testShouldNotHaveReceived(): void { - $this->fooMock->shouldNotHaveReceived(null)->withArgs(['bar']); + $this->fooSpy->shouldNotHaveReceived(null)->withArgs(['bar']); + $this->fooSpy->doBar('ccc'); + $this->fooSpy->shouldNotHaveReceived('doBar', ['ddd']); + $this->fooSpy->shouldNotHaveReceived('doBar', static function (string $arg): bool { + return $arg !== 'ccc'; + }); } public function testShouldHaveReceived(): void { - $this->fooMock->allows('doFoo')->andReturn('bar'); - self::assertSame('bar', $this->fooMock->doFoo()); - $this->fooMock->shouldHaveReceived('doFoo')->once(); + $this->fooSpy->allows('doFoo')->andReturn('bar'); + self::assertSame('bar', $this->fooSpy->doFoo()); + $this->fooSpy->shouldHaveReceived('doFoo')->once(); + $this->fooSpy->doBar('ccc'); + $this->fooSpy->shouldHaveReceived('doBar', ['ccc']); + $this->fooSpy->shouldHaveReceived('doBar', static function (string $arg): bool { + return $arg === 'ccc'; + }); } } diff --git a/tests/Mockery/data/Foo.php b/tests/Mockery/data/Foo.php index fe5aa74..5b36ea2 100644 --- a/tests/Mockery/data/Foo.php +++ b/tests/Mockery/data/Foo.php @@ -22,4 +22,7 @@ public function doFoo(): ?string return 'foo'; } + public function doBar(string $arg): void + { + } }