<?php /** @file * Unit tester * * The heart and soul of HTML Purifier's correctness; anything and everything * is tested here! Arguments are specified like --arg=opt, allowed arguments * are: * - flush, whether or not to flush definition caches before running * - standalone, whether or not to test the standalone version * - file (f), a single file to test * - xml, whether or not to output XML * - dry, whether or not to do a dry run * - type, the type of tests to run, can be 'htmlpurifier', 'configdoc', * 'fstools', 'htmlt', 'vtest' or 'phpt' * * If you're interested in running the test-cases, mosey over to * ../test-settings.sample.php, copy the file to test-settings.php and follow * the enclosed instructions. * * @warning File setup does not exactly match with autoloader; make sure that * non-test classes (i.e. classes that are not retrieved using * $test_files) do not have underscores in their names. */ // HTML Purifier runs error free on E_STRICT, so if code reports // errors, we want to know about it. error_reporting(E_ALL | E_STRICT); // Because we always want to know about errors, and because SimpleTest // will notify us about them, logging the errors to stderr is // counterproductive and in fact the wrong thing when a test case // exercises an error condition to detect for it. ini_set('log_errors', false); define('HTMLPurifierTest', 1); define('HTMLPURIFIER_SCHEMA_STRICT', true); // validate schemas chdir(dirname(__FILE__)); $php = 'php'; // for safety ini_set('memory_limit', '64M'); require 'common.php'; $AC = array(); // parameters $AC['flush'] = false; $AC['standalone'] = false; $AC['file'] = ''; $AC['xml'] = false; $AC['dry'] = false; $AC['php'] = $php; $AC['help'] = false; $AC['verbose'] = false; $AC['txt'] = false; $AC['type'] = ''; $AC['disable-phpt'] = false; $AC['only-phpt'] = false; // alias for --type=phpt $aliases = array( 'f' => 'file', 'h' => 'help', 'v' => 'verbose', ); // It's important that this does not call the autoloader. Not a problem // with a function, but could be if we put this in a class. htmlpurifier_parse_args($AC, $aliases); if ($AC['help']) { ?>HTML Purifier test suite Allowed options: --flush --standalone --file (-f) HTMLPurifier/NameOfTest.php --xml --txt --dry --php /path/to/php --type ( htmlpurifier | configdoc | fstools | htmlt | vtest | phpt ) --disable-phpt --verbose (-v) <?php exit; } // Disable PHPT tests if they're not enabled if (!$GLOBALS['HTMLPurifierTest']['PHPT']) { $AC['disable-phpt'] = true; } elseif (!$AC['type'] && $AC['only-phpt']) { // backwards-compat $AC['type'] = 'phpt'; } if (!SimpleReporter::inCli()) { // Undo any dangerous parameters $AC['php'] = $php; } // initialize and load HTML Purifier // use ?standalone to load the alterative standalone stub if ($AC['standalone']) { require '../library/HTMLPurifier.standalone.php'; } else { require '../library/HTMLPurifier.path.php'; require 'HTMLPurifier.includes.php'; } require '../library/HTMLPurifier.autoload.php'; require 'HTMLPurifier/Harness.php'; // immediately load external libraries, so we can bail out early if // they're bad if ($GLOBALS['HTMLPurifierTest']['PEAR']) { if ($GLOBALS['HTMLPurifierTest']['Net_IDNA2']) { require_once 'Net/IDNA2.php'; } } // Shell-script code is executed if ($AC['xml']) { if (!SimpleReporter::inCli()) header('Content-Type: text/xml;charset=UTF-8'); $reporter = new XmlReporter(); } elseif (SimpleReporter::inCli() || $AC['txt']) { if (!SimpleReporter::inCli()) header('Content-Type: text/plain;charset=UTF-8'); $reporter = new HTMLPurifier_SimpleTest_TextReporter($AC); } else { $reporter = new HTMLPurifier_SimpleTest_Reporter('UTF-8', $AC); } if ($AC['flush']) { htmlpurifier_flush($AC['php'], $reporter); } // Now, userland code begins to be executed // setup special DefinitionCacheFactory decorator $factory = HTMLPurifier_DefinitionCacheFactory::instance(); $factory->addDecorator('Memory'); // since we deal with a lot of config objects if (!$AC['disable-phpt']) { $phpt = PHPT_Registry::getInstance(); $phpt->php = $AC['php']; } // load tests require 'test_files.php'; $FS = new FSTools(); // handle test dirs foreach ($test_dirs as $dir) { $raw_files = $FS->globr($dir, '*Test.php'); foreach ($raw_files as $file) { $file = str_replace('\\', '/', $file); if (isset($test_dirs_exclude[$file])) continue; $test_files[] = $file; } } // handle vtest dirs foreach ($vtest_dirs as $dir) { $raw_files = $FS->globr($dir, '*.vtest'); foreach ($raw_files as $file) { $test_files[] = str_replace('\\', '/', $file); } } // handle phpt files foreach ($phpt_dirs as $dir) { $phpt_files = $FS->globr($dir, '*.phpt'); foreach ($phpt_files as $file) { $test_files[] = str_replace('\\', '/', $file); } } // handle htmlt dirs foreach ($htmlt_dirs as $dir) { $htmlt_files = $FS->globr($dir, '*.htmlt'); foreach ($htmlt_files as $file) { $test_files[] = str_replace('\\', '/', $file); } } array_unique($test_files); sort($test_files); // for the SELECT $GLOBALS['HTMLPurifierTest']['Files'] = $test_files; // for the reporter $test_file_lookup = array_flip($test_files); // determine test file if ($AC['file']) { if (!isset($test_file_lookup[$AC['file']])) { echo "Invalid file passed\n"; exit; } } if ($AC['file']) { $test = new TestSuite($AC['file']); htmlpurifier_add_test($test, $AC['file']); } else { $standalone = ''; if ($AC['standalone']) $standalone = ' (standalone)'; $test = new TestSuite('All HTML Purifier tests on PHP ' . PHP_VERSION . $standalone); foreach ($test_files as $test_file) { htmlpurifier_add_test($test, $test_file); } } if ($AC['dry']) $reporter->makeDry(); $test->run($reporter); // vim: et sw=4 sts=4