You are here

class PHPUnit_Framework_MockObject_InvocationMocker in Zircon Profile 8

Same name and namespace in other branches
  1. 8.0 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/InvocationMocker.php \PHPUnit_Framework_MockObject_InvocationMocker

Mocker for invocations which are sent from PHPUnit_Framework_MockObject_MockObject objects.

Keeps track of all expectations and stubs as well as registering identifications for builders.

@since Class available since Release 1.0.0

Hierarchy

Expanded class hierarchy of PHPUnit_Framework_MockObject_InvocationMocker

File

vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/InvocationMocker.php, line 20

View source
class PHPUnit_Framework_MockObject_InvocationMocker implements PHPUnit_Framework_MockObject_Stub_MatcherCollection, PHPUnit_Framework_MockObject_Invokable, PHPUnit_Framework_MockObject_Builder_Namespace {

  /**
   * @var PHPUnit_Framework_MockObject_Matcher_Invocation[]
   */
  protected $matchers = array();

  /**
   * @var PHPUnit_Framework_MockObject_Builder_Match[]
   */
  protected $builderMap = array();

  /**
   * @param PHPUnit_Framework_MockObject_Matcher_Invocation $matcher
   */
  public function addMatcher(PHPUnit_Framework_MockObject_Matcher_Invocation $matcher) {
    $this->matchers[] = $matcher;
  }

  /**
   * @since Method available since Release 1.1.0
   */
  public function hasMatchers() {
    foreach ($this->matchers as $matcher) {
      if ($matcher
        ->hasMatchers()) {
        return true;
      }
    }
    return false;
  }

  /**
   * @param  mixed     $id
   * @return bool|null
   */
  public function lookupId($id) {
    if (isset($this->builderMap[$id])) {
      return $this->builderMap[$id];
    }
    return;
  }

  /**
   * @param  mixed                                      $id
   * @param  PHPUnit_Framework_MockObject_Builder_Match $builder
   * @throws PHPUnit_Framework_Exception
   */
  public function registerId($id, PHPUnit_Framework_MockObject_Builder_Match $builder) {
    if (isset($this->builderMap[$id])) {
      throw new PHPUnit_Framework_Exception('Match builder with id <' . $id . '> is already registered.');
    }
    $this->builderMap[$id] = $builder;
  }

  /**
   * @param  PHPUnit_Framework_MockObject_Matcher_Invocation       $matcher
   * @return PHPUnit_Framework_MockObject_Builder_InvocationMocker
   */
  public function expects(PHPUnit_Framework_MockObject_Matcher_Invocation $matcher) {
    return new PHPUnit_Framework_MockObject_Builder_InvocationMocker($this, $matcher);
  }

  /**
   * @param  PHPUnit_Framework_MockObject_Invocation $invocation
   * @return mixed
   */
  public function invoke(PHPUnit_Framework_MockObject_Invocation $invocation) {
    $exception = null;
    $hasReturnValue = false;
    if (strtolower($invocation->methodName) == '__tostring') {
      $returnValue = '';
    }
    else {
      $returnValue = null;
    }
    foreach ($this->matchers as $match) {
      try {
        if ($match
          ->matches($invocation)) {
          $value = $match
            ->invoked($invocation);
          if (!$hasReturnValue) {
            $returnValue = $value;
            $hasReturnValue = true;
          }
        }
      } catch (Exception $e) {
        $exception = $e;
      }
    }
    if ($exception !== null) {
      throw $exception;
    }
    return $returnValue;
  }

  /**
   * @param  PHPUnit_Framework_MockObject_Invocation $invocation
   * @return bool
   */
  public function matches(PHPUnit_Framework_MockObject_Invocation $invocation) {
    foreach ($this->matchers as $matcher) {
      if (!$matcher
        ->matches($invocation)) {
        return false;
      }
    }
    return true;
  }

  /**
   * @return bool
   */
  public function verify() {
    foreach ($this->matchers as $matcher) {
      $matcher
        ->verify();
    }
  }

}

Members