5 * Copyright (c) 2010-2011, Sebastian Bergmann <sb@sebastian-bergmann.de>.
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
12 * * Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
15 * * Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in
17 * the documentation and/or other materials provided with the
20 * * Neither the name of Sebastian Bergmann nor the names of his
21 * contributors may be used to endorse or promote products derived
22 * from this software without specific prior written permission.
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
25 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
26 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
27 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
28 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
29 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
30 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
31 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
32 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
34 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35 * POSSIBILITY OF SUCH DAMAGE.
37 * @package PHPUnit_MockObject
38 * @author Giorgio Sironi <piccoloprincipeazzurro@gmail.com>
39 * @author Sebastian Bergmann <sb@sebastian-bergmann.de>
40 * @copyright 2010-2011 Sebastian Bergmann <sb@sebastian-bergmann.de>
41 * @license http://www.opensource.org/licenses/bsd-license.php BSD License
42 * @link http://github.com/sebastianbergmann/phpunit-mock-objects
43 * @since File available since Release 1.0.0
47 * Implementation of the Builder pattern for Mock objects.
49 * @package PHPUnit_MockObject
50 * @author Giorgio Sironi <piccoloprincipeazzurro@gmail.com>
51 * @author Sebastian Bergmann <sb@sebastian-bergmann.de>
52 * @copyright 2010-2011 Sebastian Bergmann <sb@sebastian-bergmann.de>
53 * @license http://www.opensource.org/licenses/bsd-license.php BSD License
54 * @link http://github.com/sebastianbergmann/phpunit-mock-objects
55 * @since File available since Release 1.0.0
57 class PHPUnit_Framework_MockObject_MockBuilder
60 * @var PHPUnit_Framework_TestCase
72 protected $methods = array();
77 protected $mockClassName = '';
82 protected $constructorArgs = array();
87 protected $originalConstructor = TRUE;
92 protected $originalClone = TRUE;
97 protected $autoload = TRUE;
100 * @param PHPUnit_Framework_TestCase
103 public function __construct(PHPUnit_Framework_TestCase $testCase, $className)
105 $this->testCase = $testCase;
106 $this->className = $className;
110 * Creates a mock object using a fluent interface.
112 * @return PHPUnit_Framework_MockObject_MockObject
114 public function getMock()
116 return $this->testCase->getMock(
119 $this->constructorArgs,
120 $this->mockClassName,
121 $this->originalConstructor,
122 $this->originalClone,
128 * Creates a mock object for an abstract class using a fluent interface.
130 * @return PHPUnit_Framework_MockObject_MockObject
132 public function getMockForAbstractClass()
134 return $this->testCase->getMockForAbstractClass(
136 $this->constructorArgs,
137 $this->mockClassName,
138 $this->originalConstructor,
139 $this->originalClone,
145 * Specifies the subset of methods to mock. Default is to mock all of them.
147 * @param array $methods
148 * @return PHPUnit_Framework_MockObject_MockBuilder
150 public function setMethods(array $methods)
152 $this->methods = $methods;
158 * Specifies the arguments for the constructor.
161 * @return PHPUnit_Framework_MockObject_MockBuilder
163 public function setConstructorArgs(array $args)
165 $this->constructorArgs = $args;
171 * Specifies the name for the mock class.
173 * @param string $name
174 * @return PHPUnit_Framework_MockObject_MockBuilder
176 public function setMockClassName($name)
178 $this->mockClassName = $name;
184 * Suppresses the invocation of the original constructor.
186 * @return PHPUnit_Framework_MockObject_MockBuilder
188 public function disableOriginalConstructor()
190 $this->originalConstructor = FALSE;
196 * Suppresses the invocation of the original clone constructor.
198 * @return PHPUnit_Framework_MockObject_MockBuilder
200 public function disableOriginalClone()
202 $this->originalClone = FALSE;
208 * Suppresses the use of class autoloading while creating the mock object.
210 * @return PHPUnit_Framework_MockObject_MockBuilder
212 public function disableAutoload()
214 $this->autoload = FALSE;