document_docbook_test.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <?php
  2. /**
  3. * ezcDocumentDocbookTests
  4. *
  5. * Licensed to the Apache Software Foundation (ASF) under one
  6. * or more contributor license agreements. See the NOTICE file
  7. * distributed with this work for additional information
  8. * regarding copyright ownership. The ASF licenses this file
  9. * to you under the Apache License, Version 2.0 (the
  10. * "License"); you may not use this file except in compliance
  11. * with the License. You may obtain a copy of the License at
  12. *
  13. * http://www.apache.org/licenses/LICENSE-2.0
  14. *
  15. * Unless required by applicable law or agreed to in writing,
  16. * software distributed under the License is distributed on an
  17. * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  18. * KIND, either express or implied. See the License for the
  19. * specific language governing permissions and limitations
  20. * under the License.
  21. *
  22. * @package Document
  23. * @version //autogen//
  24. * @subpackage Tests
  25. * @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
  26. */
  27. /**
  28. * Test suite for class.
  29. *
  30. * @package Document
  31. * @subpackage Tests
  32. */
  33. class ezcDocumentDocbookTests extends ezcTestCase
  34. {
  35. protected static $testDocuments = null;
  36. public static function suite()
  37. {
  38. return new PHPUnit_Framework_TestSuite( __CLASS__ );
  39. }
  40. public static function getDocbookDocuments()
  41. {
  42. if ( self::$testDocuments === null )
  43. {
  44. // Get a list of all test files from the respektive folder
  45. $testFiles = glob( dirname( __FILE__ ) . '/files/docbook/rst/s_*.xml' );
  46. // Create array with the test file and the expected result file
  47. foreach ( $testFiles as $file )
  48. {
  49. self::$testDocuments[] = array(
  50. $file
  51. );
  52. }
  53. }
  54. return self::$testDocuments;
  55. return array_slice( self::$testDocuments, 18, 40 );
  56. }
  57. /**
  58. * @dataProvider getDocbookDocuments
  59. */
  60. public function testValidateDocbook( $file )
  61. {
  62. $doc = new ezcDocumentDocbook();
  63. $this->assertTrue(
  64. $doc->validateFile( $file )
  65. );
  66. }
  67. public function testValidateErrorneousDocbook()
  68. {
  69. $doc = new ezcDocumentDocbook();
  70. $this->assertTrue(
  71. is_array( $errors = $doc->validateFile( dirname( __FILE__ ) . '/files/docbook/errorneous.xml' ) )
  72. );
  73. $this->assertSame(
  74. 'Fatal error in 7:13: Opening and ending tag mismatch: section line 4 and Section.',
  75. (string) $errors[0]
  76. );
  77. }
  78. public function testValidateInvalidDocbook()
  79. {
  80. $doc = new ezcDocumentDocbook();
  81. $this->assertTrue(
  82. is_array( $errors = $doc->validateFile( dirname( __FILE__ ) . '/files/docbook/invalid.xml' ) )
  83. );
  84. $this->assertSame(
  85. 'Error in 4:0: Element \'{http://docbook.org/ns/docbook}section\', attribute \'id\': The attribute \'id\' is not allowed..',
  86. (string) $errors[0]
  87. );
  88. }
  89. }
  90. ?>