| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
 | <?php/*
 * This file is part of PHPUnit.
 *
 * (c) Sebastian Bergmann <sebastian@phpunit.de>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
 
 /**
 * A Decorator for Tests.
 *
 * Use TestDecorator as the base class for defining new
 * test decorators. Test decorator subclasses can be introduced
 * to add behaviour before or after a test is run.
 */
 class PHPUnit_Extensions_TestDecorator extends PHPUnit_Framework_Assert implements PHPUnit_Framework_Test, PHPUnit_Framework_SelfDescribing
 {
 /**
 * The Test to be decorated.
 *
 * @var object
 */
 protected $test = null;
 
 /**
 * Constructor.
 *
 * @param PHPUnit_Framework_Test $test
 */
 public function __construct(PHPUnit_Framework_Test $test)
 {
 $this->test = $test;
 }
 
 /**
 * Returns a string representation of the test.
 *
 * @return string
 */
 public function toString()
 {
 return $this->test->toString();
 }
 
 /**
 * Runs the test and collects the
 * result in a TestResult.
 *
 * @param PHPUnit_Framework_TestResult $result
 */
 public function basicRun(PHPUnit_Framework_TestResult $result)
 {
 $this->test->run($result);
 }
 
 /**
 * Counts the number of test cases that
 * will be run by this test.
 *
 * @return int
 */
 public function count()
 {
 return count($this->test);
 }
 
 /**
 * Creates a default TestResult object.
 *
 * @return PHPUnit_Framework_TestResult
 */
 protected function createResult()
 {
 return new PHPUnit_Framework_TestResult;
 }
 
 /**
 * Returns the test to be run.
 *
 * @return PHPUnit_Framework_Test
 */
 public function getTest()
 {
 return $this->test;
 }
 
 /**
 * Runs the decorated test and collects the
 * result in a TestResult.
 *
 * @param PHPUnit_Framework_TestResult $result
 *
 * @return PHPUnit_Framework_TestResult
 */
 public function run(PHPUnit_Framework_TestResult $result = null)
 {
 if ($result === null) {
 $result = $this->createResult();
 }
 
 $this->basicRun($result);
 
 return $result;
 }
 }
 
 |