FaultTest.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. <?php
  2. /**
  3. * Zend Framework
  4. *
  5. * LICENSE
  6. *
  7. * This source file is subject to the new BSD license that is bundled
  8. * with this package in the file LICENSE.txt.
  9. * It is also available through the world-wide-web at this URL:
  10. * http://framework.zend.com/license/new-bsd
  11. * If you did not receive a copy of the license and are unable to
  12. * obtain it through the world-wide-web, please send an email
  13. * to license@zend.com so we can send you a copy immediately.
  14. *
  15. * @category Zend
  16. * @package Zend_XmlRpc
  17. * @subpackage UnitTests
  18. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  19. * @license http://framework.zend.com/license/new-bsd New BSD License
  20. * @version $Id$
  21. */
  22. require_once 'Zend/XmlRpc/Fault.php';
  23. require_once 'PHPUnit/Framework/TestCase.php';
  24. require_once 'PHPUnit/Framework/IncompleteTestError.php';
  25. /**
  26. * Test case for Zend_XmlRpc_Fault
  27. *
  28. * @category Zend
  29. * @package Zend_XmlRpc
  30. * @subpackage UnitTests
  31. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  32. * @license http://framework.zend.com/license/new-bsd New BSD License
  33. * @group Zend_XmlRpc
  34. */
  35. class Zend_XmlRpc_FaultTest extends PHPUnit_Framework_TestCase
  36. {
  37. /**
  38. * Zend_XmlRpc_Fault object
  39. * @var Zend_XmlRpc_Fault
  40. */
  41. protected $_fault;
  42. /**
  43. * Setup environment
  44. */
  45. public function setUp()
  46. {
  47. $this->_fault = new Zend_XmlRpc_Fault();
  48. }
  49. /**
  50. * Teardown environment
  51. */
  52. public function tearDown()
  53. {
  54. unset($this->_fault);
  55. }
  56. /**
  57. * __construct() test
  58. */
  59. public function testConstructor()
  60. {
  61. $this->assertTrue($this->_fault instanceof Zend_XmlRpc_Fault);
  62. $this->assertEquals(404, $this->_fault->getCode());
  63. $this->assertEquals('Unknown Error', $this->_fault->getMessage());
  64. }
  65. /**
  66. * get/setCode() test
  67. */
  68. public function testCode()
  69. {
  70. $this->_fault->setCode('1000');
  71. $this->assertEquals(1000, $this->_fault->getCode());
  72. }
  73. /**
  74. * get/setMessage() test
  75. */
  76. public function testMessage()
  77. {
  78. $this->_fault->setMessage('Message');
  79. $this->assertEquals('Message', $this->_fault->getMessage());
  80. }
  81. protected function _createXml()
  82. {
  83. $dom = new DOMDocument('1.0', 'UTF-8');
  84. $response = $dom->appendChild($dom->createElement('methodResponse'));
  85. $fault = $response->appendChild($dom->createElement('fault'));
  86. $value = $fault->appendChild($dom->createElement('value'));
  87. $struct = $value->appendChild($dom->createElement('struct'));
  88. $member1 = $struct->appendChild($dom->createElement('member'));
  89. $member1->appendChild($dom->createElement('name', 'faultCode'));
  90. $value1 = $member1->appendChild($dom->createElement('value'));
  91. $value1->appendChild($dom->createElement('int', 1000));
  92. $member2 = $struct->appendChild($dom->createElement('member'));
  93. $member2->appendChild($dom->createElement('name', 'faultString'));
  94. $value2 = $member2->appendChild($dom->createElement('value'));
  95. $value2->appendChild($dom->createElement('string', 'Error string'));
  96. return $dom->saveXml();
  97. }
  98. protected function _createNonStandardXml()
  99. {
  100. $dom = new DOMDocument('1.0', 'UTF-8');
  101. $response = $dom->appendChild($dom->createElement('methodResponse'));
  102. $fault = $response->appendChild($dom->createElement('fault'));
  103. $value = $fault->appendChild($dom->createElement('value'));
  104. $struct = $value->appendChild($dom->createElement('struct'));
  105. $member1 = $struct->appendChild($dom->createElement('member'));
  106. $member1->appendChild($dom->createElement('name', 'faultCode'));
  107. $value1 = $member1->appendChild($dom->createElement('value'));
  108. $value1->appendChild($dom->createElement('int', 1000));
  109. $member2 = $struct->appendChild($dom->createElement('member'));
  110. $member2->appendChild($dom->createElement('name', 'faultString'));
  111. $value2 = $member2->appendChild($dom->createElement('value', 'Error string'));
  112. return $dom->saveXml();
  113. }
  114. /**
  115. * loadXml() test
  116. */
  117. public function testLoadXml()
  118. {
  119. $xml = $this->_createXml();
  120. try {
  121. $parsed = $this->_fault->loadXml($xml);
  122. } catch (Exception $e) {
  123. $this->fail('Failed to parse XML: ' . $e->getMessage());
  124. }
  125. $this->assertTrue($parsed, $xml);
  126. $this->assertEquals(1000, $this->_fault->getCode());
  127. $this->assertEquals('Error string', $this->_fault->getMessage());
  128. try {
  129. $parsed = $this->_fault->loadXml('foo');
  130. $this->fail('Should not parse invalid XML');
  131. } catch (Zend_XmlRpc_Exception $e) {
  132. // do nothing
  133. }
  134. $this->assertFalse($this->_fault->loadXml('<wellformedButInvalid/>'));
  135. try {
  136. $this->assertFalse($this->_fault->loadXml('<methodResponse><fault/></methodResponse>'));
  137. $this->fail('Should throw an exception. No value element in fault');
  138. } catch (Zend_XmlRpc_Exception $e) {
  139. $this->assertEquals('Invalid fault structure', $e->getMessage());
  140. $this->assertSame(500, $e->getCode());
  141. }
  142. try {
  143. $this->_fault->loadXml('<methodResponse><fault/></methodResponse>');
  144. $this->fail('Should throw an exception. No struct element in //fault/value');
  145. } catch (Zend_XmlRpc_Exception $e) {
  146. $this->assertEquals('Invalid fault structure', $e->getMessage());
  147. $this->assertSame(500, $e->getCode());
  148. }
  149. try {
  150. $this->_fault->loadXml('<methodResponse><fault><value><struct/></value></fault></methodResponse>');
  151. $this->fail('Should throw an exception. Empty fault code and string in //fault/value');
  152. } catch (Zend_XmlRpc_Exception $e) {
  153. $this->assertEquals('Fault code and string required', $e->getMessage());
  154. }
  155. $this->_fault->loadXml('<methodResponse><fault><value><struct>'
  156. . '<member><name>faultString</name><value><string>str</string></value></member>'
  157. . '</struct></value></fault></methodResponse>');
  158. $this->assertSame(404, $this->_fault->getCode(), 'If no fault code is given, use 404 as a default');
  159. $this->_fault->loadXml('<methodResponse><fault><value><struct>'
  160. . '<member><name>faultCode</name><value><int>610</int></value></member>'
  161. . '</struct></value></fault></methodResponse>');
  162. $this->assertSame(
  163. 'Invalid method class', $this->_fault->getMessage(), 'If empty fault string is given, resolve the code');
  164. $this->_fault->loadXml('<methodResponse><fault><value><struct>'
  165. . '<member><name>faultCode</name><value><int>1234</int></value></member>'
  166. . '</struct></value></fault></methodResponse>');
  167. $this->assertSame(
  168. 'Unknown Error',
  169. $this->_fault->getMessage(),
  170. 'If code resolval failed, use "Unknown Error"'
  171. );
  172. }
  173. /**
  174. * Zend_XmlRpc_Fault::isFault() test
  175. */
  176. public function testIsFault()
  177. {
  178. $xml = $this->_createXml();
  179. $this->assertTrue(Zend_XmlRpc_Fault::isFault($xml), $xml);
  180. $this->assertFalse(Zend_XmlRpc_Fault::isFault('foo'));
  181. $this->assertFalse(Zend_XmlRpc_Fault::isFault(array('foo')));
  182. }
  183. /**
  184. * helper for saveXml() and __toString() tests
  185. *
  186. * @param string $xml
  187. * @return void
  188. */
  189. protected function _testXmlFault($xml)
  190. {
  191. try {
  192. $sx = new SimpleXMLElement($xml);
  193. } catch (Exception $e) {
  194. $this->fail('Unable to parse generated XML');
  195. }
  196. $this->assertTrue($sx->fault ? true : false, $xml);
  197. $this->assertTrue($sx->fault->value ? true : false, $xml);
  198. $this->assertTrue($sx->fault->value->struct ? true : false, $xml);
  199. $count = 0;
  200. foreach ($sx->fault->value->struct->member as $member) {
  201. $count++;
  202. $this->assertTrue($member->name ? true : false, $xml);
  203. $this->assertTrue($member->value ? true : false, $xml);
  204. if ('faultCode' == (string) $member->name) {
  205. $this->assertTrue($member->value->int ? true : false, $xml);
  206. $this->assertEquals(1000, (int) $member->value->int, $xml);
  207. }
  208. if ('faultString' == (string) $member->name) {
  209. $this->assertTrue($member->value->string ? true : false, $xml);
  210. $this->assertEquals('Fault message', (string) $member->value->string, $xml);
  211. }
  212. }
  213. $this->assertEquals(2, $count, $xml);
  214. }
  215. /**
  216. * saveXml() test
  217. */
  218. public function testSaveXML()
  219. {
  220. $this->_fault->setCode(1000);
  221. $this->_fault->setMessage('Fault message');
  222. $xml = $this->_fault->saveXml();
  223. $this->_testXmlFault($xml);
  224. }
  225. /**
  226. * __toString() test
  227. */
  228. public function test__toString()
  229. {
  230. $this->_fault->setCode(1000);
  231. $this->_fault->setMessage('Fault message');
  232. $xml = $this->_fault->__toString();
  233. $this->_testXmlFault($xml);
  234. }
  235. /**
  236. * Test encoding settings
  237. */
  238. public function testSetGetEncoding()
  239. {
  240. $this->assertEquals('UTF-8', $this->_fault->getEncoding());
  241. $this->assertEquals('UTF-8', Zend_XmlRpc_Value::getGenerator()->getEncoding());
  242. $this->_fault->setEncoding('ISO-8859-1');
  243. $this->assertEquals('ISO-8859-1', $this->_fault->getEncoding());
  244. $this->assertEquals('ISO-8859-1', Zend_XmlRpc_Value::getGenerator()->getEncoding());
  245. }
  246. public function testUnknownErrorIsUsedIfUnknownErrorCodeEndEmptyMessageIsPassed()
  247. {
  248. $fault = new Zend_XmlRpc_Fault(1234);
  249. $this->assertSame(1234, $fault->getCode());
  250. $this->assertSame('Unknown error', $fault->getMessage());
  251. }
  252. public function testFaultStringWithoutStringTypeDeclaration()
  253. {
  254. $xml = $this->_createNonStandardXml();
  255. try {
  256. $parsed = $this->_fault->loadXml($xml);
  257. } catch (Exception $e) {
  258. $this->fail('Failed to parse XML: ' . $e->getMessage());
  259. }
  260. $this->assertTrue($parsed, $xml);
  261. $this->assertEquals('Error string', $this->_fault->getMessage());
  262. }
  263. }