218 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			218 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?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
 | 
