/modules/phpunit-1.0/vendor/PHPUnit/Extensions/OutputTestCase.php

https://github.com/robertleeplummerjr/bluebox · PHP · 195 lines · 81 code · 23 blank · 91 comment · 13 complexity · 11cc79a47bbb869a104f06bd48a0ef79 MD5 · raw file

  1. <?php
  2. /**
  3. * PHPUnit
  4. *
  5. * Copyright (c) 2002-2009, 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-2009 Sebastian Bergmann <sb@sebastian-bergmann.de>
  41. * @license http://www.opensource.org/licenses/bsd-license.php BSD License
  42. * @version SVN: $Id: OutputTestCase.php 4404 2008-12-31 09:27:18Z sb $
  43. * @link http://www.phpunit.de/
  44. * @since File available since Release 3.0.0
  45. */
  46. require_once 'PHPUnit/Framework.php';
  47. require_once 'PHPUnit/Util/Filter.php';
  48. PHPUnit_Util_Filter::addFileToFilter(__FILE__, 'PHPUNIT');
  49. /**
  50. * A TestCase that expects a specified output.
  51. *
  52. * @category Testing
  53. * @package PHPUnit
  54. * @author Sebastian Bergmann <sb@sebastian-bergmann.de>
  55. * @copyright 2002-2009 Sebastian Bergmann <sb@sebastian-bergmann.de>
  56. * @license http://www.opensource.org/licenses/bsd-license.php BSD License
  57. * @version Release: @package_version@
  58. * @link http://www.phpunit.de/
  59. * @since Class available since Release 3.0.0
  60. */
  61. abstract class PHPUnit_Extensions_OutputTestCase extends PHPUnit_Framework_TestCase
  62. {
  63. /**
  64. * @var string
  65. */
  66. protected $expectedRegex = NULL;
  67. /**
  68. * @var string
  69. */
  70. protected $expectedString = NULL;
  71. /**
  72. * @var string
  73. */
  74. protected $output = '';
  75. /**
  76. * @var mixed
  77. */
  78. protected $outputCallback = FALSE;
  79. /**
  80. * @return bool
  81. */
  82. public function setOutputCallback($callback)
  83. {
  84. if (is_callable($callback)) {
  85. $this->outputCallback = $callback;
  86. $set = TRUE;
  87. } else {
  88. $set = FALSE;
  89. }
  90. return $set;
  91. }
  92. /**
  93. * @return string
  94. */
  95. public function normalizeOutput($buffer)
  96. {
  97. return str_replace("\r", '', $buffer);
  98. }
  99. /**
  100. * @return string
  101. */
  102. public function getActualOutput()
  103. {
  104. return $this->output;
  105. }
  106. /**
  107. * @return string
  108. */
  109. public function expectedRegex()
  110. {
  111. return $this->expectedRegex;
  112. }
  113. /**
  114. * @param string $expectedRegex
  115. */
  116. public function expectOutputRegex($expectedRegex)
  117. {
  118. if ($this->expectedString !== NULL) {
  119. throw new RuntimeException;
  120. }
  121. if (is_string($expectedRegex) || is_null($expectedRegex)) {
  122. $this->expectedRegex = $expectedRegex;
  123. }
  124. }
  125. /**
  126. * @return string
  127. */
  128. public function expectedString()
  129. {
  130. return $this->expectedOutput;
  131. }
  132. /**
  133. * @param string $expectedString
  134. */
  135. public function expectOutputString($expectedString)
  136. {
  137. if ($this->expectedRegex !== NULL) {
  138. throw new RuntimeException;
  139. }
  140. if (is_string($expectedString) || is_null($expectedString)) {
  141. $this->expectedString = $expectedString;
  142. }
  143. }
  144. /**
  145. */
  146. protected function runTest()
  147. {
  148. ob_start();
  149. try {
  150. parent::runTest();
  151. }
  152. catch (Exception $e) {
  153. ob_end_clean();
  154. throw $e;
  155. }
  156. if ($this->outputCallback === FALSE) {
  157. $this->output = ob_get_contents();
  158. } else {
  159. $this->output = call_user_func_array($this->outputCallback, array(ob_get_contents()));
  160. }
  161. ob_end_clean();
  162. if ($this->expectedRegex !== NULL) {
  163. $this->assertRegExp($this->expectedRegex, $this->output);
  164. $this->expectedRegex = NULL;
  165. }
  166. else if ($this->expectedString !== NULL) {
  167. $this->assertEquals($this->expectedString, $this->output);
  168. $this->expectedString = NULL;
  169. }
  170. }
  171. }
  172. ?>