Вход Регистрация
Файл: gapps/vendor/mockery/mockery/library/Mockery/CompositeExpectation.php
Строк: 113
<?php
/**
 * Mockery
 *
 * LICENSE
 *
 * This source file is subject to the new BSD license that is bundled
 * with this package in the file LICENSE.txt.
 * It is also available through the world-wide-web at this URL:
 * http://github.com/padraic/mockery/blob/master/LICENSE
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to padraic@php.net so we can send you a copy immediately.
 *
 * @category   Mockery
 * @package    Mockery
 * @copyright  Copyright (c) 2010-2014 Pádraic Brady (http://blog.astrumfutura.com)
 * @license    http://github.com/padraic/mockery/blob/master/LICENSE New BSD License
 */

namespace Mockery;

class 
CompositeExpectation implements ExpectationInterface
{

    
/**
     * Stores an array of all expectations for this composite
     *
     * @var array
     */
    
protected $_expectations = array();

    
/**
     * Add an expectation to the composite
     *
     * @param MockeryExpectation|MockeryCompositeExpectation $expectation
     * @return void
     */
    
public function add($expectation)
    {
        
$this->_expectations[] = $expectation;
    }

    
/**
     * @param mixed ...
     */
    
public function andReturn()
    {
        return 
$this->__call(__FUNCTION__func_get_args());
    }

    
/**
     * Intercept any expectation calls and direct against all expectations
     *
     * @param string $method
     * @param array $args
     * @return self
     */
    
public function __call($method, array $args)
    {
        foreach (
$this->_expectations as $expectation) {
            
call_user_func_array(array($expectation$method), $args);
        }
        return 
$this;
    }

    
/**
     * Return order number of the first expectation
     *
     * @return int
     */
    
public function getOrderNumber()
    {
        
reset($this->_expectations);
        
$first current($this->_expectations);
        return 
$first->getOrderNumber();
    }

    
/**
     * Return the parent mock of the first expectation
     *
     * @return MockeryMockInterface
     */
    
public function getMock()
    {
        
reset($this->_expectations);
        
$first current($this->_expectations);
        return 
$first->getMock();
    }

    
/**
     * Mockery API alias to getMock
     *
     * @return MockeryMockInterface
     */
    
public function mock()
    {
        return 
$this->getMock();
    }

    
/**
     * Starts a new expectation addition on the first mock which is the primary
     * target outside of a demeter chain
     *
     * @param mixed ...
     * @return MockeryExpectation
     */
    
public function shouldReceive()
    {
        
$args func_get_args();
        
reset($this->_expectations);
        
$first current($this->_expectations);
        return 
call_user_func_array(array($first->getMock(), 'shouldReceive'), $args);
    }

    
/**
     * Return the string summary of this composite expectation
     *
     * @return string
     */
    
public function __toString()
    {
        
$return '[';
        
$parts = array();
        foreach (
$this->_expectations as $exp) {
            
$parts[] = (string) $exp;
        }
        
$return .= implode(', '$parts) . ']';
        return 
$return;
    }
}
Онлайн: 0
Реклама