Files
filegator/tests/backend/TestResponse.php
Chun-Sheng, Li ea6933883f Test enhancement (#18)
Wow! Thank you very much for fixing all this.

Cheers!
2019-10-22 14:06:37 +02:00

160 lines
4.0 KiB
PHP

<?php
/*
* This file is part of the FileGator package.
*
* (c) Milos Stojanovic <alcalbg@gmail.com>
*
* For the full copyright and license information, please view the LICENSE file
*/
namespace Tests;
use PHPUnit\Framework\Constraint\ArraySubset;
use PHPUnit\Util\InvalidArgumentHelper;
trait TestResponse
{
public function assertResponseJsonHas(array $data, $strict = false)
{
self::assertArraySubset(
$data,
$this->decodeResponseJson(),
$strict,
$this->assertJsonMessage($data)
);
return $this;
}
public function assertResponseJsonFragment(array $data)
{
$actual = json_encode((array) $this->decodeResponseJson());
foreach ($data as $key => $value) {
$expected = $this->jsonSearchStrings($key, $value);
$this->assertTrue(
$this->str_contains($actual, $expected),
'Unable to find JSON fragment: '.PHP_EOL.PHP_EOL.
'['.json_encode([$key => $value]).']'.PHP_EOL.PHP_EOL.
'within'.PHP_EOL.PHP_EOL.
"[{$actual}]."
);
}
return $this;
}
public function decodeResponseJson($key = null)
{
$decodedResponse = json_decode($this->response->getContent(), true);
if (is_null($decodedResponse) || $decodedResponse === false) {
$this->fail('Invalid JSON was returned from the route.');
}
return $decodedResponse;
}
public static function assertArraySubset($subset, $array, bool $checkForObjectIdentity = false, string $message = ''): void
{
if (! (\is_array($subset) || $subset instanceof ArrayAccess)) {
throw InvalidArgumentHelper::factory(
1,
'array or ArrayAccess'
);
}
if (! (\is_array($array) || $array instanceof ArrayAccess)) {
throw InvalidArgumentHelper::factory(
2,
'array or ArrayAccess'
);
}
$constraint = new ArraySubset($subset, $checkForObjectIdentity);
self::assertThat($array, $constraint, $message);
}
public function getStatusCode()
{
return $this->response->getStatusCode();
}
public function assertStatus($status)
{
$this->assertEquals(
$status,
$this->getStatusCode()
);
return $this;
}
public function assertOk()
{
$this->assertTrue(
$this->isOk(),
'Response status code ['.$this->getStatusCode().'] does not match expected 200 status code.'
);
return $this;
}
public function assertUnprocessable()
{
$this->assertTrue(
$this->isUnprocessable(),
'Response status code ['.$this->getStatusCode().'] does not match expected 422 status code.'
);
return $this;
}
public function isOk(): bool
{
return 200 === $this->getStatusCode();
}
public function isUnprocessable(): bool
{
return 422 === $this->getStatusCode();
}
public function str_contains($haystack, $needles)
{
foreach ((array) $needles as $needle) {
if ($needle !== '' && mb_strpos($haystack, $needle) !== false) {
return true;
}
}
return false;
}
protected function assertJsonMessage(array $data)
{
$expected = json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);
$actual = json_encode($this->decodeResponseJson(), JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);
return 'Unable to find JSON: '.PHP_EOL.PHP_EOL.
"[{$expected}]".PHP_EOL.PHP_EOL.
'within response JSON:'.PHP_EOL.PHP_EOL.
"[{$actual}].".PHP_EOL.PHP_EOL;
}
protected function jsonSearchStrings($key, $value)
{
$needle = substr(json_encode([$key => $value]), 1, -1);
return [
$needle.']',
$needle.'}',
$needle.',',
];
}
}