docbook_visitor_test.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <?php
  2. /**
  3. * ezcDocumentBBCodeParserTests
  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 ezcDocumentBBCodeDocbookVisitorTests 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 getTestDocuments()
  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/bbcode/docbook/s_*.txt' );
  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. substr( $file, 0, -3 ) . 'xml'
  52. );
  53. }
  54. }
  55. return self::$testDocuments;
  56. return array_slice( self::$testDocuments, 72, 1 );
  57. }
  58. /**
  59. * @dataProvider getTestDocuments
  60. */
  61. public function testParseBBCodeFile( $from, $to )
  62. {
  63. if ( !is_file( $to ) )
  64. {
  65. $this->markTestSkipped( "Comparision file '$to' not yet defined." );
  66. }
  67. $document = new ezcDocumentBBCode();
  68. $document->options->errorReporting = E_PARSE | E_ERROR | E_WARNING;
  69. /*
  70. $document->registerPlugin( 'currenttimeplugin', 'ezcDocumentTestDummyPlugin' );
  71. $document->registerPlugin( 'calendar', 'ezcDocumentTestDummyPlugin' );
  72. $document->registerPlugin( 'html', 'ezcDocumentTestDummyPlugin' );
  73. $document->registerPlugin( 'php', 'ezcDocumentTestDummyPlugin' );
  74. */
  75. $document->loadFile( $from );
  76. $docbook = $document->getAsDocbook();
  77. $xml = $docbook->save();
  78. // Store test file, to have something to compare on failure
  79. $tempDir = $this->createTempDir( 'bbcode_visitor_' ) . '/';
  80. file_put_contents( $tempDir . basename( $to ), $xml );
  81. // Validate generated docbook
  82. $this->assertTrue( $docbook->validateString( $xml ) );
  83. $this->assertEquals(
  84. file_get_contents( $to ),
  85. $xml,
  86. 'Document not visited as expected.'
  87. );
  88. // Remove tempdir, when nothing failed.
  89. $this->removeTempDir();
  90. }
  91. }
  92. ?>