';
        
        $inputs[5] = new HTMLPurifier_Token_Empty('br');
        $expect[5] = '
';
        
        // test fault tolerance
        $inputs[6] = null;
        $expect[6] = '';
        
        // don't convert non-special characters
        $theta_char = $this->_entity_lookup->table['theta'];
        $inputs[7] = new HTMLPurifier_Token_Text($theta_char);
        $expect[7] = $theta_char;
        
        foreach ($inputs as $i => $input) {
            $result = $this->obj->generateFromToken($input);
            $this->assertEqual($result, $expect[$i]);
            paintIf($result, $result != $expect[$i]);
        }
        
    }
    
    function test_generateAttributes() {
        
        $inputs = $expect = array();
        
        $inputs[0] = array();
        $expect[0] = '';
        
        $inputs[1] = array('href' => 'dyn?a=foo&b=bar');
        $expect[1] = 'href="dyn?a=foo&b=bar"';
        
        $inputs[2] = array('style' => 'font-family:"Courier New";');
        $expect[2] = 'style="font-family:"Courier New";"';
        
        $inputs[3] = array('src' => 'picture.jpg', 'alt' => 'Short & interesting');
        $expect[3] = 'src="picture.jpg" alt="Short & interesting"';
        
        // don't escape nonspecial characters
        $theta_char = $this->_entity_lookup->table['theta'];
        $inputs[4] = array('title' => 'Theta is ' . $theta_char);
        $expect[4] = 'title="Theta is ' . $theta_char . '"';
        
        foreach ($inputs as $i => $input) {
            $result = $this->obj->generateAttributes($input);
            $this->assertEqual($result, $expect[$i]);
            paintIf($result, $result != $expect[$i]);
        }
        
    }
    
    function test_generateFromTokens() {
        
        $this->func = 'generateFromTokens';
        
        $this->assertResult(
            array(
                new HTMLPurifier_Token_Start('b'),
                new HTMLPurifier_Token_Text('Foobar!'),
                new HTMLPurifier_Token_End('b')
            ),
            'Foobar!'
        );
        
        $this->assertResult(array(), '');
        
    }
    
    var $config;
    function assertGeneration($tokens, $expect) {
        $context = new HTMLPurifier_Context();
        $result = $this->gen->generateFromTokens(
          $tokens, $this->config, $context);
        // normalized newlines, this probably should be put somewhere else
        $result = str_replace("\r\n", "\n", $result);
        $result = str_replace("\r", "\n", $result);
        $this->assertEqual($expect, $result);
    }
    
    function test_generateFromTokens_XHTMLoff() {
        $this->config = HTMLPurifier_Config::createDefault();
        $this->config->set('Core', 'XHTML', false);
        
        // omit trailing slash
        $this->assertGeneration(
            array( new HTMLPurifier_Token_Empty('br') ),
            '
'
        );
        
        // there should be a test for attribute minimization, but it is
        // impossible for something like that to happen due to our current
        // definitions! fix it later
        
        // namespaced attributes must be dropped
        $this->assertGeneration(
            array( new HTMLPurifier_Token_Start('p', array('xml:lang'=>'fr')) ),
            ''
        );
        
    }
    
    function test_generateFromTokens_TidyFormat() {
        // abort test if tidy isn't loaded
        if (!extension_loaded('tidy')) return;
        
        $this->config = HTMLPurifier_Config::createDefault();
        $this->config->set('Core', 'TidyFormat', true);
        
        // nice wrapping please
        $this->assertGeneration(
            array(
                new HTMLPurifier_Token_Start('div'),
                new HTMLPurifier_Token_Text('Text'),
                new HTMLPurifier_Token_End('div')
            ),
            "
\n  Text\n
\n"
        );
        
    }
    
}
?>