Exact::validate()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 18
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 16
CRAP Score 2

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 18
ccs 16
cts 16
cp 1
rs 9.4285
cc 2
eloc 14
nc 2
nop 1
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\CountValidator;
22
23
use Mockery;
24
25
class Exact extends CountValidatorAbstract
26
{
27
    /**
28
     * Validate the call count against this validator
29
     *
30
     * @param int $n
31
     * @return bool
32
     */
33 107
    public function validate($n)
34
    {
35 107
        if ($this->_limit !== $n) {
36 21
            $exception = new Mockery\Exception\InvalidCountException(
37 21
                'Method ' . (string) $this->_expectation
38 21
                . ' from ' . $this->_expectation->getMock()->mockery_getName()
39 21
                . ' should be called' . PHP_EOL
40 21
                . ' exactly ' . $this->_limit . ' times but called ' . $n
41 21
                . ' times.'
42 21
            );
43 21
            $exception->setMock($this->_expectation->getMock())
44 21
                ->setMethodName((string) $this->_expectation)
45 21
                ->setExpectedCountComparative('=')
46 21
                ->setExpectedCount($this->_limit)
47 21
                ->setActualCount($n);
48 21
            throw $exception;
49
        }
50 92
    }
51
}
52