Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x
  2. LazyDouble.php

class LazyDouble

Lazy double. Gives simple interface to describe double before creating it.

@template T of object

@author Konstantin Kudryashov <ever.zet@gmail.com>

Hierarchy

  • class \Prophecy\Doubler\LazyDouble

Expanded class hierarchy of LazyDouble

2 files declare their use of LazyDouble
ObjectProphecy.php in vendor/phpspec/prophecy/src/Prophecy/Prophecy/ObjectProphecy.php
Prophet.php in vendor/phpspec/prophecy/src/Prophecy/Prophet.php

File

vendor/phpspec/prophecy/src/Prophecy/Doubler/LazyDouble.php, line 27

Namespace

Prophecy\Doubler
View source
class LazyDouble {
    private $doubler;
    
    /**
     * @var ReflectionClass<T>|null
     */
    private $class;
    
    /**
     * @var list<ReflectionClass<object>>
     */
    private $interfaces = array();
    
    /**
     * @var array<mixed>|null
     */
    private $arguments = null;
    
    /**
     * @var (T&DoubleInterface)|null
     */
    private $double;
    public function __construct(Doubler $doubler) {
        $this->doubler = $doubler;
    }
    
    /**
     * Tells doubler to use specific class as parent one for double.
     *
     * @param class-string|ReflectionClass<object> $class
     *
     * @return void
     *
     * @template U of object
     * @phpstan-param class-string<U>|ReflectionClass<U> $class
     * @phpstan-this-out static<U>
     *
     * @throws ClassNotFoundException
     * @throws DoubleException
     */
    public function setParentClass($class) {
        if (null !== $this->double) {
            throw new DoubleException('Can not extend class with already instantiated double.');
        }
        if (!$class instanceof ReflectionClass) {
            if (!class_exists($class)) {
                throw new ClassNotFoundException(sprintf('Class %s not found.', $class), $class);
            }
            $class = new ReflectionClass($class);
        }
        
        /** @var static<U> $this */
        $this->class = $class;
    }
    
    /**
     * Tells doubler to implement specific interface with double.
     *
     * @param class-string|ReflectionClass<object> $interface
     *
     * @return void
     *
     * @template U of object
     * @phpstan-param class-string<U>|ReflectionClass<U> $interface
     * @phpstan-this-out static<T&U>
     *
     * @throws InterfaceNotFoundException
     * @throws DoubleException
     */
    public function addInterface($interface) {
        if (null !== $this->double) {
            throw new DoubleException('Can not implement interface with already instantiated double.');
        }
        if (!$interface instanceof ReflectionClass) {
            if (!interface_exists($interface)) {
                throw new InterfaceNotFoundException(sprintf('Interface %s not found.', $interface), $interface);
            }
            $interface = new ReflectionClass($interface);
        }
        $this->interfaces[] = $interface;
    }
    
    /**
     * Sets constructor arguments.
     *
     * @param array<mixed>|null $arguments
     *
     * @return void
     */
    public function setArguments(?array $arguments = null) {
        $this->arguments = $arguments;
    }
    
    /**
     * Creates double instance or returns already created one.
     *
     * @return T&DoubleInterface
     */
    public function getInstance() {
        if (null === $this->double) {
            if (null !== $this->arguments) {
                return $this->double = $this->doubler
                    ->double($this->class, $this->interfaces, $this->arguments);
            }
            $this->double = $this->doubler
                ->double($this->class, $this->interfaces);
        }
        return $this->double;
    }

}

Members

Title Sort descending Modifiers Object type Summary
LazyDouble::$arguments private property
LazyDouble::$class private property
LazyDouble::$double private property
LazyDouble::$doubler private property
LazyDouble::$interfaces private property
LazyDouble::addInterface public function Tells doubler to implement specific interface with double.
LazyDouble::getInstance public function Creates double instance or returns already created one.
LazyDouble::setArguments public function Sets constructor arguments.
LazyDouble::setParentClass public function Tells doubler to use specific class as parent one for double.
LazyDouble::__construct public function
RSS feed
Powered by Drupal