Skip to content

Commit

Permalink
HTML API: Add tests confirming comment behavior in HTML Processor.
Browse files Browse the repository at this point in the history
There was a bug-fix late in the 6.6 cycle in the HTML Processor which
resolved an issue with the wrong name being reported when paused at
processing-instruction look-alike invalid comments, but no tests were
added to enforce the correct behaviors.

This patch adds the missing tests.

Developed in WordPress#6765
Discussed in https://core.trac.wordpress.org/ticket/61530

Follow-up to [58304], [58558].

Props dmsnell, jonsurrell.
See #61530.


git-svn-id: https://develop.svn.wordpress.org/trunk@58734 602fd350-edb4-49c9-b593-d223f7449a82
  • Loading branch information
dmsnell committed Jul 16, 2024
1 parent 36ac310 commit bd61b0b
Showing 1 changed file with 76 additions and 0 deletions.
76 changes: 76 additions & 0 deletions tests/phpunit/tests/html-api/wpHtmlProcessorComments.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
<?php
/**
* Unit tests covering WP_HTML_Processor functionality.
*
* @package WordPress
* @subpackage HTML-API
*
* @since 6.7.0
*
* @group html-api
*
* @coversDefaultClass WP_HTML_Processor
*/
class Tests_HtmlApi_WpHtmlProcessorComments extends WP_UnitTestCase {
/**
* Ensures that different types of comments are processed correctly.
*
* @ticket 61530
*
* @dataProvider data_comments
*/
public function test_comment_processing( string $html, string $expected_comment_type, string $expected_modifiable_text, string $expected_tag = null ) {
$processor = WP_HTML_Processor::create_fragment( $html );
$processor->next_token();

$this->assertSame( '#comment', $processor->get_token_name() );
$this->assertSame( $expected_comment_type, $processor->get_comment_type() );
$this->assertSame( $expected_modifiable_text, $processor->get_modifiable_text() );
$this->assertSame( $expected_tag, $processor->get_tag() );
}

/**
* Data provider.
*
* @return array[]
*/
public static function data_comments() {
return array(
'Normative comment' => array( '<!-- A comment. -->', WP_HTML_Processor::COMMENT_AS_HTML_COMMENT, ' A comment. ' ),
'Abruptly closed comment' => array( '<!-->', WP_HTML_Processor::COMMENT_AS_ABRUPTLY_CLOSED_COMMENT, '' ),
'Invalid HTML comment !' => array( '<! Bang opener >', WP_HTML_Processor::COMMENT_AS_INVALID_HTML, ' Bang opener ' ),
'Invalid HTML comment ?' => array( '<? Question opener >', WP_HTML_Processor::COMMENT_AS_INVALID_HTML, ' Question opener ' ),
'CDATA comment' => array( '<![CDATA[ cdata body ]]>', WP_HTML_Processor::COMMENT_AS_CDATA_LOOKALIKE, ' cdata body ' ),
'Processing instriction comment' => array( '<?pi-target Instruction body. ?>', WP_HTML_Processor::COMMENT_AS_PI_NODE_LOOKALIKE, ' Instruction body. ', 'pi-target' ),
'Processing instriction php' => array( '<?php const HTML_COMMENT = true; ?>', WP_HTML_Processor::COMMENT_AS_PI_NODE_LOOKALIKE, ' const HTML_COMMENT = true; ', 'php' ),
);
}

/**
* Ensures that different types of comments are processed correctly.
*
* @ticket 61530
*
* @dataProvider data_funky_comments
*/
public function test_funky_comment( string $html, string $expected_modifiable_text ) {
$processor = WP_HTML_Processor::create_fragment( $html );
$processor->next_token();

$this->assertSame( '#funky-comment', $processor->get_token_name() );
$this->assertSame( $expected_modifiable_text, $processor->get_modifiable_text() );
}

/**
* Data provider.
*
* @return array[]
*/
public static function data_funky_comments() {
return array(
'Funky comment # (empty)' => array( '</#>', '#' ),
'Funky comment #' => array( '</# foo>', '# foo' ),
'Funky comment •' => array( '</• bar>', '• bar' ),
);
}
}

0 comments on commit bd61b0b

Please sign in to comment.