AtMost::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 AtMost extends CountValidatorAbstract
26
{
27
    /**
28
     * Validate the call count against this validator
29
     *
30
     * @param int $n
31
     * @return bool
32
     */
33 6
    public function validate($n)
34
    {
35 6
        if ($this->_limit < $n) {
36 2
            $exception = new Mockery\Exception\InvalidCountException(
37 2
                'Method ' . (string) $this->_expectation
38 2
                . ' from ' . $this->_expectation->getMock()->mockery_getName()
39 2
                . ' should be called' . PHP_EOL
40 2
                . ' at most ' . $this->_limit . ' times but called ' . $n
41 2
                . ' times.'
42 2
            );
43 2
            $exception->setMock($this->_expectation->getMock())
44 2
                ->setMethodName((string) $this->_expectation)
45 2
                ->setExpectedCountComparative('<=')
46 2
                ->setExpectedCount($this->_limit)
47 2
                ->setActualCount($n);
48 2
            throw $exception;
49
        }
50 4
    }
51
}
52