document_wiki_parser_test.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <?php
  2. /**
  3. * ezcDocumentConverterEzp3TpEzp4Tests
  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 ezcDocumentWikiParserTests 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/wiki/*/*.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 ) . 'ast'
  52. );
  53. }
  54. }
  55. return self::$testDocuments;
  56. return array_slice( self::$testDocuments, 19, 1 );
  57. }
  58. /**
  59. * @dataProvider getTestDocuments
  60. */
  61. public function testParseFile( $from, $to )
  62. {
  63. if ( !is_file( $to ) )
  64. {
  65. $this->markTestSkipped( "Comparision file '$to' not yet defined." );
  66. }
  67. $type = ucfirst( basename( dirname( $from ) ) );
  68. $tokenizerClass = 'ezcDocumentWiki' . $type . 'Tokenizer';
  69. $tokenizer = new $tokenizerClass();
  70. $parser = new ezcDocumentWikiParser();
  71. $parser->options->errorReporting = E_PARSE | E_ERROR | E_WARNING;
  72. $ast = $parser->parse( $tokenizer->tokenizeFile( $from ) );
  73. $expected = include $to;
  74. // Store test file, to have something to compare on failure
  75. $tempDir = $this->createTempDir( 'wiki_parser_' . $type . '_' ) . '/';
  76. file_put_contents( $tempDir . basename( $to ), "<?php\n\nreturn " . var_export( $ast, true ) . ";\n\n" );
  77. $this->assertEquals(
  78. $expected,
  79. $ast,
  80. 'Extracted ast do not match expected ast.'
  81. );
  82. // Remove tempdir, when nothing failed.
  83. $this->removeTempDir();
  84. }
  85. }
  86. ?>