annotate vendor/phpunit/phpunit-mock-objects/src/Matcher/InvokedAtMostCount.php @ 19:fa3358dc1485 tip

Add ndrum files
author Chris Cannam
date Wed, 28 Aug 2019 13:14:47 +0100
parents 1fec387a4317
children
rev   line source
Chris@14 1 <?php
Chris@14 2 /*
Chris@14 3 * This file is part of the phpunit-mock-objects package.
Chris@14 4 *
Chris@14 5 * (c) Sebastian Bergmann <sebastian@phpunit.de>
Chris@14 6 *
Chris@14 7 * For the full copyright and license information, please view the LICENSE
Chris@14 8 * file that was distributed with this source code.
Chris@14 9 */
Chris@14 10 namespace PHPUnit\Framework\MockObject\Matcher;
Chris@14 11
Chris@14 12 use PHPUnit\Framework\ExpectationFailedException;
Chris@14 13
Chris@14 14 /**
Chris@14 15 * Invocation matcher which checks if a method has been invoked at least
Chris@14 16 * N times.
Chris@14 17 */
Chris@14 18 class InvokedAtMostCount extends InvokedRecorder
Chris@14 19 {
Chris@14 20 /**
Chris@14 21 * @var int
Chris@14 22 */
Chris@14 23 private $allowedInvocations;
Chris@14 24
Chris@14 25 /**
Chris@14 26 * @param int $allowedInvocations
Chris@14 27 */
Chris@14 28 public function __construct($allowedInvocations)
Chris@14 29 {
Chris@14 30 $this->allowedInvocations = $allowedInvocations;
Chris@14 31 }
Chris@14 32
Chris@14 33 /**
Chris@14 34 * @return string
Chris@14 35 */
Chris@14 36 public function toString()
Chris@14 37 {
Chris@14 38 return 'invoked at most ' . $this->allowedInvocations . ' times';
Chris@14 39 }
Chris@14 40
Chris@14 41 /**
Chris@14 42 * Verifies that the current expectation is valid. If everything is OK the
Chris@14 43 * code should just return, if not it must throw an exception.
Chris@14 44 *
Chris@14 45 * @throws ExpectationFailedException
Chris@14 46 */
Chris@14 47 public function verify()
Chris@14 48 {
Chris@14 49 $count = $this->getInvocationCount();
Chris@14 50
Chris@14 51 if ($count > $this->allowedInvocations) {
Chris@14 52 throw new ExpectationFailedException(
Chris@14 53 'Expected invocation at most ' . $this->allowedInvocations .
Chris@14 54 ' times but it occurred ' . $count . ' time(s).'
Chris@14 55 );
Chris@14 56 }
Chris@14 57 }
Chris@14 58 }