nokogiri 1.5.10 → 1.13.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of nokogiri might be problematic. Click here for more details.
- checksums.yaml +7 -0
- data/Gemfile +5 -0
- data/LICENSE-DEPENDENCIES.md +1903 -0
- data/LICENSE.md +9 -0
- data/README.md +280 -0
- data/bin/nokogiri +84 -31
- data/dependencies.yml +73 -0
- data/ext/nokogiri/depend +38 -358
- data/ext/nokogiri/extconf.rb +956 -100
- data/ext/nokogiri/gumbo.c +584 -0
- data/ext/nokogiri/html4_document.c +166 -0
- data/ext/nokogiri/html4_element_description.c +294 -0
- data/ext/nokogiri/html4_entity_lookup.c +37 -0
- data/ext/nokogiri/html4_sax_parser_context.c +120 -0
- data/ext/nokogiri/html4_sax_push_parser.c +95 -0
- data/ext/nokogiri/libxml2_backwards_compat.c +121 -0
- data/ext/nokogiri/nokogiri.c +232 -87
- data/ext/nokogiri/nokogiri.h +188 -129
- data/ext/nokogiri/test_global_handlers.c +40 -0
- data/ext/nokogiri/xml_attr.c +49 -40
- data/ext/nokogiri/xml_attribute_decl.c +18 -18
- data/ext/nokogiri/xml_cdata.c +24 -23
- data/ext/nokogiri/xml_comment.c +29 -21
- data/ext/nokogiri/xml_document.c +327 -223
- data/ext/nokogiri/xml_document_fragment.c +12 -16
- data/ext/nokogiri/xml_dtd.c +56 -50
- data/ext/nokogiri/xml_element_content.c +31 -26
- data/ext/nokogiri/xml_element_decl.c +22 -22
- data/ext/nokogiri/xml_encoding_handler.c +45 -20
- data/ext/nokogiri/xml_entity_decl.c +32 -30
- data/ext/nokogiri/xml_entity_reference.c +16 -18
- data/ext/nokogiri/xml_namespace.c +74 -32
- data/ext/nokogiri/xml_node.c +1290 -680
- data/ext/nokogiri/xml_node_set.c +239 -208
- data/ext/nokogiri/xml_processing_instruction.c +17 -19
- data/ext/nokogiri/xml_reader.c +227 -189
- data/ext/nokogiri/xml_relax_ng.c +52 -28
- data/ext/nokogiri/xml_sax_parser.c +123 -125
- data/ext/nokogiri/xml_sax_parser_context.c +138 -79
- data/ext/nokogiri/xml_sax_push_parser.c +88 -35
- data/ext/nokogiri/xml_schema.c +112 -33
- data/ext/nokogiri/xml_syntax_error.c +50 -23
- data/ext/nokogiri/xml_text.c +14 -18
- data/ext/nokogiri/xml_xpath_context.c +227 -140
- data/ext/nokogiri/xslt_stylesheet.c +162 -168
- data/gumbo-parser/CHANGES.md +63 -0
- data/gumbo-parser/Makefile +101 -0
- data/gumbo-parser/THANKS +27 -0
- data/gumbo-parser/src/Makefile +34 -0
- data/gumbo-parser/src/README.md +41 -0
- data/gumbo-parser/src/ascii.c +75 -0
- data/gumbo-parser/src/ascii.h +115 -0
- data/gumbo-parser/src/attribute.c +42 -0
- data/gumbo-parser/src/attribute.h +17 -0
- data/gumbo-parser/src/char_ref.c +22225 -0
- data/gumbo-parser/src/char_ref.h +29 -0
- data/gumbo-parser/src/char_ref.rl +2154 -0
- data/gumbo-parser/src/error.c +626 -0
- data/gumbo-parser/src/error.h +148 -0
- data/gumbo-parser/src/foreign_attrs.c +104 -0
- data/gumbo-parser/src/foreign_attrs.gperf +27 -0
- data/gumbo-parser/src/gumbo.h +943 -0
- data/gumbo-parser/src/insertion_mode.h +33 -0
- data/gumbo-parser/src/macros.h +91 -0
- data/gumbo-parser/src/parser.c +4875 -0
- data/gumbo-parser/src/parser.h +41 -0
- data/gumbo-parser/src/replacement.h +33 -0
- data/gumbo-parser/src/string_buffer.c +103 -0
- data/gumbo-parser/src/string_buffer.h +68 -0
- data/gumbo-parser/src/string_piece.c +48 -0
- data/gumbo-parser/src/svg_attrs.c +174 -0
- data/gumbo-parser/src/svg_attrs.gperf +77 -0
- data/gumbo-parser/src/svg_tags.c +137 -0
- data/gumbo-parser/src/svg_tags.gperf +55 -0
- data/gumbo-parser/src/tag.c +222 -0
- data/gumbo-parser/src/tag_lookup.c +382 -0
- data/gumbo-parser/src/tag_lookup.gperf +169 -0
- data/gumbo-parser/src/tag_lookup.h +13 -0
- data/gumbo-parser/src/token_buffer.c +79 -0
- data/gumbo-parser/src/token_buffer.h +71 -0
- data/gumbo-parser/src/token_type.h +17 -0
- data/gumbo-parser/src/tokenizer.c +3463 -0
- data/gumbo-parser/src/tokenizer.h +112 -0
- data/gumbo-parser/src/tokenizer_states.h +339 -0
- data/gumbo-parser/src/utf8.c +245 -0
- data/gumbo-parser/src/utf8.h +164 -0
- data/gumbo-parser/src/util.c +68 -0
- data/gumbo-parser/src/util.h +30 -0
- data/gumbo-parser/src/vector.c +111 -0
- data/gumbo-parser/src/vector.h +45 -0
- data/lib/nokogiri/class_resolver.rb +67 -0
- data/lib/nokogiri/css/node.rb +10 -58
- data/lib/nokogiri/css/parser.rb +327 -288
- data/lib/nokogiri/css/parser.y +67 -45
- data/lib/nokogiri/css/parser_extras.rb +52 -49
- data/lib/nokogiri/css/syntax_error.rb +3 -1
- data/lib/nokogiri/css/tokenizer.rb +107 -104
- data/lib/nokogiri/css/tokenizer.rex +7 -6
- data/lib/nokogiri/css/xpath_visitor.rb +263 -75
- data/lib/nokogiri/css.rb +50 -17
- data/lib/nokogiri/decorators/slop.rb +17 -8
- data/lib/nokogiri/extension.rb +31 -0
- data/lib/nokogiri/gumbo.rb +15 -0
- data/lib/nokogiri/html.rb +38 -27
- data/lib/nokogiri/{html → html4}/builder.rb +4 -2
- data/lib/nokogiri/html4/document.rb +331 -0
- data/lib/nokogiri/html4/document_fragment.rb +54 -0
- data/lib/nokogiri/{html → html4}/element_description.rb +3 -1
- data/lib/nokogiri/html4/element_description_defaults.rb +578 -0
- data/lib/nokogiri/{html → html4}/entity_lookup.rb +4 -2
- data/lib/nokogiri/{html → html4}/sax/parser.rb +24 -15
- data/lib/nokogiri/html4/sax/parser_context.rb +20 -0
- data/lib/nokogiri/html4/sax/push_parser.rb +37 -0
- data/lib/nokogiri/html4.rb +46 -0
- data/lib/nokogiri/html5/document.rb +88 -0
- data/lib/nokogiri/html5/document_fragment.rb +83 -0
- data/lib/nokogiri/html5/node.rb +96 -0
- data/lib/nokogiri/html5.rb +477 -0
- data/lib/nokogiri/jruby/dependencies.rb +21 -0
- data/lib/nokogiri/syntax_error.rb +2 -0
- data/lib/nokogiri/version/constant.rb +6 -0
- data/lib/nokogiri/version/info.rb +221 -0
- data/lib/nokogiri/version.rb +3 -90
- data/lib/nokogiri/xml/attr.rb +6 -3
- data/lib/nokogiri/xml/attribute_decl.rb +3 -1
- data/lib/nokogiri/xml/builder.rb +96 -54
- data/lib/nokogiri/xml/cdata.rb +3 -1
- data/lib/nokogiri/xml/character_data.rb +2 -0
- data/lib/nokogiri/xml/document.rb +234 -95
- data/lib/nokogiri/xml/document_fragment.rb +86 -36
- data/lib/nokogiri/xml/dtd.rb +16 -4
- data/lib/nokogiri/xml/element_content.rb +2 -0
- data/lib/nokogiri/xml/element_decl.rb +3 -1
- data/lib/nokogiri/xml/entity_decl.rb +4 -2
- data/lib/nokogiri/xml/entity_reference.rb +20 -0
- data/lib/nokogiri/xml/namespace.rb +3 -0
- data/lib/nokogiri/xml/node/save_options.rb +8 -4
- data/lib/nokogiri/xml/node.rb +947 -502
- data/lib/nokogiri/xml/node_set.rb +168 -159
- data/lib/nokogiri/xml/notation.rb +13 -0
- data/lib/nokogiri/xml/parse_options.rb +40 -5
- data/lib/nokogiri/xml/pp/character_data.rb +9 -6
- data/lib/nokogiri/xml/pp/node.rb +25 -26
- data/lib/nokogiri/xml/pp.rb +4 -2
- data/lib/nokogiri/xml/processing_instruction.rb +3 -1
- data/lib/nokogiri/xml/reader.rb +23 -28
- data/lib/nokogiri/xml/relax_ng.rb +8 -2
- data/lib/nokogiri/xml/sax/document.rb +45 -49
- data/lib/nokogiri/xml/sax/parser.rb +43 -41
- data/lib/nokogiri/xml/sax/parser_context.rb +8 -3
- data/lib/nokogiri/xml/sax/push_parser.rb +6 -5
- data/lib/nokogiri/xml/sax.rb +6 -4
- data/lib/nokogiri/xml/schema.rb +19 -9
- data/lib/nokogiri/xml/searchable.rb +259 -0
- data/lib/nokogiri/xml/syntax_error.rb +25 -1
- data/lib/nokogiri/xml/text.rb +2 -0
- data/lib/nokogiri/xml/xpath/syntax_error.rb +4 -2
- data/lib/nokogiri/xml/xpath.rb +15 -4
- data/lib/nokogiri/xml/xpath_context.rb +3 -3
- data/lib/nokogiri/xml.rb +38 -36
- data/lib/nokogiri/xslt/stylesheet.rb +3 -1
- data/lib/nokogiri/xslt.rb +18 -16
- data/lib/nokogiri.rb +69 -69
- data/lib/xsd/xmlparser/nokogiri.rb +26 -24
- data/patches/libxml2/0001-Remove-script-macro-support.patch +40 -0
- data/patches/libxml2/0002-Update-entities-to-remove-handling-of-ssi.patch +44 -0
- data/patches/libxml2/0003-libxml2.la-is-in-top_builddir.patch +25 -0
- data/patches/libxml2/0004-use-glibc-strlen.patch +53 -0
- data/patches/libxml2/0005-avoid-isnan-isinf.patch +81 -0
- data/patches/libxml2/0006-update-automake-files-for-arm64.patch +2511 -0
- data/patches/libxml2/0007-Fix-XPath-recursion-limit.patch +31 -0
- data/patches/libxml2/0008-htmlParseComment-handle-abruptly-closed-comments.patch +61 -0
- data/patches/libxml2/0009-allow-wildcard-namespaces.patch +77 -0
- data/patches/libxslt/0001-update-automake-files-for-arm64.patch +2511 -0
- data/patches/libxslt/0002-Fix-xml2-config-check-in-configure-script.patch +19 -0
- data/ports/archives/libxml2-2.9.12.tar.gz +0 -0
- data/ports/archives/libxslt-1.1.34.tar.gz +0 -0
- metadata +382 -460
- data/.autotest +0 -26
- data/.gemtest +0 -0
- data/CHANGELOG.ja.rdoc +0 -785
- data/CHANGELOG.rdoc +0 -783
- data/C_CODING_STYLE.rdoc +0 -33
- data/Manifest.txt +0 -303
- data/README.ja.rdoc +0 -106
- data/README.rdoc +0 -175
- data/ROADMAP.md +0 -90
- data/Rakefile +0 -228
- data/STANDARD_RESPONSES.md +0 -47
- data/Y_U_NO_GEMSPEC.md +0 -155
- data/build_all +0 -105
- data/ext/nokogiri/html_document.c +0 -170
- data/ext/nokogiri/html_document.h +0 -10
- data/ext/nokogiri/html_element_description.c +0 -279
- data/ext/nokogiri/html_element_description.h +0 -10
- data/ext/nokogiri/html_entity_lookup.c +0 -32
- data/ext/nokogiri/html_entity_lookup.h +0 -8
- data/ext/nokogiri/html_sax_parser_context.c +0 -116
- data/ext/nokogiri/html_sax_parser_context.h +0 -11
- data/ext/nokogiri/html_sax_push_parser.c +0 -87
- data/ext/nokogiri/html_sax_push_parser.h +0 -9
- data/ext/nokogiri/xml_attr.h +0 -9
- data/ext/nokogiri/xml_attribute_decl.h +0 -9
- data/ext/nokogiri/xml_cdata.h +0 -9
- data/ext/nokogiri/xml_comment.h +0 -9
- data/ext/nokogiri/xml_document.h +0 -23
- data/ext/nokogiri/xml_document_fragment.h +0 -10
- data/ext/nokogiri/xml_dtd.h +0 -10
- data/ext/nokogiri/xml_element_content.h +0 -10
- data/ext/nokogiri/xml_element_decl.h +0 -9
- data/ext/nokogiri/xml_encoding_handler.h +0 -8
- data/ext/nokogiri/xml_entity_decl.h +0 -10
- data/ext/nokogiri/xml_entity_reference.h +0 -9
- data/ext/nokogiri/xml_io.c +0 -56
- data/ext/nokogiri/xml_io.h +0 -11
- data/ext/nokogiri/xml_libxml2_hacks.c +0 -112
- data/ext/nokogiri/xml_libxml2_hacks.h +0 -12
- data/ext/nokogiri/xml_namespace.h +0 -13
- data/ext/nokogiri/xml_node.h +0 -13
- data/ext/nokogiri/xml_node_set.h +0 -14
- data/ext/nokogiri/xml_processing_instruction.h +0 -9
- data/ext/nokogiri/xml_reader.h +0 -10
- data/ext/nokogiri/xml_relax_ng.h +0 -9
- data/ext/nokogiri/xml_sax_parser.h +0 -39
- data/ext/nokogiri/xml_sax_parser_context.h +0 -10
- data/ext/nokogiri/xml_sax_push_parser.h +0 -9
- data/ext/nokogiri/xml_schema.h +0 -9
- data/ext/nokogiri/xml_syntax_error.h +0 -13
- data/ext/nokogiri/xml_text.h +0 -9
- data/ext/nokogiri/xml_xpath_context.h +0 -10
- data/ext/nokogiri/xslt_stylesheet.h +0 -14
- data/lib/nokogiri/html/document.rb +0 -254
- data/lib/nokogiri/html/document_fragment.rb +0 -41
- data/lib/nokogiri/html/element_description_defaults.rb +0 -671
- data/lib/nokogiri/html/sax/parser_context.rb +0 -16
- data/lib/nokogiri/html/sax/push_parser.rb +0 -16
- data/tasks/cross_compile.rb +0 -150
- data/tasks/nokogiri.org.rb +0 -24
- data/tasks/test.rb +0 -95
- data/test/css/test_nthiness.rb +0 -159
- data/test/css/test_parser.rb +0 -341
- data/test/css/test_tokenizer.rb +0 -198
- data/test/css/test_xpath_visitor.rb +0 -91
- data/test/decorators/test_slop.rb +0 -16
- data/test/files/2ch.html +0 -108
- data/test/files/address_book.rlx +0 -12
- data/test/files/address_book.xml +0 -10
- data/test/files/bar/bar.xsd +0 -4
- data/test/files/dont_hurt_em_why.xml +0 -422
- data/test/files/encoding.html +0 -82
- data/test/files/encoding.xhtml +0 -84
- data/test/files/exslt.xml +0 -8
- data/test/files/exslt.xslt +0 -35
- data/test/files/foo/foo.xsd +0 -4
- data/test/files/metacharset.html +0 -10
- data/test/files/noencoding.html +0 -47
- data/test/files/po.xml +0 -32
- data/test/files/po.xsd +0 -66
- data/test/files/shift_jis.html +0 -10
- data/test/files/shift_jis.xml +0 -5
- data/test/files/snuggles.xml +0 -3
- data/test/files/staff.dtd +0 -10
- data/test/files/staff.xml +0 -59
- data/test/files/staff.xslt +0 -32
- data/test/files/test_document_url/bar.xml +0 -2
- data/test/files/test_document_url/document.dtd +0 -4
- data/test/files/test_document_url/document.xml +0 -6
- data/test/files/tlm.html +0 -850
- data/test/files/to_be_xincluded.xml +0 -2
- data/test/files/valid_bar.xml +0 -2
- data/test/files/xinclude.xml +0 -4
- data/test/helper.rb +0 -154
- data/test/html/sax/test_parser.rb +0 -141
- data/test/html/sax/test_parser_context.rb +0 -46
- data/test/html/test_builder.rb +0 -164
- data/test/html/test_document.rb +0 -552
- data/test/html/test_document_encoding.rb +0 -138
- data/test/html/test_document_fragment.rb +0 -261
- data/test/html/test_element_description.rb +0 -105
- data/test/html/test_named_characters.rb +0 -14
- data/test/html/test_node.rb +0 -196
- data/test/html/test_node_encoding.rb +0 -27
- data/test/namespaces/test_additional_namespaces_in_builder_doc.rb +0 -14
- data/test/namespaces/test_namespaces_in_builder_doc.rb +0 -75
- data/test/namespaces/test_namespaces_in_created_doc.rb +0 -75
- data/test/namespaces/test_namespaces_in_parsed_doc.rb +0 -66
- data/test/test_convert_xpath.rb +0 -135
- data/test/test_css_cache.rb +0 -45
- data/test/test_encoding_handler.rb +0 -46
- data/test/test_memory_leak.rb +0 -156
- data/test/test_nokogiri.rb +0 -132
- data/test/test_reader.rb +0 -555
- data/test/test_soap4r_sax.rb +0 -52
- data/test/test_xslt_transforms.rb +0 -254
- data/test/xml/node/test_save_options.rb +0 -28
- data/test/xml/node/test_subclass.rb +0 -44
- data/test/xml/sax/test_parser.rb +0 -366
- data/test/xml/sax/test_parser_context.rb +0 -106
- data/test/xml/sax/test_push_parser.rb +0 -157
- data/test/xml/test_attr.rb +0 -64
- data/test/xml/test_attribute_decl.rb +0 -86
- data/test/xml/test_builder.rb +0 -306
- data/test/xml/test_c14n.rb +0 -151
- data/test/xml/test_cdata.rb +0 -48
- data/test/xml/test_comment.rb +0 -29
- data/test/xml/test_document.rb +0 -828
- data/test/xml/test_document_encoding.rb +0 -28
- data/test/xml/test_document_fragment.rb +0 -223
- data/test/xml/test_dtd.rb +0 -103
- data/test/xml/test_dtd_encoding.rb +0 -33
- data/test/xml/test_element_content.rb +0 -56
- data/test/xml/test_element_decl.rb +0 -73
- data/test/xml/test_entity_decl.rb +0 -122
- data/test/xml/test_entity_reference.rb +0 -245
- data/test/xml/test_namespace.rb +0 -95
- data/test/xml/test_node.rb +0 -1137
- data/test/xml/test_node_attributes.rb +0 -96
- data/test/xml/test_node_encoding.rb +0 -107
- data/test/xml/test_node_inheritance.rb +0 -32
- data/test/xml/test_node_reparenting.rb +0 -374
- data/test/xml/test_node_set.rb +0 -755
- data/test/xml/test_parse_options.rb +0 -64
- data/test/xml/test_processing_instruction.rb +0 -30
- data/test/xml/test_reader_encoding.rb +0 -142
- data/test/xml/test_relax_ng.rb +0 -60
- data/test/xml/test_schema.rb +0 -103
- data/test/xml/test_syntax_error.rb +0 -12
- data/test/xml/test_text.rb +0 -45
- data/test/xml/test_unparented_node.rb +0 -422
- data/test/xml/test_xinclude.rb +0 -83
- data/test/xml/test_xpath.rb +0 -295
- data/test/xslt/test_custom_functions.rb +0 -133
- data/test/xslt/test_exception_handling.rb +0 -37
- data/test_all +0 -81
data/test/files/valid_bar.xml
DELETED
data/test/files/xinclude.xml
DELETED
data/test/helper.rb
DELETED
@@ -1,154 +0,0 @@
|
|
1
|
-
#Process.setrlimit(Process::RLIMIT_CORE, Process::RLIM_INFINITY) unless RUBY_PLATFORM =~ /(java|mswin|mingw)/i
|
2
|
-
$VERBOSE = true
|
3
|
-
require 'minitest/autorun'
|
4
|
-
require 'minitest/pride'
|
5
|
-
require 'fileutils'
|
6
|
-
require 'tempfile'
|
7
|
-
require 'pp'
|
8
|
-
|
9
|
-
require 'nokogiri'
|
10
|
-
|
11
|
-
warn "#{__FILE__}:#{__LINE__}: version info: #{Nokogiri::VERSION_INFO.inspect}"
|
12
|
-
|
13
|
-
module Nokogiri
|
14
|
-
class TestCase < MiniTest::Spec
|
15
|
-
ASSETS_DIR = File.expand_path File.join(File.dirname(__FILE__), 'files')
|
16
|
-
ADDRESS_SCHEMA_FILE = File.join(ASSETS_DIR, 'address_book.rlx')
|
17
|
-
ADDRESS_XML_FILE = File.join(ASSETS_DIR, 'address_book.xml')
|
18
|
-
ENCODING_HTML_FILE = File.join(ASSETS_DIR, 'encoding.html')
|
19
|
-
ENCODING_XHTML_FILE = File.join(ASSETS_DIR, 'encoding.xhtml')
|
20
|
-
EXML_FILE = File.join(ASSETS_DIR, 'exslt.xml')
|
21
|
-
EXSLT_FILE = File.join(ASSETS_DIR, 'exslt.xslt')
|
22
|
-
HTML_FILE = File.join(ASSETS_DIR, 'tlm.html')
|
23
|
-
METACHARSET_FILE = File.join(ASSETS_DIR, 'metacharset.html')
|
24
|
-
NICH_FILE = File.join(ASSETS_DIR, '2ch.html')
|
25
|
-
NOENCODING_FILE = File.join(ASSETS_DIR, 'noencoding.html')
|
26
|
-
PO_SCHEMA_FILE = File.join(ASSETS_DIR, 'po.xsd')
|
27
|
-
PO_XML_FILE = File.join(ASSETS_DIR, 'po.xml')
|
28
|
-
SHIFT_JIS_HTML = File.join(ASSETS_DIR, 'shift_jis.html')
|
29
|
-
SHIFT_JIS_XML = File.join(ASSETS_DIR, 'shift_jis.xml')
|
30
|
-
SNUGGLES_FILE = File.join(ASSETS_DIR, 'snuggles.xml')
|
31
|
-
XML_FILE = File.join(ASSETS_DIR, 'staff.xml')
|
32
|
-
XML_XINCLUDE_FILE = File.join(ASSETS_DIR, 'xinclude.xml')
|
33
|
-
XSLT_FILE = File.join(ASSETS_DIR, 'staff.xslt')
|
34
|
-
|
35
|
-
def teardown
|
36
|
-
if ENV['NOKOGIRI_GC']
|
37
|
-
STDOUT.putc '!'
|
38
|
-
if RUBY_PLATFORM =~ /java/
|
39
|
-
require 'java'
|
40
|
-
java.lang.System.gc
|
41
|
-
else
|
42
|
-
GC.start
|
43
|
-
end
|
44
|
-
end
|
45
|
-
end
|
46
|
-
|
47
|
-
def assert_indent amount, doc, message = nil
|
48
|
-
nodes = []
|
49
|
-
doc.traverse do |node|
|
50
|
-
nodes << node if node.text? && node.blank?
|
51
|
-
end
|
52
|
-
assert nodes.length > 0
|
53
|
-
nodes.each do |node|
|
54
|
-
len = node.content.gsub(/[\r\n]/, '').length
|
55
|
-
assert_equal(0, len % amount, message)
|
56
|
-
end
|
57
|
-
end
|
58
|
-
|
59
|
-
def util_decorate(document, decorator_module)
|
60
|
-
document.decorators(XML::Node) << decorator_module
|
61
|
-
document.decorators(XML::NodeSet) << decorator_module
|
62
|
-
document.decorate!
|
63
|
-
end
|
64
|
-
|
65
|
-
#
|
66
|
-
# Test::Unit backwards compatibility section
|
67
|
-
#
|
68
|
-
alias :assert_no_match :refute_match
|
69
|
-
alias :assert_not_nil :refute_nil
|
70
|
-
alias :assert_raise :assert_raises
|
71
|
-
alias :assert_not_equal :refute_equal
|
72
|
-
end
|
73
|
-
|
74
|
-
module SAX
|
75
|
-
class TestCase < Nokogiri::TestCase
|
76
|
-
class Doc < XML::SAX::Document
|
77
|
-
attr_reader :start_elements, :start_document_called
|
78
|
-
attr_reader :end_elements, :end_document_called
|
79
|
-
attr_reader :data, :comments, :cdata_blocks, :start_elements_namespace
|
80
|
-
attr_reader :errors, :warnings, :end_elements_namespace
|
81
|
-
attr_reader :xmldecls
|
82
|
-
attr_reader :processing_instructions
|
83
|
-
|
84
|
-
def xmldecl version, encoding, standalone
|
85
|
-
@xmldecls = [version, encoding, standalone].compact
|
86
|
-
super
|
87
|
-
end
|
88
|
-
|
89
|
-
def start_document
|
90
|
-
@start_document_called = true
|
91
|
-
super
|
92
|
-
end
|
93
|
-
|
94
|
-
def end_document
|
95
|
-
@end_document_called = true
|
96
|
-
super
|
97
|
-
end
|
98
|
-
|
99
|
-
def error error
|
100
|
-
(@errors ||= []) << error
|
101
|
-
super
|
102
|
-
end
|
103
|
-
|
104
|
-
def warning warning
|
105
|
-
(@warning ||= []) << warning
|
106
|
-
super
|
107
|
-
end
|
108
|
-
|
109
|
-
def start_element *args
|
110
|
-
(@start_elements ||= []) << args
|
111
|
-
super
|
112
|
-
end
|
113
|
-
|
114
|
-
def start_element_namespace *args
|
115
|
-
(@start_elements_namespace ||= []) << args
|
116
|
-
super
|
117
|
-
end
|
118
|
-
|
119
|
-
def end_element *args
|
120
|
-
(@end_elements ||= []) << args
|
121
|
-
super
|
122
|
-
end
|
123
|
-
|
124
|
-
def end_element_namespace *args
|
125
|
-
(@end_elements_namespace ||= []) << args
|
126
|
-
super
|
127
|
-
end
|
128
|
-
|
129
|
-
def characters string
|
130
|
-
@data ||= []
|
131
|
-
@data += [string]
|
132
|
-
super
|
133
|
-
end
|
134
|
-
|
135
|
-
def comment string
|
136
|
-
@comments ||= []
|
137
|
-
@comments += [string]
|
138
|
-
super
|
139
|
-
end
|
140
|
-
|
141
|
-
def cdata_block string
|
142
|
-
@cdata_blocks ||= []
|
143
|
-
@cdata_blocks += [string]
|
144
|
-
super
|
145
|
-
end
|
146
|
-
|
147
|
-
def processing_instruction name, content
|
148
|
-
@processing_instructions ||= []
|
149
|
-
@processing_instructions << [name, content]
|
150
|
-
end
|
151
|
-
end
|
152
|
-
end
|
153
|
-
end
|
154
|
-
end
|
@@ -1,141 +0,0 @@
|
|
1
|
-
# -*- coding: utf-8 -*-
|
2
|
-
require "helper"
|
3
|
-
|
4
|
-
module Nokogiri
|
5
|
-
module HTML
|
6
|
-
module SAX
|
7
|
-
class TestParser < Nokogiri::SAX::TestCase
|
8
|
-
def setup
|
9
|
-
super
|
10
|
-
@parser = HTML::SAX::Parser.new(Doc.new)
|
11
|
-
end
|
12
|
-
|
13
|
-
def test_parse_empty_document
|
14
|
-
# This caused a segfault in libxml 2.6.x
|
15
|
-
assert_nil @parser.parse ''
|
16
|
-
end
|
17
|
-
|
18
|
-
def test_parse_empty_file
|
19
|
-
# Make sure empty files don't break stuff
|
20
|
-
empty_file_name = File.join(ASSETS_DIR, 'bogus.xml')
|
21
|
-
# assert_nothing_raised do
|
22
|
-
@parser.parse_file empty_file_name
|
23
|
-
# end
|
24
|
-
end
|
25
|
-
|
26
|
-
def test_parse_file
|
27
|
-
@parser.parse_file(HTML_FILE)
|
28
|
-
|
29
|
-
# Take a look at the comment in test_parse_document to know
|
30
|
-
# a possible reason to this difference.
|
31
|
-
if Nokogiri.uses_libxml?
|
32
|
-
assert_equal 1110, @parser.document.end_elements.length
|
33
|
-
else
|
34
|
-
assert_equal 1119, @parser.document.end_elements.length
|
35
|
-
end
|
36
|
-
end
|
37
|
-
|
38
|
-
def test_parse_file_nil_argument
|
39
|
-
assert_raises(ArgumentError) {
|
40
|
-
@parser.parse_file(nil)
|
41
|
-
}
|
42
|
-
end
|
43
|
-
|
44
|
-
def test_parse_file_non_existant
|
45
|
-
assert_raise Errno::ENOENT do
|
46
|
-
@parser.parse_file('there_is_no_reasonable_way_this_file_exists')
|
47
|
-
end
|
48
|
-
end
|
49
|
-
|
50
|
-
def test_parse_file_with_dir
|
51
|
-
assert_raise Errno::EISDIR do
|
52
|
-
@parser.parse_file(File.dirname(__FILE__))
|
53
|
-
end
|
54
|
-
end
|
55
|
-
|
56
|
-
def test_parse_memory_nil
|
57
|
-
assert_raise ArgumentError do
|
58
|
-
@parser.parse_memory(nil)
|
59
|
-
end
|
60
|
-
end
|
61
|
-
|
62
|
-
def test_parse_force_encoding
|
63
|
-
@parser.parse_memory(<<-HTML, 'UTF-8')
|
64
|
-
<meta http-equiv="Content-Type" content="text/html; charset=windows-1251">
|
65
|
-
Информация
|
66
|
-
HTML
|
67
|
-
assert_equal("Информация",
|
68
|
-
@parser.document.data.join.strip)
|
69
|
-
end
|
70
|
-
|
71
|
-
def test_parse_document
|
72
|
-
@parser.parse_memory(<<-eoxml)
|
73
|
-
<p>Paragraph 1</p>
|
74
|
-
<p>Paragraph 2</p>
|
75
|
-
eoxml
|
76
|
-
|
77
|
-
# JRuby version is different because of the internal implementation
|
78
|
-
# JRuby version uses NekoHTML which inserts empty "head" elements.
|
79
|
-
#
|
80
|
-
# Currently following features are set:
|
81
|
-
# "http://cyberneko.org/html/properties/names/elems" => "lower"
|
82
|
-
# "http://cyberneko.org/html/properties/names/attrs" => "lower"
|
83
|
-
if Nokogiri.uses_libxml?
|
84
|
-
assert_equal([["html", []], ["body", []], ["p", []], ["p", []]],
|
85
|
-
@parser.document.start_elements)
|
86
|
-
else
|
87
|
-
assert_equal([["html", []], ["head", []], ["body", []], ["p", []], ["p", []]],
|
88
|
-
@parser.document.start_elements)
|
89
|
-
end
|
90
|
-
end
|
91
|
-
|
92
|
-
def test_parser_attributes
|
93
|
-
html = <<-eohtml
|
94
|
-
<html>
|
95
|
-
<head>
|
96
|
-
<title>hello</title>
|
97
|
-
</head>
|
98
|
-
<body>
|
99
|
-
<img src="face.jpg" title="daddy & me">
|
100
|
-
<hr noshade size="2">
|
101
|
-
</body>
|
102
|
-
</html>
|
103
|
-
eohtml
|
104
|
-
|
105
|
-
block_called = false
|
106
|
-
@parser.parse(html) { |ctx|
|
107
|
-
block_called = true
|
108
|
-
ctx.replace_entities = true
|
109
|
-
}
|
110
|
-
|
111
|
-
assert block_called
|
112
|
-
|
113
|
-
noshade_value = if Nokogiri.uses_libxml? && Nokogiri::VERSION_INFO['libxml']['loaded'] < '2.7.7'
|
114
|
-
['noshade', 'noshade']
|
115
|
-
else
|
116
|
-
['noshade', nil]
|
117
|
-
end
|
118
|
-
|
119
|
-
assert_equal [
|
120
|
-
['html', []],
|
121
|
-
['head', []],
|
122
|
-
['title', []],
|
123
|
-
['body', []],
|
124
|
-
['img', [
|
125
|
-
['src', 'face.jpg'],
|
126
|
-
['title', 'daddy & me']
|
127
|
-
]],
|
128
|
-
['hr', [
|
129
|
-
noshade_value,
|
130
|
-
['size', '2']
|
131
|
-
]]
|
132
|
-
], @parser.document.start_elements
|
133
|
-
end
|
134
|
-
|
135
|
-
def test_empty_processing_instruction
|
136
|
-
@parser.parse_memory("<strong>this will segfault<?strong>")
|
137
|
-
end
|
138
|
-
end
|
139
|
-
end
|
140
|
-
end
|
141
|
-
end
|
@@ -1,46 +0,0 @@
|
|
1
|
-
# -*- coding: utf-8 -*-
|
2
|
-
|
3
|
-
require "helper"
|
4
|
-
|
5
|
-
module Nokogiri
|
6
|
-
module HTML
|
7
|
-
module SAX
|
8
|
-
class TestParserContext < Nokogiri::SAX::TestCase
|
9
|
-
def test_from_io
|
10
|
-
ctx = ParserContext.new StringIO.new('fo'), 'UTF-8'
|
11
|
-
assert ctx
|
12
|
-
end
|
13
|
-
|
14
|
-
def test_from_string
|
15
|
-
ctx = ParserContext.new 'blah blah'
|
16
|
-
assert ctx
|
17
|
-
end
|
18
|
-
|
19
|
-
def test_parse_with
|
20
|
-
ctx = ParserContext.new 'blah'
|
21
|
-
assert_raises ArgumentError do
|
22
|
-
ctx.parse_with nil
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
def test_parse_with_sax_parser
|
27
|
-
# assert_nothing_raised do
|
28
|
-
xml = "<root />"
|
29
|
-
ctx = ParserContext.new xml
|
30
|
-
parser = Parser.new Doc.new
|
31
|
-
ctx.parse_with parser
|
32
|
-
# end
|
33
|
-
end
|
34
|
-
|
35
|
-
def test_from_file
|
36
|
-
# assert_nothing_raised do
|
37
|
-
ctx = ParserContext.file HTML_FILE, 'UTF-8'
|
38
|
-
parser = Parser.new Doc.new
|
39
|
-
ctx.parse_with parser
|
40
|
-
# end
|
41
|
-
end
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
|
-
end
|
46
|
-
|
data/test/html/test_builder.rb
DELETED
@@ -1,164 +0,0 @@
|
|
1
|
-
require "helper"
|
2
|
-
|
3
|
-
module Nokogiri
|
4
|
-
module HTML
|
5
|
-
class TestBuilder < Nokogiri::TestCase
|
6
|
-
def test_top_level_function_builds
|
7
|
-
foo = nil
|
8
|
-
Nokogiri() { |xml| foo = xml }
|
9
|
-
assert_instance_of Nokogiri::HTML::Builder, foo
|
10
|
-
end
|
11
|
-
|
12
|
-
def test_builder_with_explicit_tags
|
13
|
-
html_doc = Nokogiri::HTML::Builder.new {
|
14
|
-
div.slide(:class => 'another_class') {
|
15
|
-
node = Nokogiri::XML::Node.new("id", doc)
|
16
|
-
node.content = "hello"
|
17
|
-
insert(node)
|
18
|
-
}
|
19
|
-
}.doc
|
20
|
-
assert_equal 1, html_doc.css('div.slide > id').length
|
21
|
-
assert_equal 'hello', html_doc.at('div.slide > id').content
|
22
|
-
end
|
23
|
-
|
24
|
-
def test_hash_as_attributes_for_attribute_method
|
25
|
-
html = Nokogiri::HTML::Builder.new { ||
|
26
|
-
div.slide(:class => 'another_class') {
|
27
|
-
span 'Slide 1'
|
28
|
-
}
|
29
|
-
}.to_html
|
30
|
-
assert_match 'class="slide another_class"', html
|
31
|
-
end
|
32
|
-
|
33
|
-
def test_hash_as_attributes
|
34
|
-
builder = Nokogiri::HTML::Builder.new do
|
35
|
-
div(:id => 'awesome') {
|
36
|
-
h1 "america"
|
37
|
-
}
|
38
|
-
end
|
39
|
-
assert_equal('<div id="awesome"><h1>america</h1></div>',
|
40
|
-
builder.doc.root.to_html.gsub(/\n/, '').gsub(/>\s*</, '><'))
|
41
|
-
end
|
42
|
-
|
43
|
-
def test_href_with_attributes
|
44
|
-
uri = 'http://tenderlovemaking.com/'
|
45
|
-
built = Nokogiri::XML::Builder.new {
|
46
|
-
div {
|
47
|
-
a('King Khan & The Shrines', :href => uri)
|
48
|
-
}
|
49
|
-
}
|
50
|
-
assert_equal 'http://tenderlovemaking.com/',
|
51
|
-
built.doc.at('a')[:href]
|
52
|
-
end
|
53
|
-
|
54
|
-
def test_tag_nesting
|
55
|
-
builder = Nokogiri::HTML::Builder.new do
|
56
|
-
body {
|
57
|
-
span.left ''
|
58
|
-
span.middle {
|
59
|
-
div.icon ''
|
60
|
-
}
|
61
|
-
span.right ''
|
62
|
-
}
|
63
|
-
end
|
64
|
-
assert node = builder.doc.css('span.right').first
|
65
|
-
assert_equal 'middle', node.previous_sibling['class']
|
66
|
-
end
|
67
|
-
|
68
|
-
def test_has_ampersand
|
69
|
-
builder = Nokogiri::HTML::Builder.new do
|
70
|
-
div.rad.thing! {
|
71
|
-
text "<awe&some>"
|
72
|
-
b "hello & world"
|
73
|
-
}
|
74
|
-
end
|
75
|
-
assert_equal(
|
76
|
-
'<div class="rad" id="thing"><awe&some><b>hello & world</b></div>',
|
77
|
-
builder.doc.root.to_html.gsub(/\n/, ''))
|
78
|
-
end
|
79
|
-
|
80
|
-
def test_multi_tags
|
81
|
-
builder = Nokogiri::HTML::Builder.new do
|
82
|
-
div.rad.thing! {
|
83
|
-
text "<awesome>"
|
84
|
-
b "hello"
|
85
|
-
}
|
86
|
-
end
|
87
|
-
assert_equal(
|
88
|
-
'<div class="rad" id="thing"><awesome><b>hello</b></div>',
|
89
|
-
builder.doc.root.to_html.gsub(/\n/, ''))
|
90
|
-
end
|
91
|
-
|
92
|
-
def test_attributes_plus_block
|
93
|
-
builder = Nokogiri::HTML::Builder.new do
|
94
|
-
div.rad.thing! {
|
95
|
-
text "<awesome>"
|
96
|
-
}
|
97
|
-
end
|
98
|
-
assert_equal('<div class="rad" id="thing"><awesome></div>',
|
99
|
-
builder.doc.root.to_html.chomp)
|
100
|
-
end
|
101
|
-
|
102
|
-
def test_builder_adds_attributes
|
103
|
-
builder = Nokogiri::HTML::Builder.new do
|
104
|
-
div.rad.thing! "tender div"
|
105
|
-
end
|
106
|
-
assert_equal('<div class="rad" id="thing">tender div</div>',
|
107
|
-
builder.doc.root.to_html.chomp)
|
108
|
-
end
|
109
|
-
|
110
|
-
def test_bold_tag
|
111
|
-
builder = Nokogiri::HTML::Builder.new do
|
112
|
-
b "bold tag"
|
113
|
-
end
|
114
|
-
assert_equal('<b>bold tag</b>', builder.doc.root.to_html.chomp)
|
115
|
-
end
|
116
|
-
|
117
|
-
def test_html_then_body_tag
|
118
|
-
builder = Nokogiri::HTML::Builder.new do
|
119
|
-
html {
|
120
|
-
body {
|
121
|
-
b "bold tag"
|
122
|
-
}
|
123
|
-
}
|
124
|
-
end
|
125
|
-
assert_equal('<html><body><b>bold tag</b></body></html>',
|
126
|
-
builder.doc.root.to_html.chomp.gsub(/>\s*</, '><'))
|
127
|
-
end
|
128
|
-
|
129
|
-
def test_instance_eval_with_delegation_to_block_context
|
130
|
-
class << self
|
131
|
-
def foo
|
132
|
-
"foo!"
|
133
|
-
end
|
134
|
-
end
|
135
|
-
|
136
|
-
builder = Nokogiri::HTML::Builder.new { text foo }
|
137
|
-
assert builder.to_html.include?("foo!")
|
138
|
-
end
|
139
|
-
|
140
|
-
def test_builder_with_param
|
141
|
-
doc = Nokogiri::HTML::Builder.new { |html|
|
142
|
-
html.body {
|
143
|
-
html.p "hello world"
|
144
|
-
}
|
145
|
-
}.doc
|
146
|
-
|
147
|
-
assert node = doc.xpath('//body/p').first
|
148
|
-
assert_equal 'hello world', node.content
|
149
|
-
end
|
150
|
-
|
151
|
-
def test_builder_with_id
|
152
|
-
text = "hello world"
|
153
|
-
doc = Nokogiri::HTML::Builder.new { |html|
|
154
|
-
html.body {
|
155
|
-
html.id_ text
|
156
|
-
}
|
157
|
-
}.doc
|
158
|
-
|
159
|
-
assert node = doc.xpath('//body/id').first
|
160
|
-
assert_equal text, node.content
|
161
|
-
end
|
162
|
-
end
|
163
|
-
end
|
164
|
-
end
|