From 3ecce35e4741259c2fa3e7d9468c4f9878202fdf Mon Sep 17 00:00:00 2001 From: "Davis W. Frank" Date: Thu, 14 Nov 2024 14:33:33 -0600 Subject: [PATCH] Updates Node#parse with keyword arguments; updates tests to test parsing HTML4 and XML parsing w/ positional and keyword args --- lib/nokogiri/xml/node.rb | 2 +- test/xml/test_node.rb | 29 +++++++++++++++++++++++++++++ 2 files changed, 30 insertions(+), 1 deletion(-) diff --git a/lib/nokogiri/xml/node.rb b/lib/nokogiri/xml/node.rb index c90a64cabc0..41538a80ed9 100644 --- a/lib/nokogiri/xml/node.rb +++ b/lib/nokogiri/xml/node.rb @@ -1102,7 +1102,7 @@ def fragment(tags) # Parse +string_or_io+ as a document fragment within the context of # *this* node. Returns a XML::NodeSet containing the nodes parsed from # +string_or_io+. - def parse(string_or_io, options = nil) + def parse(string_or_io, options_ = nil, options: options_) ## # When the current node is unparented and not an element node, use the # document as the parsing context instead. Otherwise, the in-context diff --git a/test/xml/test_node.rb b/test/xml/test_node.rb index abb11161a34..3c21124b3cb 100644 --- a/test/xml/test_node.rb +++ b/test/xml/test_node.rb @@ -153,6 +153,35 @@ def test_node_context_parsing_of_malformed_html_fragment_without_recover_is_not_ end end + def test_node_context_parsing_of_malformed_html_fragment_without_recover_is_not_corrected_keyword + skip("libxml2 2.14.0 no longer raises this error") if Nokogiri.uses_libxml?(">= 2.14.0") + + doc = HTML4.parse("
") + context_node = doc.at_css("div") + assert_raises(Nokogiri::XML::SyntaxError) do + context_node.parse("
", options: ParseOptions.new) + end + end + + def test_node_context_parsing_of_malformed_xml_fragment_without_recover_is_not_corrected + skip("libxml2 2.14.0 no longer raises this error") if Nokogiri.uses_libxml?(">= 2.14.0") + + doc = XML.parse("
", &:strict) + end + end + def test_node_context_parsing_of_malformed_xml_fragment_without_recover_is_not_corrected_keyword + skip("libxml2 2.14.0 no longer raises this error") if Nokogiri.uses_libxml?(">= 2.14.0") + + doc = XML.parse("
", options: ParseOptions.new) + end + end + def test_node_context_parsing_of_malformed_xml_fragment_uses_the_right_class_to_recover doc = XML.parse("
") context_node = doc.at_css("div")