1
|
|
|
<?php |
2
|
|
|
|
3
|
|
|
namespace whm\Smoke\Rules\Http; |
4
|
|
|
|
5
|
|
|
use GuzzleHttp\Psr7\Request; |
6
|
|
|
use phm\HttpWebdriverClient\Http\Client\Guzzle\GuzzleClient; |
7
|
|
|
use Psr\Http\Message\ResponseInterface; |
8
|
|
|
use whm\Html\Uri; |
9
|
|
|
use whm\Smoke\Rules\CheckResult; |
10
|
|
|
use whm\Smoke\Rules\Rule; |
11
|
|
|
|
12
|
|
|
/** |
13
|
|
|
* This rule can validate if a http request takes longer than a given max duration. |
14
|
|
|
* A website that is slower than one second is considered as slow. |
15
|
|
|
*/ |
16
|
|
|
class RedirectRule implements Rule |
17
|
|
|
{ |
18
|
|
|
private $urls; |
19
|
|
|
|
20
|
|
|
public function init($redirectedUrls) |
21
|
|
|
{ |
22
|
|
|
$this->urls = $redirectedUrls; |
23
|
|
|
} |
24
|
|
|
|
25
|
|
|
public function validate(ResponseInterface $response) |
26
|
|
|
{ |
27
|
|
|
$client = new GuzzleClient(); |
28
|
|
|
$errors = []; |
29
|
|
|
|
30
|
|
|
foreach ($this->urls as $url) { |
31
|
|
|
$uri = new Uri($url['url']); |
32
|
|
|
|
33
|
|
|
$urlResponses = $client->sendRequests([new Request('GET', $uri)]); |
34
|
|
|
$effectiveUrl = (string)$urlResponses[0]->getEffectiveUri(); |
35
|
|
|
|
36
|
|
|
if ($effectiveUrl != (string)$response->getUri()) { |
|
|
|
|
37
|
|
|
$errors[] = 'The url "' . $url['url'] . '" gets redirected to "' . $effectiveUrl . '".'; |
38
|
|
|
} |
39
|
|
|
} |
40
|
|
|
|
41
|
|
|
if (count($errors) > 0) { |
42
|
|
|
$message = 'Not all given urls do redirect to "' . (string)$response->getUri() . '"".<ul>'; |
|
|
|
|
43
|
|
|
foreach ($errors as $error) { |
44
|
|
|
$message .= '<li>' . $error . '</li>'; |
45
|
|
|
} |
46
|
|
|
$message .= "</ul>"; |
47
|
|
|
|
48
|
|
|
return new CheckResult(CheckResult::STATUS_FAILURE, $message); |
49
|
|
|
} else { |
50
|
|
|
return new CheckResult(CheckResult::STATUS_SUCCESS, 'All given urls redirect to ' . (string)$response->getUri()); |
|
|
|
|
51
|
|
|
} |
52
|
|
|
} |
53
|
|
|
} |
54
|
|
|
|
Let’s take a look at an example:
In the above example, the authenticate() method works fine as long as you just pass instances of MyUser. However, if you now also want to pass a different implementation of User which does not have a getDisplayName() method, the code will break.
Available Fixes
Change the type-hint for the parameter:
Add an additional type-check:
Add the method to the interface: