diff --git a/src/Illuminate/Foundation/Testing/TestResponse.php b/src/Illuminate/Foundation/Testing/TestResponse.php index 1f77c47d443b..776aececcb0c 100644 --- a/src/Illuminate/Foundation/Testing/TestResponse.php +++ b/src/Illuminate/Foundation/Testing/TestResponse.php @@ -253,6 +253,32 @@ public function assertSee($value) return $this; } + /** + * Assert that the given strings are contained in order within the response. + * + * @param array $values + * @return $this + */ + public function assertSeeInOrder(array $values) + { + $position = -1; + + foreach ($values as $value) { + $valuePosition = mb_strpos($this->getContent(), $value); + + if ($valuePosition === false || $valuePosition < $position) { + PHPUnit::fail( + 'Failed asserting that \''.$this->getContent(). + '\' contains "'.$value.'" in specified order.' + ); + } + + $position = $valuePosition; + } + + return $this; + } + /** * Assert that the given string is contained within the response text. * @@ -266,6 +292,32 @@ public function assertSeeText($value) return $this; } + /** + * Assert that the given strings are contained in order within the response text. + * + * @param array $values + * @return $this + */ + public function assertSeeTextInOrder(array $values) + { + $position = -1; + + foreach ($values as $value) { + $valuePosition = mb_strpos(strip_tags($this->getContent()), $value); + + if ($valuePosition === false || $valuePosition < $position) { + PHPUnit::fail( + 'Failed asserting that \''.strip_tags($this->getContent()). + '\' contains "'.$value.'" in specified order.' + ); + } + + $position = $valuePosition; + } + + return $this; + } + /** * Assert that the given string is not contained within the response. * diff --git a/tests/Foundation/FoundationTestResponseTest.php b/tests/Foundation/FoundationTestResponseTest.php index d04b4ac2f41a..bdece6dfe012 100644 --- a/tests/Foundation/FoundationTestResponseTest.php +++ b/tests/Foundation/FoundationTestResponseTest.php @@ -41,6 +41,28 @@ public function testAssertViewHas() $response->assertViewHas('foo'); } + public function testAssertSeeInOrder() + { + $baseResponse = tap(new Response, function ($response) { + $response->setContent(\Mockery::mock(View::class, [ + 'render' => '', + ])); + }); + + $response = TestResponse::fromBaseResponse($baseResponse); + + $response->assertSeeInOrder(['foo', 'bar', 'baz']); + + try { + $response->assertSeeInOrder(['baz', 'bar', 'foo']); + $response->assertSeeInOrder(['foo', 'qux', 'bar', 'baz']); + } catch (\PHPUnit\Framework\AssertionFailedError $e) { + return; + } + + TestCase::fail('Assertion was expected to fail.'); + } + public function testAssertSeeText() { $baseResponse = tap(new Response, function ($response) { @@ -54,6 +76,28 @@ public function testAssertSeeText() $response->assertSeeText('foobar'); } + public function testAssertSeeTextInOrder() + { + $baseResponse = tap(new Response, function ($response) { + $response->setContent(\Mockery::mock(View::class, [ + 'render' => 'foobar baz', + ])); + }); + + $response = TestResponse::fromBaseResponse($baseResponse); + + $response->assertSeeTextInOrder(['foobar', 'baz']); + + try { + $response->assertSeeTextInOrder(['baz', 'foobar']); + $response->assertSeeTextInOrder(['foobar', 'qux', 'baz']); + } catch (\PHPUnit\Framework\AssertionFailedError $e) { + return; + } + + TestCase::fail('Assertion was expected to fail.'); + } + public function testAssertHeader() { $baseResponse = tap(new Response, function ($response) {