Subversion-Projekte lars-tiefland.php_share

Revision

Details | Letzte Änderung | Log anzeigen | RSS feed

Revision Autor Zeilennr. Zeile
1 lars 1
<?php
2
/**
3
 * PHPUnit
4
 *
5
 * Copyright (c) 2002-2010, Sebastian Bergmann <sb@sebastian-bergmann.de>.
6
 * All rights reserved.
7
 *
8
 * Redistribution and use in source and binary forms, with or without
9
 * modification, are permitted provided that the following conditions
10
 * are met:
11
 *
12
 *   * Redistributions of source code must retain the above copyright
13
 *     notice, this list of conditions and the following disclaimer.
14
 *
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
18
 *     distribution.
19
 *
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.
23
 *
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.
36
 *
37
 * @category   Testing
38
 * @package    PHPUnit
39
 * @author     Sebastian Bergmann <sb@sebastian-bergmann.de>
40
 * @copyright  2002-2010 Sebastian Bergmann <sb@sebastian-bergmann.de>
41
 * @license    http://www.opensource.org/licenses/bsd-license.php  BSD License
42
 * @link       http://www.phpunit.de/
43
 * @since      File available since Release 3.0.0
44
 */
45
 
46
require_once 'PHPUnit/Util/Filter.php';
47
require_once 'PHPUnit/Framework/MockObject/Builder/MethodNameMatch.php';
48
require_once 'PHPUnit/Framework/MockObject/Matcher.php';
49
require_once 'PHPUnit/Framework/MockObject/Stub.php';
50
 
51
PHPUnit_Util_Filter::addFileToFilter(__FILE__, 'PHPUNIT');
52
 
53
/**
54
 * Builder for mocked or stubbed invocations.
55
 *
56
 * Provides methods for building expectations without having to resort to
57
 * instantiating the various matchers manually. These methods also form a
58
 * more natural way of reading the expectation. This class should be together
59
 * with the test case PHPUnit_Framework_MockObject_TestCase.
60
 *
61
 * @category   Testing
62
 * @package    PHPUnit
63
 * @author     Sebastian Bergmann <sb@sebastian-bergmann.de>
64
 * @copyright  2002-2010 Sebastian Bergmann <sb@sebastian-bergmann.de>
65
 * @license    http://www.opensource.org/licenses/bsd-license.php  BSD License
66
 * @version    Release: 3.4.15
67
 * @link       http://www.phpunit.de/
68
 * @since      Class available since Release 3.0.0
69
 */
70
class PHPUnit_Framework_MockObject_Builder_InvocationMocker implements PHPUnit_Framework_MockObject_Builder_MethodNameMatch
71
{
72
    /**
73
     * @var PHPUnit_Framework_MockObject_Stub_MatcherCollection
74
     */
75
    protected $collection;
76
 
77
    /**
78
     * @var PHPUnit_Framework_MockObject_Matcher
79
     */
80
    protected $matcher;
81
 
82
    /**
83
     * @param PHPUnit_Framework_MockObject_Stub_MatcherCollection $collection
84
     * @param PHPUnit_Framework_MockObject_Matcher_Invocation $invocationMatcher
85
     */
86
    public function __construct(PHPUnit_Framework_MockObject_Stub_MatcherCollection $collection, PHPUnit_Framework_MockObject_Matcher_Invocation $invocationMatcher)
87
    {
88
        $this->collection = $collection;
89
        $this->matcher    = new PHPUnit_Framework_MockObject_Matcher(
90
          $invocationMatcher
91
        );
92
 
93
        $this->collection->addMatcher($this->matcher);
94
    }
95
 
96
    /**
97
     * @return PHPUnit_Framework_MockObject_Matcher
98
     */
99
    public function getMatcher()
100
    {
101
        return $this->matcher;
102
    }
103
 
104
    /**
105
     * @param  mixed $id
106
     * @return PHPUnit_Framework_MockObject_Builder_InvocationMocker
107
     */
108
    public function id($id)
109
    {
110
        $this->collection->registerId($id, $this);
111
 
112
        return $this;
113
    }
114
 
115
    /**
116
     * @param  PHPUnit_Framework_MockObject_Stub $stub
117
     * @return PHPUnit_Framework_MockObject_Builder_InvocationMocker
118
     */
119
    public function will(PHPUnit_Framework_MockObject_Stub $stub)
120
    {
121
        $this->matcher->stub = $stub;
122
 
123
        return $this;
124
    }
125
 
126
    /**
127
     * @param  mixed $id
128
     * @return PHPUnit_Framework_MockObject_Builder_InvocationMocker
129
     */
130
    public function after($id)
131
    {
132
        $this->matcher->afterMatchBuilderId = $id;
133
 
134
        return $this;
135
    }
136
 
137
    /**
138
     * @param  mixed $argument, ...
139
     * @return PHPUnit_Framework_MockObject_Builder_InvocationMocker
140
     */
141
    public function with()
142
    {
143
        $args = func_get_args();
144
 
145
        if ($this->matcher->methodNameMatcher === NULL) {
146
            throw new PHPUnit_Framework_Exception(
147
              'Method name matcher is not defined, cannot define parameter ' .
148
              ' matcher without one'
149
            );
150
        }
151
 
152
        if ($this->matcher->parametersMatcher !== NULL) {
153
            throw new PHPUnit_Framework_Exception(
154
              'Parameter matcher is already defined, cannot redefine'
155
            );
156
        }
157
 
158
        $this->matcher->parametersMatcher = new PHPUnit_Framework_MockObject_Matcher_Parameters($args);
159
 
160
        return $this;
161
    }
162
 
163
    /**
164
     * @return PHPUnit_Framework_MockObject_Builder_InvocationMocker
165
     */
166
    public function withAnyParameters()
167
    {
168
        if ($this->matcher->methodNameMatcher === NULL) {
169
            throw new PHPUnit_Framework_Exception(
170
              'Method name matcher is not defined, cannot define parameter ' .
171
              'matcher without one'
172
            );
173
        }
174
 
175
        if ($this->matcher->parametersMatcher !== NULL) {
176
            throw new PHPUnit_Framework_Exception(
177
              'Parameter matcher is already defined, cannot redefine'
178
            );
179
        }
180
 
181
        $this->matcher->parametersMatcher = new PHPUnit_Framework_MockObject_Matcher_AnyParameters;
182
 
183
        return $this;
184
    }
185
 
186
    /**
187
     * @param  PHPUnit_Framework_Constraint|string $constraint
188
     * @return PHPUnit_Framework_MockObject_Builder_InvocationMocker
189
     */
190
    public function method($constraint)
191
    {
192
        if ($this->matcher->methodNameMatcher !== NULL) {
193
            throw new PHPUnit_Framework_Exception(
194
              'Method name matcher is already defined, cannot redefine'
195
            );
196
        }
197
 
198
        $this->matcher->methodNameMatcher = new PHPUnit_Framework_MockObject_Matcher_MethodName($constraint);
199
 
200
        return $this;
201
    }
202
}
203
?>