lexer     = new HTMLPurifier_Lexer_DirectLex();
        $this->generator = new HTMLPurifier_Generator();
        parent::UnitTestCase();
    }
    
    /**
     * Asserts a specific result from a one parameter + config/context function
     * @param $input Input parameter
     * @param $expect Expectation
     * @param $config_array Configuration array in form of
     *                      Namespace.Directive => Value or an actual config
     *                      object.
     * @param $context_array Context array in form of Key => Value or an actual
     *                       context object.
     */
    function assertResult($input, $expect = true,
        $config_array = array(), $context_array = array()
    ) {
        
        // setup config object
        $config  = HTMLPurifier_Config::createDefault();
        $config->loadArray($config_array);
        
        // setup context object. Note that we are operating on a copy of it!
        // We will extend the test harness to allow you to do post-tests
        // on the context object
        $context = new HTMLPurifier_Context();
        $context->loadArray($context_array);
        
        if ($this->to_tokens && is_string($input)) {
            $input = $this->lexer->tokenizeHTML($input, $config, $context);
        }
        
        // call the function
        $func = $this->func;
        $result = $this->obj->$func($input, $config, $context);
        
        // test a bool result
        if (is_bool($result)) {
            $this->assertIdentical($expect, $result);
            return;
        } elseif (is_bool($expect)) {
            $expect = $input;
        }
        
        if ($this->to_html) {
            $result = $this->generator->
              generateFromTokens($result, $config, $context);
            if (is_array($expect)) {
                $expect = $this->generator->
                  generateFromTokens($expect, $config, $context);
            }
        }
        
        $this->assertEqual($expect, $result);
        
    }
    
}
?>