Ducktype::__toString()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 4
ccs 0
cts 2
cp 0
rs 10
cc 1
eloc 2
nc 1
nop 0
crap 2
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 Ducktype 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
        if (!is_object($actual)) {
34
            return false;
35
        }
36 2
        foreach ($this->_expected as $method) {
37 2
            if (!method_exists($actual, $method)) {
38 1
                return false;
39
            }
40 2
        }
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 '<Ducktype[' . implode(', ', $this->_expected) . ']>';
52
    }
53
}
54