/
PHPUnitConstraint.php
76 lines (70 loc) · 2.02 KB
/
PHPUnitConstraint.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
<?php
/**
* Mockery
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://github.com/padraic/mockery/blob/master/LICENSE
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to padraic@php.net so we can send you a copy immediately.
*
* @category Mockery
* @package Mockery
* @copyright Copyright (c) 2010 Pádraic Brady (http://blog.astrumfutura.com)
* @license http://github.com/padraic/mockery/blob/master/LICENSE New BSD License
*/
namespace Mockery\Matcher;
use Mockery\Exception\InvalidArgumentException;
class PHPUnitConstraint extends MatcherAbstract
{
protected $constraint;
protected $rethrow;
/**
* @param mixed $constraint
* @param bool $rethrow
*/
public function __construct($constraint, $rethrow = false)
{
if (!($constraint instanceof \PHPUnit_Framework_Constraint)
&& !($constraint instanceof \PHPUnit\Framework\Constraint)) {
throw new InvalidArgumentException(
'Constraint must be one of \PHPUnit\Framework\Constraint or ' .
'\PHPUnit_Framework_Constraint'
);
}
$this->constraint = $constraint;
$this->rethrow = $rethrow;
}
/**
* @param mixed $actual
* @return bool
*/
public function match(&$actual)
{
try {
$this->constraint->evaluate($actual);
return true;
} catch (\PHPUnit_Framework_AssertionFailedError $e) {
if ($this->rethrow) {
throw $e;
}
return false;
} catch (\PHPUnit\Framework\AssertionFailedError $e) {
if ($this->rethrow) {
throw $e;
}
return false;
}
}
/**
*
*/
public function __toString()
{
return '<Constraint>';
}
}