mirror of
https://github.com/Neur0toxine/pock.git
synced 2025-04-06 14:13:31 +03:00
Compare commits
6 commits
Author | SHA1 | Date | |
---|---|---|---|
a9a9c7a2b8 | |||
1de2133b12 | |||
a5f7f280f2 | |||
eef38bf466 | |||
bbfe55bc94 | |||
f455ba52d5 |
14 changed files with 151 additions and 43 deletions
2
.github/workflows/tests.yml
vendored
2
.github/workflows/tests.yml
vendored
|
@ -14,7 +14,7 @@ jobs:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
php-version: ['7.2', '7.3', '7.4', '8.0', '8.1']
|
php-version: ['7.2', '7.3', '7.4', '8.0', '8.1', '8.2']
|
||||||
steps:
|
steps:
|
||||||
- name: Check out code into the workspace
|
- name: Check out code into the workspace
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||

|

|
||||||
[](https://codecov.io/gh/Neur0toxine/pock)
|
[](https://codecov.io/gh/Neur0toxine/pock)
|
||||||
[](https://packagist.org/packages/neur0toxine/pock)
|
[](https://packagist.org/packages/neur0toxine/pock)
|
||||||
[](https://packagist.org/packages/neur0toxine/pock)
|
[](https://packagist.org/packages/neur0toxine/pock)
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
"php": ">=7.2.0",
|
"php": ">=7.2.0",
|
||||||
"ext-json": "*",
|
"ext-json": "*",
|
||||||
"psr/http-client": "^1.0",
|
"psr/http-client": "^1.0",
|
||||||
"psr/http-message": "^1.0",
|
"psr/http-message": "^1.0 || ^2.0",
|
||||||
"php-http/httplug": "^1.0 || ^2.0",
|
"php-http/httplug": "^1.0 || ^2.0",
|
||||||
"nyholm/psr7": "^1.4",
|
"nyholm/psr7": "^1.4",
|
||||||
"riverline/multipart-parser": "^2.0"
|
"riverline/multipart-parser": "^2.0"
|
||||||
|
@ -73,5 +73,11 @@
|
||||||
"@lint",
|
"@lint",
|
||||||
"@phpunit"
|
"@phpunit"
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"allow-plugins": {
|
||||||
|
"dealerdirect/phpcodesniffer-composer-installer": true,
|
||||||
|
"php-http/discovery": true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,11 +5,6 @@ parameters:
|
||||||
count: 1
|
count: 1
|
||||||
path: src/Client.php
|
path: src/Client.php
|
||||||
|
|
||||||
-
|
|
||||||
message: "#^Method Pock\\\\Comparator\\\\ComparatorLocator\\:\\:get\\(\\) should return Pock\\\\Comparator\\\\ComparatorInterface but returns object\\.$#"
|
|
||||||
count: 1
|
|
||||||
path: src/Comparator/ComparatorLocator.php
|
|
||||||
|
|
||||||
-
|
-
|
||||||
message: "#^Static property Pock\\\\Comparator\\\\ComparatorLocator\\:\\:\\$comparators \\(array\\<Pock\\\\Comparator\\\\ComparatorInterface\\>\\) does not accept array\\<object\\>\\.$#"
|
message: "#^Static property Pock\\\\Comparator\\\\ComparatorLocator\\:\\:\\$comparators \\(array\\<Pock\\\\Comparator\\\\ComparatorInterface\\>\\) does not accept array\\<object\\>\\.$#"
|
||||||
count: 1
|
count: 1
|
||||||
|
@ -20,21 +15,6 @@ parameters:
|
||||||
count: 3
|
count: 3
|
||||||
path: src/Comparator/ComparatorLocator.php
|
path: src/Comparator/ComparatorLocator.php
|
||||||
|
|
||||||
-
|
|
||||||
message: "#^Parameter \\#1 \\$object_or_class of function method_exists expects object\\|string, mixed given\\.$#"
|
|
||||||
count: 1
|
|
||||||
path: src/Creator/AbstractJmsSerializerCreator.php
|
|
||||||
|
|
||||||
-
|
|
||||||
message: "#^Parameter \\#2 \\$encoders of class Symfony\\\\Component\\\\Serializer\\\\Serializer constructor expects array\\<Symfony\\\\Component\\\\Serializer\\\\Encoder\\\\DecoderInterface\\|Symfony\\\\Component\\\\Serializer\\\\Encoder\\\\EncoderInterface\\>, array\\<int, object\\> given\\.$#"
|
|
||||||
count: 1
|
|
||||||
path: src/Creator/AbstractSymfonySerializerCreator.php
|
|
||||||
|
|
||||||
-
|
|
||||||
message: "#^Method Pock\\\\Factory\\\\CallbackReplyFactory\\:\\:createReply\\(\\) should return Psr\\\\Http\\\\Message\\\\ResponseInterface but returns mixed\\.$#"
|
|
||||||
count: 1
|
|
||||||
path: src/Factory/CallbackReplyFactory.php
|
|
||||||
|
|
||||||
-
|
-
|
||||||
message: "#^Unsafe access to private property Pock\\\\Factory\\\\JsonSerializerFactory\\:\\:\\$mainSerializer through static\\:\\:\\.$#"
|
message: "#^Unsafe access to private property Pock\\\\Factory\\\\JsonSerializerFactory\\:\\:\\$mainSerializer through static\\:\\:\\.$#"
|
||||||
count: 2
|
count: 2
|
||||||
|
@ -46,9 +26,9 @@ parameters:
|
||||||
path: src/Factory/XmlSerializerFactory.php
|
path: src/Factory/XmlSerializerFactory.php
|
||||||
|
|
||||||
-
|
-
|
||||||
message: "#^Method Pock\\\\Matchers\\\\CallbackRequestMatcher\\:\\:matches\\(\\) should return bool but returns mixed\\.$#"
|
message: "#^Parameter \\#4 \\$flags of function preg_match expects TFlags of 0\\|256\\|512\\|768, int given\\.$#"
|
||||||
count: 1
|
count: 1
|
||||||
path: src/Matchers/CallbackRequestMatcher.php
|
path: src/Matchers/AbstractRegExpMatcher.php
|
||||||
|
|
||||||
-
|
-
|
||||||
message: "#^Unsafe call to private method Pock\\\\Matchers\\\\ExactHeadersMatcher\\:\\:headerValuesEqual\\(\\) through static\\:\\:\\.$#"
|
message: "#^Unsafe call to private method Pock\\\\Matchers\\\\ExactHeadersMatcher\\:\\:headerValuesEqual\\(\\) through static\\:\\:\\.$#"
|
||||||
|
@ -66,9 +46,9 @@ parameters:
|
||||||
path: src/Matchers/JsonBodyMatcher.php
|
path: src/Matchers/JsonBodyMatcher.php
|
||||||
|
|
||||||
-
|
-
|
||||||
message: "#^Method Pock\\\\Matchers\\\\MultipartFormDataMatcher\\:\\:matches\\(\\) should return bool but returns mixed\\.$#"
|
message: "#^Method Pock\\\\Matchers\\\\QueryMatcher\\:\\:parseQuery\\(\\) should return array\\<string, mixed\\> but returns array\\<int\\|string, array\\|string\\>\\.$#"
|
||||||
count: 1
|
count: 1
|
||||||
path: src/Matchers/MultipartFormDataMatcher.php
|
path: src/Matchers/QueryMatcher.php
|
||||||
|
|
||||||
-
|
-
|
||||||
message: "#^Method Pock\\\\Matchers\\\\XmlBodyMatcher\\:\\:sortXmlTags\\(\\) should return string but returns string\\|null\\.$#"
|
message: "#^Method Pock\\\\Matchers\\\\XmlBodyMatcher\\:\\:sortXmlTags\\(\\) should return string but returns string\\|null\\.$#"
|
||||||
|
@ -129,4 +109,3 @@ parameters:
|
||||||
message: "#^Parameter \\#3 \\$depth of function json_encode expects int\\<1, max\\>, int given\\.$#"
|
message: "#^Parameter \\#3 \\$depth of function json_encode expects int\\<1, max\\>, int given\\.$#"
|
||||||
count: 1
|
count: 1
|
||||||
path: src/PockResponseBuilder.php
|
path: src/PockResponseBuilder.php
|
||||||
|
|
||||||
|
|
|
@ -50,8 +50,12 @@ class RecursiveArrayComparator implements ComparatorInterface
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($first as $key => $value) {
|
foreach ($first as $key => $value) {
|
||||||
if (is_array($value) && !self::recursiveCompareArrays($value, $second[$key])) {
|
if (is_array($value)) {
|
||||||
return false;
|
if (!is_array($second[$key]) || !self::recursiveCompareArrays($value, $second[$key])) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($value !== $second[$key]) {
|
if ($value !== $second[$key]) {
|
||||||
|
|
|
@ -47,11 +47,12 @@ class RecursiveLtrArrayComparator extends RecursiveArrayComparator
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($needle as $key => $value) {
|
foreach ($needle as $key => $value) {
|
||||||
if (
|
if (is_array($value)) {
|
||||||
is_array($value) &&
|
if (!is_array($haystack[$key]) || !self::recursiveCompareArrays($value, $haystack[$key])) {
|
||||||
(!is_array($haystack[$key]) || !self::recursiveCompareArrays($value, $haystack[$key]))
|
return false;
|
||||||
) {
|
}
|
||||||
return false;
|
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($value !== $haystack[$key]) {
|
if ($value !== $haystack[$key]) {
|
||||||
|
|
|
@ -30,12 +30,12 @@ abstract class AbstractJmsSerializerCreator implements SerializerCreatorInterfac
|
||||||
{
|
{
|
||||||
if (
|
if (
|
||||||
class_exists(self::BUILDER_CLASS) &&
|
class_exists(self::BUILDER_CLASS) &&
|
||||||
method_exists(self::BUILDER_CLASS, 'create')
|
method_exists(self::BUILDER_CLASS, 'create') // @phpstan-ignore-line
|
||||||
) {
|
) {
|
||||||
try {
|
try {
|
||||||
$builder = call_user_func([self::BUILDER_CLASS, 'create']);
|
$builder = call_user_func([self::BUILDER_CLASS, 'create']); // @phpstan-ignore-line
|
||||||
|
|
||||||
if (null !== $builder && method_exists($builder, 'build')) {
|
if (null !== $builder && method_exists($builder, 'build')) { // @phpstan-ignore-line
|
||||||
return new JmsSerializerAdapter($builder->build(), static::getFormat()); // @phpstan-ignore-line
|
return new JmsSerializerAdapter($builder->build(), static::getFormat()); // @phpstan-ignore-line
|
||||||
}
|
}
|
||||||
} catch (Throwable $throwable) {
|
} catch (Throwable $throwable) {
|
||||||
|
|
|
@ -34,7 +34,7 @@ abstract class AbstractSymfonySerializerCreator implements SerializerCreatorInte
|
||||||
$encoder = static::getEncoderClass();
|
$encoder = static::getEncoderClass();
|
||||||
|
|
||||||
return new SymfonySerializerAdapter(
|
return new SymfonySerializerAdapter(
|
||||||
new $serializer([new $normalizer()], [new $encoder()]),
|
new $serializer([new $normalizer()], [new $encoder()]), // @phpstan-ignore-line
|
||||||
static::getFormat()
|
static::getFormat()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -79,5 +79,7 @@ class BodyMatcher implements RequestMatcherInterface
|
||||||
if (is_resource($contents)) {
|
if (is_resource($contents)) {
|
||||||
return static::readAllResource($contents);
|
return static::readAllResource($contents);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return '';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
namespace Pock\Matchers;
|
namespace Pock\Matchers;
|
||||||
|
|
||||||
use Pock\Comparator\ComparatorLocator;
|
use Pock\Comparator\ComparatorLocator;
|
||||||
use Pock\Comparator\RecursiveLtrArrayComparator;
|
use Pock\Comparator\RecursiveArrayComparator;
|
||||||
use Pock\Traits\SeekableStreamDataExtractor;
|
use Pock\Traits\SeekableStreamDataExtractor;
|
||||||
use Psr\Http\Message\RequestInterface;
|
use Psr\Http\Message\RequestInterface;
|
||||||
|
|
||||||
|
@ -35,6 +35,6 @@ class FormDataMatcher extends QueryMatcher
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ComparatorLocator::get(RecursiveLtrArrayComparator::class)->compare($this->query, $query);
|
return ComparatorLocator::get(RecursiveArrayComparator::class)->compare($this->query, $query);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
75
tests/src/Comparator/RecursiveArrayComparatorTest.php
Normal file
75
tests/src/Comparator/RecursiveArrayComparatorTest.php
Normal file
|
@ -0,0 +1,75 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PHP version 7.3
|
||||||
|
*
|
||||||
|
* @category RecursiveArrayComparatorTest
|
||||||
|
* @package Pock\Tests\Comparator
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Pock\Tests\Comparator;
|
||||||
|
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
use Pock\Comparator\ComparatorLocator;
|
||||||
|
use Pock\Comparator\RecursiveArrayComparator;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class RecursiveArrayComparatorTest
|
||||||
|
*
|
||||||
|
* @category RecursiveArrayComparatorTest
|
||||||
|
* @package Pock\Tests\Comparator
|
||||||
|
*/
|
||||||
|
class RecursiveArrayComparatorTest extends TestCase
|
||||||
|
{
|
||||||
|
public function testMatches(): void
|
||||||
|
{
|
||||||
|
$needle = [
|
||||||
|
'filter' => [
|
||||||
|
'createdAtFrom' => '2020-01-01 00:00:00',
|
||||||
|
'createdAtTo' => '2021-08-01 00:00:00',
|
||||||
|
],
|
||||||
|
'test' => ''
|
||||||
|
];
|
||||||
|
$haystack = [
|
||||||
|
'filter' => [
|
||||||
|
'createdAtFrom' => '2020-01-01 00:00:00',
|
||||||
|
'createdAtTo' => '2021-08-01 00:00:00',
|
||||||
|
],
|
||||||
|
'test' => ''
|
||||||
|
];
|
||||||
|
|
||||||
|
self::assertTrue(ComparatorLocator::get(RecursiveArrayComparator::class)->compare($needle, $haystack));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testNotMatches(): void
|
||||||
|
{
|
||||||
|
$needle = [
|
||||||
|
'filter' => [
|
||||||
|
'createdAtFrom' => '2020-01-01 00:00:00',
|
||||||
|
'createdAtTo' => '2021-08-01 00:00:00',
|
||||||
|
],
|
||||||
|
'test2' => [1]
|
||||||
|
];
|
||||||
|
$haystack = [
|
||||||
|
'filter' => [
|
||||||
|
'createdAtFrom' => '2020-01-01 00:00:00',
|
||||||
|
'createdAtTo' => '2021-08-01 00:00:00',
|
||||||
|
],
|
||||||
|
'test2' => 1
|
||||||
|
];
|
||||||
|
|
||||||
|
self::assertFalse(ComparatorLocator::get(RecursiveArrayComparator::class)->compare($needle, $haystack));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testNotMatchesKeyPositions(): void
|
||||||
|
{
|
||||||
|
$needle = [
|
||||||
|
'source' => json_decode('{"medium":"tiktok","source":"Test Ad","campaign":"Test Campaign"}', true)
|
||||||
|
];
|
||||||
|
$haystack = [
|
||||||
|
'source' => json_decode('{"source":"Test Ad","medium":"tiktok","campaign":"Test Campaign"}', true)
|
||||||
|
];
|
||||||
|
|
||||||
|
self::assertTrue(ComparatorLocator::get(RecursiveArrayComparator::class)->compare($needle, $haystack));
|
||||||
|
}
|
||||||
|
}
|
|
@ -39,4 +39,37 @@ class RecursiveArrayLtrComparatorTest extends TestCase
|
||||||
|
|
||||||
self::assertTrue(ComparatorLocator::get(RecursiveLtrArrayComparator::class)->compare($needle, $haystack));
|
self::assertTrue(ComparatorLocator::get(RecursiveLtrArrayComparator::class)->compare($needle, $haystack));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testNotMatches(): void
|
||||||
|
{
|
||||||
|
$needle = [
|
||||||
|
'filter' => [
|
||||||
|
'createdAtFrom' => '2020-01-01 00:00:00',
|
||||||
|
'createdAtTo' => '2021-08-01 00:00:00',
|
||||||
|
],
|
||||||
|
'test2' => [1]
|
||||||
|
];
|
||||||
|
$haystack = [
|
||||||
|
'filter' => [
|
||||||
|
'createdAtFrom' => '2020-01-01 00:00:00',
|
||||||
|
'createdAtTo' => '2021-08-01 00:00:00',
|
||||||
|
],
|
||||||
|
'test2' => 1,
|
||||||
|
'test' => ''
|
||||||
|
];
|
||||||
|
|
||||||
|
self::assertFalse(ComparatorLocator::get(RecursiveLtrArrayComparator::class)->compare($needle, $haystack));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testNotMatchesKeyPositions(): void
|
||||||
|
{
|
||||||
|
$needle = [
|
||||||
|
'source' => json_decode('{"medium":"tiktok","source":"Test Ad","campaign":"Test Campaign"}', true)
|
||||||
|
];
|
||||||
|
$haystack = [
|
||||||
|
'source' => json_decode('{"source":"Test Ad","medium":"tiktok","campaign":"Test Campaign"}', true)
|
||||||
|
];
|
||||||
|
|
||||||
|
self::assertTrue(ComparatorLocator::get(RecursiveLtrArrayComparator::class)->compare($needle, $haystack));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,11 +44,19 @@ class FormDataMatcherTest extends PockTestCase
|
||||||
self::assertFalse($matcher->matches($request));
|
self::assertFalse($matcher->matches($request));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testMatches(): void
|
public function testNoMatchesExtraValues(): void
|
||||||
{
|
{
|
||||||
$matcher = new FormDataMatcher(['field2' => 'value2']);
|
$matcher = new FormDataMatcher(['field2' => 'value2']);
|
||||||
$request = self::getRequestWithBody('field1=value1&field2=value2');
|
$request = self::getRequestWithBody('field1=value1&field2=value2');
|
||||||
|
|
||||||
|
self::assertFalse($matcher->matches($request));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testMatches(): void
|
||||||
|
{
|
||||||
|
$matcher = new FormDataMatcher(['field1' => 'value1', 'field2' => 'value2']);
|
||||||
|
$request = self::getRequestWithBody('field1=value1&field2=value2');
|
||||||
|
|
||||||
self::assertTrue($matcher->matches($request));
|
self::assertTrue($matcher->matches($request));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -681,7 +681,7 @@ EOF;
|
||||||
$builder = new PockBuilder();
|
$builder = new PockBuilder();
|
||||||
$builder->matchMethod(RequestMethod::GET)
|
$builder->matchMethod(RequestMethod::GET)
|
||||||
->matchUri(self::TEST_URI)
|
->matchUri(self::TEST_URI)
|
||||||
->matchFormData(['field2' => 'value2'])
|
->matchFormData(['field1' => 'value1', 'field2' => 'value2'])
|
||||||
->reply(200);
|
->reply(200);
|
||||||
|
|
||||||
$response = $builder->getClient()->sendRequest(self::getRequestWithBody('field1=value1&field2=value2'));
|
$response = $builder->getClient()->sendRequest(self::getRequestWithBody('field1=value1&field2=value2'));
|
||||||
|
|
Loading…
Add table
Reference in a new issue