Passed
Push — master ( a33cf4...6335da )
by Mariano
01:54
created

ArrayToProxyResponseConverter::convertResponse()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 13
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 6

Importance

Changes 0
Metric Value
cc 2
eloc 6
nc 2
nop 3
dl 0
loc 13
ccs 0
cts 7
cp 0
crap 6
rs 10
c 0
b 0
f 0
1
<?php
2
/**
3
 * This file is part of Phiremock.
4
 *
5
 * Phiremock is free software: you can redistribute it and/or modify
6
 * it under the terms of the GNU Lesser General Public License as published by
7
 * the Free Software Foundation, either version 3 of the License, or
8
 * (at your option) any later version.
9
 *
10
 * Phiremock is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with Phiremock.  If not, see <http://www.gnu.org/licenses/>.
17
 */
18
19
namespace Mcustiel\Phiremock\Common\Utils\V2;
20
21
use Mcustiel\Phiremock\Domain\Http\Uri;
22
use Mcustiel\Phiremock\Domain\Options\Delay;
23
use Mcustiel\Phiremock\Domain\Options\ScenarioState;
24
use Mcustiel\Phiremock\Domain\ProxyResponse;
25
use Mcustiel\Phiremock\Domain\Response;
26
27
class ArrayToProxyResponseConverter extends ArrayToResponseConverter
28
{
29
    protected function convertResponse(
30
        array $responseArray,
31
        ?Delay $delay,
32
        ?ScenarioState $newScenarioState
33
    ): Response {
34
        if (empty($responseArray['proxyTo'])) {
35
            throw new \InvalidArgumentException('Trying to create a proxied response with an empty uri');
36
        }
37
38
        return new ProxyResponse(
39
            new Uri($responseArray['proxyTo']),
40
            $delay,
41
            $newScenarioState
42
        );
43
    }
44
}
45