Completed
Pull Request — master (#682)
by Bilge
02:41
created

Subset::__toString()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 10
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 6

Importance

Changes 0
Metric Value
dl 0
loc 10
ccs 0
cts 0
cp 0
rs 9.4285
c 0
b 0
f 0
cc 2
eloc 7
nc 2
nop 0
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 Subset 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
        foreach ($this->_expected as $k=>$v) {
34 2
            if (!array_key_exists($k, $actual)) {
35 1
                return false;
36
            }
37 2
            if ($actual[$k] !== $v) {
38 2
                return false;
39
            }
40
        }
41 1
        return true;
42
    }
43
44
    /**
45
     * Return a string representation of this Matcher
46
     *
47
     * @return string
48
     */
49
    public function __toString()
50
    {
51
        $return = '<Subset[';
52
        $elements = array();
53
        foreach ($this->_expected as $k=>$v) {
54
            $elements[] = $k . '=' . (string) $v;
55
        }
56
        $return .= implode(', ', $elements) . ']>';
57
        return $return;
58
    }
59
}
60