HeaderExistsExpectation   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 14
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 3
eloc 6
c 1
b 0
f 0
dl 0
loc 14
ccs 6
cts 6
cp 1
rs 10

1 Method

Rating   Name   Duplication   Size   Complexity  
A from() 0 12 3
1
<?php
2
3
namespace EasyHttp\MockBuilder\Expectations;
4
5
use EasyHttp\MockBuilder\Contracts\ExpectationMatcher;
6
use EasyHttp\MockBuilder\Expectation;
7
use GuzzleHttp\Promise\RejectedPromise;
8
use Psr\Http\Message\RequestInterface;
9
10
class HeaderExistsExpectation implements ExpectationMatcher
11
{
12 121
    public static function from(Expectation $expectation): callable
13
    {
14 121
        return function ($request) use ($expectation) {
15
            /** @var RequestInterface $request */
16
17 72
            foreach ($expectation->emptyHeadersIterator() as $param => $value) {
18 7
                if (!$request->hasHeader($param)) {
0 ignored issues
show
Bug introduced by
It seems like $param can also be of type null; however, parameter $name of Psr\Http\Message\MessageInterface::hasHeader() does only seem to accept string, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

18
                if (!$request->hasHeader(/** @scrutinizer ignore-type */ $param)) {
Loading history...
19 5
                    return new RejectedPromise('header \'' . $param . '\' is missing');
20
                }
21
            }
22
23 67
            return $request;
24 121
        };
25
    }
26
}
27