fDOMXPath.test.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. /**
  3. * Copyright (c) 2010-2017 Arne Blankerts <arne@blankerts.de>
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without modification,
  7. * are permitted provided that the following conditions are met:
  8. *
  9. * * Redistributions of source code must retain the above copyright notice,
  10. * this list of conditions and the following disclaimer.
  11. *
  12. * * Redistributions in binary form must reproduce the above copyright notice,
  13. * this list of conditions and the following disclaimer in the documentation
  14. * and/or other materials provided with the distribution.
  15. *
  16. * * Neither the name of Arne Blankerts nor the names of contributors
  17. * may be used to endorse or promote products derived from this software
  18. * without specific prior written permission.
  19. *
  20. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  21. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT * NOT LIMITED TO,
  22. * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  23. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER ORCONTRIBUTORS
  24. * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
  25. * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  26. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  27. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  28. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  29. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  30. * POSSIBILITY OF SUCH DAMAGE.
  31. *
  32. *
  33. * @category PHP
  34. * @package TheSeer\fDOM
  35. * @author Arne Blankerts <arne@blankerts.de>
  36. * @copyright Arne Blankerts <arne@blankerts.de>, All rights reserved.
  37. * @license http://www.opensource.org/licenses/bsd-license.php BSD License
  38. * @link http://github.com/theseer/fdomdocument
  39. *
  40. */
  41. namespace TheSeer\fDOM\Tests {
  42. use TheSeer\fDOM\fDOMDocument;
  43. use TheSeer\fDOM\fDOMXPath;
  44. /**
  45. *
  46. * @author Arne Blankerts <arne@blankerts.de>
  47. * @copyright Arne Blankerts <arne@blankerts.de>, All rights reserved.
  48. */
  49. class fDOMXPathTest extends \PHPUnit\Framework\TestCase {
  50. /**
  51. * @var TheSeer\fDOM\fDOMDocument
  52. */
  53. private $dom;
  54. /**
  55. * @var TheSeer\fDOM\fDOMXPath
  56. */
  57. private $xp;
  58. public function setUp() {
  59. $this->dom = new fDOMDocument();
  60. $this->dom->loadXML('<?xml version="1.0" ?><root><node attr="foo" /></root>');
  61. $this->xp = $this->dom->getDOMXPath();
  62. }
  63. /**
  64. * @covers TheSeer\fDOM\fDOMXPath::query
  65. * @expectedException TheSeer\fDOM\fDOMException
  66. */
  67. public function testExecutingAQueryWithInvalidXPathThrowsException() {
  68. $this->xp->query('//[invalid');
  69. }
  70. public function testQueryReturnsNodeList() {
  71. $res = $this->xp->query('//*');
  72. $this->assertInstanceOf('DOMNodeList', $res);
  73. $this->assertEquals(2, $res->length);
  74. }
  75. /**
  76. * @covers TheSeer\fDOM\fDOMXPath::evaluate
  77. * @expectedException TheSeer\fDOM\fDOMException
  78. */
  79. public function testExecutingAQueryWithEvaluateWithInvalidXPathThrowsException() {
  80. $this->xp->evaluate('//[invalid');
  81. }
  82. /**
  83. * @covers TheSeer\fDOM\fDOMXPath::quote
  84. */
  85. public function testPrepareReturnsStraightStringOnPlainText() {
  86. $this->assertEquals('"test"', $this->xp->quote('test'));
  87. }
  88. public function testQueryOneReturnsANode() {
  89. $this->assertSame($this->dom->documentElement, $this->xp->queryOne('//root'));
  90. }
  91. public function testPrepareReturnsUnmodifiedXPathOnEmptyArray() {
  92. $xpath = 'test';
  93. $this->assertEquals($xpath, $this->xp->prepare($xpath, array()));
  94. }
  95. public function testQueryOneReturnsValueOnNonNodeQuery() {
  96. $this->assertEquals('1', $this->xp->queryOne('count(//root)'));
  97. }
  98. }
  99. }