mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-02 21:01:52 +00:00
[3.1.0] Fix broken autoloader, resulting in duplicate classes
- Factor out phpt directory parsing - More phpt tests git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1561 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
a3b6a15595
commit
40d3d5b961
1
TODO
1
TODO
@ -24,6 +24,7 @@ IMPORTANT
|
||||
- Release candidate, because of the major changes
|
||||
- Move utility classes for ConfigSchema into HTML Purifier itself: they're
|
||||
that important
|
||||
- Allow unit tests to be run w/o PHPT
|
||||
|
||||
DOCUMENTATION
|
||||
- Document new ConfigSchema setup and format; dev-includes.txt is a base
|
||||
|
@ -11,6 +11,7 @@ class HTMLPurifierExtras
|
||||
$path = HTMLPurifierExtras::getPath($class);
|
||||
if (!$path) return false;
|
||||
require $path;
|
||||
return true;
|
||||
}
|
||||
|
||||
public static function getPath($class) {
|
||||
|
@ -0,0 +1,19 @@
|
||||
--TEST--
|
||||
HTMLPurifier.auto.php without spl_autoload_register without userland autoload loading test
|
||||
--SKIPIF--
|
||||
<?php
|
||||
if (function_exists('spl_autoload_register')) {
|
||||
echo "skip - spl_autoload_register() available";
|
||||
}
|
||||
--FILE--
|
||||
<?php
|
||||
assert("!function_exists('__autoload')");
|
||||
require_once '../library/HTMLPurifier.auto.php';
|
||||
$config = HTMLPurifier_Config::createDefault();
|
||||
$purifier = new HTMLPurifier($config);
|
||||
echo $purifier->purify('<b>Salsa!') . PHP_EOL;
|
||||
assert("function_exists('__autoload')");
|
||||
|
||||
--EXPECT--
|
||||
<b>Salsa!</b>
|
||||
|
@ -9,8 +9,8 @@ if (!defined('HTMLPurifierTest')) {
|
||||
// is not allowed
|
||||
function __autoload($class) {
|
||||
if (!function_exists('spl_autoload_register')) {
|
||||
if (class_exists('HTMLPurifier_Bootstrap', false) && HTMLPurifier_Bootstrap::autoload($class)) return true;
|
||||
if (class_exists('HTMLPurifierExtras', false) && HTMLPurifierExtras::autoload($class)) return true;
|
||||
if (HTMLPurifier_Bootstrap::autoload($class)) return true;
|
||||
if (HTMLPurifierExtras::autoload($class)) return true;
|
||||
}
|
||||
require str_replace('_', '/', $class) . '.php';
|
||||
return true;
|
||||
|
@ -35,6 +35,9 @@ $AC['only-phpt'] = false;
|
||||
$aliases = array(
|
||||
'f' => 'file',
|
||||
);
|
||||
|
||||
// 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 (!SimpleReporter::inCli()) {
|
||||
@ -47,17 +50,6 @@ if ($AC['disable-phpt'] && $AC['only-phpt']) {
|
||||
exit(1);
|
||||
}
|
||||
|
||||
if (!$AC['disable-phpt']) {
|
||||
$phpt = PHPT_Registry::getInstance();
|
||||
$phpt->php = $AC['php'];
|
||||
}
|
||||
|
||||
if ($AC['flush']) {
|
||||
shell_exec($AC['php'] . ' ../maintenance/generate-schema-cache.php');
|
||||
shell_exec($AC['php'] . ' ../maintenance/flush-definition-cache.php');
|
||||
shell_exec($AC['php'] . ' ../maintenance/merge-library.php');
|
||||
}
|
||||
|
||||
// initialize and load HTML Purifier
|
||||
// use ?standalone to load the alterative standalone stub
|
||||
if ($AC['standalone']) {
|
||||
@ -71,13 +63,37 @@ if ($AC['standalone']) {
|
||||
}
|
||||
require 'HTMLPurifier/Harness.php';
|
||||
|
||||
// Shell-script code is executed
|
||||
|
||||
if ($AC['flush']) {
|
||||
shell_exec($AC['php'] . ' ../maintenance/generate-schema-cache.php');
|
||||
shell_exec($AC['php'] . ' ../maintenance/flush-definition-cache.php');
|
||||
shell_exec($AC['php'] . ' ../maintenance/merge-library.php');
|
||||
}
|
||||
|
||||
// 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
|
||||
$test_files = array();
|
||||
$phpt_dirs = array();
|
||||
require 'test_files.php'; // populates $test_files array
|
||||
// handle phpt files
|
||||
foreach ($phpt_dirs as $dir) {
|
||||
$FS = new FSTools();
|
||||
$phpt_files = $FS->globr($dir, '*.phpt');
|
||||
foreach ($phpt_files as $file) {
|
||||
$test_files[] = str_replace('\\', '/', $file);
|
||||
}
|
||||
}
|
||||
sort($test_files); // for the SELECT
|
||||
$GLOBALS['HTMLPurifierTest']['Files'] = $test_files; // for the reporter
|
||||
$test_file_lookup = array_flip($test_files);
|
||||
|
@ -150,12 +150,4 @@ $test_files[] = 'ConfigSchema/StringHashTest.php';
|
||||
if (!$AC['disable-phpt']) {
|
||||
$phpt_dirs = array();
|
||||
$phpt_dirs[] = 'HTMLPurifier/PHPT';
|
||||
|
||||
foreach ($phpt_dirs as $dir) {
|
||||
$FS = new FSTools();
|
||||
$phpt_files = $FS->globr($dir, '*.phpt');
|
||||
foreach ($phpt_files as $file) {
|
||||
$test_files[] = str_replace('\\', '/', $file);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user