document_rst_tokenizer_test.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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 ezcDocumentRstTokenizerTests 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/rst/tokenizer/*.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 ) . 'tokens'
  52. );
  53. }
  54. }
  55. return self::$testDocuments;
  56. }
  57. /**
  58. * @dataProvider getTestDocuments
  59. */
  60. public function testTokenizeRstFile( $from, $to )
  61. {
  62. if ( !is_file( $to ) )
  63. {
  64. $this->markTestSkipped( "Comparision file '$to' not yet defined." );
  65. }
  66. $tokenizer = new ezcDocumentRstTokenizer();
  67. $tokens = $tokenizer->tokenizeFile( $from );
  68. $expected = include $to;
  69. // Store test file, to have something to compare on failure
  70. $tempDir = $this->createTempDir( 'rst_tokenizer_' ) . '/';
  71. file_put_contents( $tempDir . basename( $to ), "<?php\n\nreturn " . var_export( $tokens, true ) . ";\n\n" );
  72. $this->assertEquals(
  73. $expected,
  74. $tokens,
  75. 'Extracted tokens do not match expected tokens.'
  76. );
  77. // Remove tempdir, when nothing failed.
  78. $this->removeTempDir();
  79. }
  80. public function testNotExistantFile()
  81. {
  82. try
  83. {
  84. $tokenizer = new ezcDocumentRstTokenizer();
  85. $tokens = $tokenizer->tokenizeFile(
  86. dirname( __FILE__ ) . '/files/rst/tokenizer/not_existant_file.txt'
  87. );
  88. $this->fail( 'Expected ezcBaseFileNotFoundException.' );
  89. }
  90. catch ( ezcBaseFileNotFoundException $e )
  91. { /* Expected */ }
  92. }
  93. }
  94. ?>