Completed
Pull Request — master (#709)
by Dave
02:37
created

Contains::match()   B

Complexity

Conditions 6
Paths 7

Size

Total Lines 17
Code Lines 11

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 11
CRAP Score 6

Importance

Changes 0
Metric Value
dl 0
loc 17
ccs 11
cts 11
cp 1
rs 8.8571
c 0
b 0
f 0
cc 6
eloc 11
nc 7
nop 1
crap 6
1
<?php
2
/**
3
 * Mockery
4
 *
5
 * LICENSE
6
 *
7
 * This source file is subject to the new BSD license that is bundled
8
 * with this package in the file LICENSE.txt.
9
 * It is also available through the world-wide-web at this URL:
10
 * http://github.com/padraic/mockery/blob/master/LICENSE
11
 * If you did not receive a copy of the license and are unable to
12
 * obtain it through the world-wide-web, please send an email
13
 * to [email protected] so we can send you a copy immediately.
14
 *
15
 * @category   Mockery
16
 * @package    Mockery
17
 * @copyright  Copyright (c) 2010 Pádraic Brady (http://blog.astrumfutura.com)
18
 * @license    http://github.com/padraic/mockery/blob/master/LICENSE New BSD License
19
 */
20
21
namespace Mockery\Matcher;
22
23
class Contains extends MatcherAbstract
24
{
25
    /**
26
     * Check if the actual value matches the expected.
27
     *
28
     * @param mixed $actual
29
     * @return bool
30
     */
31 2
    public function match(&$actual)
32
    {
33 2
        $values = array_values($actual);
34 2
        foreach ($this->_expected as $exp) {
35 2
            $match = false;
36 2
            foreach ($values as $val) {
37 2
                if ($exp === $val || $exp == $val) {
38 2
                    $match = true;
39 2
                    break;
40
                }
41
            }
42 2
            if ($match === false) {
43 2
                return false;
44
            }
45
        }
46 1
        return true;
47
    }
48
49
    /**
50
     * Return a string representation of this Matcher
51
     *
52
     * @return string
53
     */
54
    public function __toString()
55
    {
56
        $return = '<Contains[';
57
        $elements = array();
58
        foreach ($this->_expected as $v) {
59
            $elements[] = (string) $v;
60
        }
61
        $return .= implode(', ', $elements) . ']>';
62
        return $return;
63
    }
64
}
65