diff --git a/test/xml/sax/test_parser.rb b/test/xml/sax/test_parser.rb index b259369bdb..328deb88f7 100644 --- a/test/xml/sax/test_parser.rb +++ b/test/xml/sax/test_parser.rb @@ -1,4 +1,4 @@ -# -*- coding: utf-8 -*- +# frozen_string_literal: true require "helper" @@ -13,181 +13,175 @@ def setup def test_parser_context_yielded_io doc = Doc.new - parser = XML::SAX::Parser.new doc + parser = XML::SAX::Parser.new(doc) xml = "" block_called = false - parser.parse(StringIO.new(xml)) { |ctx| + parser.parse(StringIO.new(xml)) do |ctx| block_called = true ctx.replace_entities = true - } + end - assert block_called + assert(block_called) - assert_equal [["foo", [["a", "&b"]]]], doc.start_elements + assert_equal([["foo", [["a", "&b"]]]], doc.start_elements) end def test_parser_context_yielded_in_memory doc = Doc.new - parser = XML::SAX::Parser.new doc + parser = XML::SAX::Parser.new(doc) xml = "" block_called = false - parser.parse(xml) { |ctx| + parser.parse(xml) do |ctx| block_called = true ctx.replace_entities = true - } + end - assert block_called + assert(block_called) - assert_equal [["foo", [["a", "&b"]]]], doc.start_elements + assert_equal([["foo", [["a", "&b"]]]], doc.start_elements) end def test_empty_decl parser = XML::SAX::Parser.new(Doc.new) xml = "" - parser.parse xml - assert parser.document.start_document_called, xml - assert_nil parser.document.xmldecls, xml + parser.parse(xml) + assert(parser.document.start_document_called, xml) + assert_nil(parser.document.xmldecls, xml) end def test_xml_decl [ - ['', - ["1.0"]], - ['', - ["1.0", "UTF-8"]], - ['', - ["1.0", "yes"]], - ['', - ["1.0", "no"]], - ['', - ["1.0", "UTF-8", "no"]], - ['', - ["1.0", "ISO-8859-1", "yes"]], + ['', ["1.0"]], + ['', ["1.0", "UTF-8"]], + ['', ["1.0", "yes"]], + ['', ["1.0", "no"]], + ['', ["1.0", "UTF-8", "no"]], + ['', ["1.0", "ISO-8859-1", "yes"]], ].each do |decl, value| parser = XML::SAX::Parser.new(Doc.new) xml = "#{decl}\n" - parser.parse xml - assert parser.document.start_document_called, xml - assert_equal value, parser.document.xmldecls, xml + parser.parse(xml) + assert(parser.document.start_document_called, xml) + assert_equal(value, parser.document.xmldecls, xml) end end def test_parse_empty - assert_raises RuntimeError do + assert_raises(RuntimeError) do @parser.parse("") end end def test_namespace_declaration_order_is_saved - @parser.parse <<-eoxml - - - + @parser.parse(<<~eoxml) + + + eoxml - assert_equal 2, @parser.document.start_elements_namespace.length + assert_equal(2, @parser.document.start_elements_namespace.length) el = @parser.document.start_elements_namespace.first namespaces = el.last - assert_equal ["foo", "http://foo.example.com/"], namespaces.first - assert_equal [nil, "http://example.com/"], namespaces.last + assert_equal(["foo", "http://foo.example.com/"], namespaces.first) + assert_equal([nil, "http://example.com/"], namespaces.last) end def test_bad_document_calls_error_handler @parser.parse("") - assert @parser.document.errors - assert @parser.document.errors.length > 0 + assert(@parser.document.errors) + assert(@parser.document.errors.length > 0) end def test_namespace_are_super_fun_to_parse - @parser.parse <<-eoxml - - - - - - hello world - + @parser.parse(<<~eoxml) + + + + + + hello world + eoxml - assert @parser.document.start_elements_namespace.length > 0 + assert(@parser.document.start_elements_namespace.length > 0) el = @parser.document.start_elements_namespace[1] - assert_equal "a", el.first - assert_equal 1, el[1].length + assert_equal("a", el.first) + assert_equal(1, el[1].length) attribute = el[1].first - assert_equal "bar", attribute.localname - assert_equal "foo", attribute.prefix - assert_equal "hello", attribute.value - assert_equal "http://foo.example.com/", attribute.uri + assert_equal("bar", attribute.localname) + assert_equal("foo", attribute.prefix) + assert_equal("hello", attribute.value) + assert_equal("http://foo.example.com/", attribute.uri) end def test_sax_v1_namespace_attribute_declarations - @parser.parse <<-eoxml - - - - - - hello world - + @parser.parse(<<~eoxml) + + + + + + hello world + eoxml - assert @parser.document.start_elements.length > 0 + assert(@parser.document.start_elements.length > 0) elm = @parser.document.start_elements.first - assert_equal "root", elm.first - assert elm[1].include?(["xmlns:foo", "http://foo.example.com/"]) - assert elm[1].include?(["xmlns", "http://example.com/"]) + assert_equal("root", elm.first) + assert(elm[1].include?(["xmlns:foo", "http://foo.example.com/"])) + assert(elm[1].include?(["xmlns", "http://example.com/"])) end def test_sax_v1_namespace_nodes - @parser.parse <<-eoxml - - - - - - hello world - + @parser.parse(<<~eoxml) + + + + + + hello world + eoxml - assert_equal 5, @parser.document.start_elements.length - assert @parser.document.start_elements.map(&:first).include?("foo:bar") - assert @parser.document.end_elements.map(&:first).include?("foo:bar") + assert_equal(5, @parser.document.start_elements.length) + assert(@parser.document.start_elements.map(&:first).include?("foo:bar")) + assert(@parser.document.end_elements.map(&:first).include?("foo:bar")) end def test_start_is_called_without_namespace - @parser.parse(<<-eoxml) - - - + @parser.parse(<<~eoxml) + + + eoxml - assert_equal ["root", "foo:f", "bar"], - @parser.document.start_elements.map(&:first) + assert_equal(["root", "foo:f", "bar"], + @parser.document.start_elements.map(&:first)) end def test_parser_sets_encoding parser = XML::SAX::Parser.new(Doc.new, "UTF-8") - assert_equal "UTF-8", parser.encoding + assert_equal("UTF-8", parser.encoding) end def test_errors_set_after_parsing_bad_dom doc = Nokogiri::XML("") - assert doc.errors + assert(doc.errors) @parser.parse("") - assert @parser.document.errors - assert @parser.document.errors.length > 0 + assert(@parser.document.errors) + assert(@parser.document.errors.length > 0) doc.errors.each do |error| - assert_equal "UTF-8", error.message.encoding.name + assert_equal("UTF-8", error.message.encoding.name) end # when using JRuby Nokogiri, more errors will be generated as the DOM # parser continue to parse an ill formed document, while the sax parser # will stop at the first error unless Nokogiri.jruby? - assert_equal doc.errors.length, @parser.document.errors.length + assert_equal(doc.errors.length, @parser.document.errors.length) end end @@ -197,76 +191,76 @@ def test_parse_with_memory_argument end def test_parse_with_io_argument - File.open(XML_FILE, "rb") { |f| + File.open(XML_FILE, "rb") do |f| @parser.parse(f) - } + end assert(@parser.document.cdata_blocks.length > 0) end def test_parse_io - call_parse_io_with_encoding "UTF-8" + call_parse_io_with_encoding("UTF-8") end # issue #828 def test_parse_io_lower_case_encoding - call_parse_io_with_encoding "utf-8" + call_parse_io_with_encoding("utf-8") end def call_parse_io_with_encoding(encoding) - File.open(XML_FILE, "rb") { |f| + File.open(XML_FILE, "rb") do |f| @parser.parse_io(f, encoding) - } + end assert(@parser.document.cdata_blocks.length > 0) called = false @parser.document.start_elements.flatten.each do |thing| - assert_equal "UTF-8", thing.encoding.name + assert_equal("UTF-8", thing.encoding.name) called = true end - assert called + assert(called) called = false @parser.document.end_elements.flatten.each do |thing| - assert_equal "UTF-8", thing.encoding.name + assert_equal("UTF-8", thing.encoding.name) called = true end - assert called + assert(called) called = false @parser.document.data.each do |thing| - assert_equal "UTF-8", thing.encoding.name + assert_equal("UTF-8", thing.encoding.name) called = true end - assert called + assert(called) called = false @parser.document.comments.flatten.each do |thing| - assert_equal "UTF-8", thing.encoding.name + assert_equal("UTF-8", thing.encoding.name) called = true end - assert called + assert(called) called = false @parser.document.cdata_blocks.flatten.each do |thing| - assert_equal "UTF-8", thing.encoding.name + assert_equal("UTF-8", thing.encoding.name) called = true end - assert called + assert(called) end def test_parse_file @parser.parse_file(XML_FILE) - assert_raises(ArgumentError) { + assert_raises(ArgumentError) do @parser.parse_file(nil) - } + end - assert_raises(Errno::ENOENT) { + assert_raises(Errno::ENOENT) do @parser.parse_file("") - } - assert_raises(Errno::EISDIR) { + end + assert_raises(Errno::EISDIR) do @parser.parse_file(File.expand_path(File.dirname(__FILE__))) - } + end end def test_render_parse_nil_param @@ -279,122 +273,120 @@ def test_bad_encoding_args end def test_ctag - @parser.parse_memory(<<-eoxml) + @parser.parse_memory(<<~eoxml)

Paragraph 1

eoxml - assert_equal [" This is a comment "], @parser.document.cdata_blocks + assert_equal([" This is a comment "], @parser.document.cdata_blocks) end def test_comment - @parser.parse_memory(<<-eoxml) + @parser.parse_memory(<<~eoxml)

Paragraph 1

eoxml - assert_equal [" This is a comment "], @parser.document.comments + assert_equal([" This is a comment "], @parser.document.comments) end def test_characters - @parser.parse_memory(<<-eoxml) + @parser.parse_memory(<<~eoxml)

Paragraph 1

eoxml - assert_equal ["Paragraph 1"], @parser.document.data + assert_equal(["Paragraph 1"], @parser.document.data) end def test_end_document - @parser.parse_memory(<<-eoxml) + @parser.parse_memory(<<~eoxml)

Paragraph 1

eoxml - assert @parser.document.end_document_called + assert(@parser.document.end_document_called) end def test_end_element - @parser.parse_memory(<<-eoxml) + @parser.parse_memory(<<~eoxml)

Paragraph 1

eoxml - assert_equal [["p"]], - @parser.document.end_elements + assert_equal([["p"]], @parser.document.end_elements) end def test_start_element_attrs - @parser.parse_memory(<<-eoxml) + @parser.parse_memory(<<~eoxml)

Paragraph 1

eoxml - assert_equal [["p", [["id", "asdfasdf"]]]], - @parser.document.start_elements + assert_equal([["p", [["id", "asdfasdf"]]]], @parser.document.start_elements) end def test_start_element_attrs_include_namespaces - @parser.parse_memory(<<-eoxml) + @parser.parse_memory(<<~eoxml)

Paragraph 1

eoxml - assert_equal [["p", [["xmlns:foo", "http://foo.example.com/"]]]], - @parser.document.start_elements + assert_equal([["p", [["xmlns:foo", "http://foo.example.com/"]]]], + @parser.document.start_elements) end def test_processing_instruction - @parser.parse_memory(<<-eoxml) + @parser.parse_memory(<<~eoxml) eoxml - assert_equal [["xml-stylesheet", 'href="a.xsl" type="text/xsl"']], - @parser.document.processing_instructions + assert_equal([["xml-stylesheet", 'href="a.xsl" type="text/xsl"']], + @parser.document.processing_instructions) end - if Nokogiri.uses_libxml? # JRuby SAXParser only parses well-formed XML documents - def test_parse_document - @parser.parse_memory(<<-eoxml) -

Paragraph 1

-

Paragraph 2

- eoxml - end + def test_parse_document + skip("JRuby SAXParser only parses well-formed XML documents") unless Nokogiri.uses_libxml? + @parser.parse_memory(<<~eoxml) +

Paragraph 1

+

Paragraph 2

+ eoxml end def test_parser_attributes - xml = <<-eoxml - + xml = <<~eoxml + eoxml block_called = false - @parser.parse(xml) { |ctx| + @parser.parse(xml) do |ctx| block_called = true ctx.replace_entities = true - } + end - assert block_called + assert(block_called) - assert_equal [["root", []], ["foo", [["a", "&b"], ["c", ">d"]]]], @parser.document.start_elements + assert_equal([["root", []], ["foo", [["a", "&b"], ["c", ">d"]]]], @parser.document.start_elements) end def test_recovery_from_incorrect_xml - xml = <<-eoxml -heyhey yourself + xml = <<~eoxml + heyhey yourself eoxml block_called = false - @parser.parse(xml) { |ctx| + @parser.parse(xml) do |ctx| block_called = true ctx.recovery = true - } + end - assert block_called + assert(block_called) - assert_equal [["Root", []], ["Data", []], ["Item", []], ["Data", []], ["Item", []]], @parser.document.start_elements + assert_equal([["Root", []], ["Data", []], ["Item", []], ["Data", []], ["Item", []]], + @parser.document.start_elements) end def test_square_bracket_in_text # issue 1261 - xml = <<-eoxml - - en:#:home_page:#:stories:#:[6]:#:name - Sandy S. - + xml = <<~eoxml + + en:#:home_page:#:stories:#:[6]:#:name + Sandy S. + eoxml @parser.parse(xml) - assert_includes @parser.document.data, "en:#:home_page:#:stories:#:[6]:#:name" + assert_includes(@parser.document.data, "en:#:home_page:#:stories:#:[6]:#:name") end end end