LazyDouble::setParentClass()   A
last analyzed

Complexity

Conditions 4
Paths 4

Size

Total Lines 16

Duplication

Lines 16
Ratio 100 %

Importance

Changes 0
Metric Value
dl 16
loc 16
rs 9.7333
c 0
b 0
f 0
cc 4
nc 4
nop 1
1
<?php
2
3
/*
4
 * This file is part of the Prophecy.
5
 * (c) Konstantin Kudryashov <[email protected]>
6
 *     Marcello Duarte <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace Prophecy\Doubler;
13
14
use Prophecy\Exception\Doubler\DoubleException;
15
use Prophecy\Exception\Doubler\ClassNotFoundException;
16
use Prophecy\Exception\Doubler\InterfaceNotFoundException;
17
use ReflectionClass;
18
19
/**
20
 * Lazy double.
21
 * Gives simple interface to describe double before creating it.
22
 *
23
 * @author Konstantin Kudryashov <[email protected]>
24
 */
25
class LazyDouble
26
{
27
    private $doubler;
28
    private $class;
29
    private $interfaces = array();
30
    private $arguments  = null;
31
    private $double;
32
33
    /**
34
     * Initializes lazy double.
35
     *
36
     * @param Doubler $doubler
37
     */
38
    public function __construct(Doubler $doubler)
39
    {
40
        $this->doubler = $doubler;
41
    }
42
43
    /**
44
     * Tells doubler to use specific class as parent one for double.
45
     *
46
     * @param string|ReflectionClass $class
47
     *
48
     * @throws \Prophecy\Exception\Doubler\ClassNotFoundException
49
     * @throws \Prophecy\Exception\Doubler\DoubleException
50
     */
51 View Code Duplication
    public function setParentClass($class)
0 ignored issues
show
Duplication introduced by
This method seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
52
    {
53
        if (null !== $this->double) {
54
            throw new DoubleException('Can not extend class with already instantiated double.');
55
        }
56
57
        if (!$class instanceof ReflectionClass) {
58
            if (!class_exists($class)) {
59
                throw new ClassNotFoundException(sprintf('Class %s not found.', $class), $class);
60
            }
61
62
            $class = new ReflectionClass($class);
63
        }
64
65
        $this->class = $class;
66
    }
67
68
    /**
69
     * Tells doubler to implement specific interface with double.
70
     *
71
     * @param string|ReflectionClass $interface
72
     *
73
     * @throws \Prophecy\Exception\Doubler\InterfaceNotFoundException
74
     * @throws \Prophecy\Exception\Doubler\DoubleException
75
     */
76 View Code Duplication
    public function addInterface($interface)
0 ignored issues
show
Duplication introduced by
This method seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
77
    {
78
        if (null !== $this->double) {
79
            throw new DoubleException(
80
                'Can not implement interface with already instantiated double.'
81
            );
82
        }
83
84
        if (!$interface instanceof ReflectionClass) {
85
            if (!interface_exists($interface)) {
86
                throw new InterfaceNotFoundException(
87
                    sprintf('Interface %s not found.', $interface),
88
                    $interface
89
                );
90
            }
91
92
            $interface = new ReflectionClass($interface);
93
        }
94
95
        $this->interfaces[] = $interface;
96
    }
97
98
    /**
99
     * Sets constructor arguments.
100
     *
101
     * @param array $arguments
102
     */
103
    public function setArguments(array $arguments = null)
104
    {
105
        $this->arguments = $arguments;
106
    }
107
108
    /**
109
     * Creates double instance or returns already created one.
110
     *
111
     * @return DoubleInterface
112
     */
113
    public function getInstance()
114
    {
115
        if (null === $this->double) {
116
            if (null !== $this->arguments) {
117
                return $this->double = $this->doubler->double(
118
                    $this->class, $this->interfaces, $this->arguments
119
                );
120
            }
121
122
            $this->double = $this->doubler->double($this->class, $this->interfaces);
123
        }
124
125
        return $this->double;
126
    }
127
}
128