blob: d9fa95bf416265f53f1b317b057e823b24b00ee2 [file] [log] [blame]
<?php
/**
* ezcDocumentWikiParserTests
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
* @package Document
* @version //autogen//
* @subpackage Tests
* @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
*/
require_once 'helper/wiki_dummy_directives.php';
/**
* Test suite for class.
*
* @package Document
* @subpackage Tests
*/
class ezcDocumentWikiDocbookVisitorTests extends ezcTestCase
{
protected static $testDocuments = null;
public static function suite()
{
return new PHPUnit_Framework_TestSuite( __CLASS__ );
}
public static function getTestDocuments()
{
if ( self::$testDocuments === null )
{
// Get a list of all test files from the respektive folder
$testFiles = glob( dirname( __FILE__ ) . '/files/wiki/*/s_*.txt' );
// Create array with the test file and the expected result file
foreach ( $testFiles as $file )
{
self::$testDocuments[] = array(
$file,
substr( $file, 0, -3 ) . 'xml'
);
}
}
return self::$testDocuments;
return array_slice( self::$testDocuments, 72, 1 );
}
/**
* @dataProvider getTestDocuments
*/
public function testParseWikiFile( $from, $to )
{
if ( !is_file( $to ) )
{
$this->markTestSkipped( "Comparision file '$to' not yet defined." );
}
$type = ucfirst( basename( dirname( $from ) ) );
$tokenizerClass = 'ezcDocumentWiki' . $type . 'Tokenizer';
$document = new ezcDocumentWiki();
$document->options->errorReporting = E_PARSE | E_ERROR | E_WARNING;
$document->options->tokenizer = new $tokenizerClass();
$document->registerPlugin( 'currenttimeplugin', 'ezcDocumentTestDummyPlugin' );
$document->registerPlugin( 'calendar', 'ezcDocumentTestDummyPlugin' );
$document->registerPlugin( 'html', 'ezcDocumentTestDummyPlugin' );
$document->registerPlugin( 'php', 'ezcDocumentTestDummyPlugin' );
$document->loadFile( $from );
$docbook = $document->getAsDocbook();
$xml = $docbook->save();
// Store test file, to have something to compare on failure
$tempDir = $this->createTempDir( 'wiki_visitor_' . $type . '_' ) . '/';
file_put_contents( $tempDir . basename( $to ), $xml );
// Validate generated docbook
$this->assertTrue( $docbook->validateString( $xml ) );
$this->assertEquals(
file_get_contents( $to ),
$xml,
'Document not visited as expected.'
);
// Remove tempdir, when nothing failed.
$this->removeTempDir();
}
}
?>