husc 0.2.1 → 0.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.gitignore +3 -0
- data/README.md +4 -0
- data/lib/husc/version.rb +1 -1
- data/lib/husc.rb +3 -1
- metadata +3 -1016
- data/Gemfile.lock +0 -64
- data/vendor/bundle/bin/htmldiff +0 -29
- data/vendor/bundle/bin/ldiff +0 -29
- data/vendor/bundle/bin/nokogiri +0 -27
- data/vendor/bundle/bin/rake +0 -27
- data/vendor/bundle/bin/rspec +0 -27
- data/vendor/bundle/cache/connection_pool-2.2.2.gem +0 -0
- data/vendor/bundle/cache/diff-lcs-1.3.gem +0 -0
- data/vendor/bundle/cache/domain_name-0.5.20190701.gem +0 -0
- data/vendor/bundle/cache/http-cookie-1.0.3.gem +0 -0
- data/vendor/bundle/cache/mechanize-2.7.6.gem +0 -0
- data/vendor/bundle/cache/mime-types-3.3.1.gem +0 -0
- data/vendor/bundle/cache/mime-types-data-3.2019.1009.gem +0 -0
- data/vendor/bundle/cache/mini_portile2-2.4.0.gem +0 -0
- data/vendor/bundle/cache/net-http-digest_auth-1.4.1.gem +0 -0
- data/vendor/bundle/cache/net-http-persistent-3.1.0.gem +0 -0
- data/vendor/bundle/cache/nokogiri-1.10.7.gem +0 -0
- data/vendor/bundle/cache/ntlm-http-0.1.1.gem +0 -0
- data/vendor/bundle/cache/rake-12.3.3.gem +0 -0
- data/vendor/bundle/cache/rspec-3.9.0.gem +0 -0
- data/vendor/bundle/cache/rspec-core-3.9.1.gem +0 -0
- data/vendor/bundle/cache/rspec-expectations-3.9.0.gem +0 -0
- data/vendor/bundle/cache/rspec-mocks-3.9.1.gem +0 -0
- data/vendor/bundle/cache/rspec-support-3.9.2.gem +0 -0
- data/vendor/bundle/cache/unf-0.1.4.gem +0 -0
- data/vendor/bundle/cache/unf_ext-0.0.7.6.gem +0 -0
- data/vendor/bundle/cache/webrobots-0.1.2.gem +0 -0
- data/vendor/bundle/extensions/x86_64-darwin-18/2.6.0-static/nokogiri-1.10.7/gem.build_complete +0 -0
- data/vendor/bundle/extensions/x86_64-darwin-18/2.6.0-static/nokogiri-1.10.7/gem_make.out +0 -153
- data/vendor/bundle/extensions/x86_64-darwin-18/2.6.0-static/nokogiri-1.10.7/mkmf.log +0 -562
- data/vendor/bundle/extensions/x86_64-darwin-18/2.6.0-static/nokogiri-1.10.7/nokogiri/nokogiri.bundle +0 -0
- data/vendor/bundle/extensions/x86_64-darwin-18/2.6.0-static/unf_ext-0.0.7.6/gem.build_complete +0 -0
- data/vendor/bundle/extensions/x86_64-darwin-18/2.6.0-static/unf_ext-0.0.7.6/gem_make.out +0 -38
- data/vendor/bundle/extensions/x86_64-darwin-18/2.6.0-static/unf_ext-0.0.7.6/mkmf.log +0 -35
- data/vendor/bundle/extensions/x86_64-darwin-18/2.6.0-static/unf_ext-0.0.7.6/unf_ext.bundle +0 -0
- data/vendor/bundle/gems/connection_pool-2.2.2/.gitignore +0 -4
- data/vendor/bundle/gems/connection_pool-2.2.2/.travis.yml +0 -10
- data/vendor/bundle/gems/connection_pool-2.2.2/Changes.md +0 -123
- data/vendor/bundle/gems/connection_pool-2.2.2/Gemfile +0 -3
- data/vendor/bundle/gems/connection_pool-2.2.2/LICENSE +0 -20
- data/vendor/bundle/gems/connection_pool-2.2.2/README.md +0 -107
- data/vendor/bundle/gems/connection_pool-2.2.2/Rakefile +0 -6
- data/vendor/bundle/gems/connection_pool-2.2.2/connection_pool.gemspec +0 -21
- data/vendor/bundle/gems/connection_pool-2.2.2/lib/connection_pool/monotonic_time.rb +0 -66
- data/vendor/bundle/gems/connection_pool-2.2.2/lib/connection_pool/timed_stack.rb +0 -176
- data/vendor/bundle/gems/connection_pool-2.2.2/lib/connection_pool/version.rb +0 -3
- data/vendor/bundle/gems/connection_pool-2.2.2/lib/connection_pool.rb +0 -161
- data/vendor/bundle/gems/connection_pool-2.2.2/test/helper.rb +0 -8
- data/vendor/bundle/gems/connection_pool-2.2.2/test/test_connection_pool.rb +0 -516
- data/vendor/bundle/gems/connection_pool-2.2.2/test/test_connection_pool_timed_stack.rb +0 -149
- data/vendor/bundle/gems/diff-lcs-1.3/.rspec +0 -1
- data/vendor/bundle/gems/diff-lcs-1.3/Code-of-Conduct.md +0 -74
- data/vendor/bundle/gems/diff-lcs-1.3/Contributing.md +0 -83
- data/vendor/bundle/gems/diff-lcs-1.3/History.md +0 -220
- data/vendor/bundle/gems/diff-lcs-1.3/License.md +0 -39
- data/vendor/bundle/gems/diff-lcs-1.3/Manifest.txt +0 -37
- data/vendor/bundle/gems/diff-lcs-1.3/README.rdoc +0 -84
- data/vendor/bundle/gems/diff-lcs-1.3/Rakefile +0 -57
- data/vendor/bundle/gems/diff-lcs-1.3/autotest/discover.rb +0 -1
- data/vendor/bundle/gems/diff-lcs-1.3/bin/htmldiff +0 -32
- data/vendor/bundle/gems/diff-lcs-1.3/bin/ldiff +0 -6
- data/vendor/bundle/gems/diff-lcs-1.3/docs/COPYING.txt +0 -339
- data/vendor/bundle/gems/diff-lcs-1.3/docs/artistic.txt +0 -127
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/array.rb +0 -7
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/block.rb +0 -37
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/callbacks.rb +0 -322
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/change.rb +0 -181
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/htmldiff.rb +0 -149
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/hunk.rb +0 -276
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/internals.rb +0 -307
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/ldiff.rb +0 -167
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs/string.rb +0 -5
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff/lcs.rb +0 -725
- data/vendor/bundle/gems/diff-lcs-1.3/lib/diff-lcs.rb +0 -3
- data/vendor/bundle/gems/diff-lcs-1.3/spec/change_spec.rb +0 -65
- data/vendor/bundle/gems/diff-lcs-1.3/spec/diff_spec.rb +0 -47
- data/vendor/bundle/gems/diff-lcs-1.3/spec/fixtures/ds1.csv +0 -50
- data/vendor/bundle/gems/diff-lcs-1.3/spec/fixtures/ds2.csv +0 -51
- data/vendor/bundle/gems/diff-lcs-1.3/spec/hunk_spec.rb +0 -72
- data/vendor/bundle/gems/diff-lcs-1.3/spec/issues_spec.rb +0 -49
- data/vendor/bundle/gems/diff-lcs-1.3/spec/lcs_spec.rb +0 -56
- data/vendor/bundle/gems/diff-lcs-1.3/spec/ldiff_spec.rb +0 -47
- data/vendor/bundle/gems/diff-lcs-1.3/spec/patch_spec.rb +0 -422
- data/vendor/bundle/gems/diff-lcs-1.3/spec/sdiff_spec.rb +0 -214
- data/vendor/bundle/gems/diff-lcs-1.3/spec/spec_helper.rb +0 -321
- data/vendor/bundle/gems/diff-lcs-1.3/spec/traverse_balanced_spec.rb +0 -310
- data/vendor/bundle/gems/diff-lcs-1.3/spec/traverse_sequences_spec.rb +0 -139
- data/vendor/bundle/gems/domain_name-0.5.20190701/.document +0 -5
- data/vendor/bundle/gems/domain_name-0.5.20190701/.gitignore +0 -17
- data/vendor/bundle/gems/domain_name-0.5.20190701/.travis.yml +0 -21
- data/vendor/bundle/gems/domain_name-0.5.20190701/CHANGELOG.md +0 -219
- data/vendor/bundle/gems/domain_name-0.5.20190701/Gemfile +0 -4
- data/vendor/bundle/gems/domain_name-0.5.20190701/LICENSE.txt +0 -78
- data/vendor/bundle/gems/domain_name-0.5.20190701/README.md +0 -67
- data/vendor/bundle/gems/domain_name-0.5.20190701/Rakefile +0 -111
- data/vendor/bundle/gems/domain_name-0.5.20190701/data/public_suffix_list.dat +0 -12985
- data/vendor/bundle/gems/domain_name-0.5.20190701/domain_name.gemspec +0 -36
- data/vendor/bundle/gems/domain_name-0.5.20190701/lib/domain_name/etld_data.rb +0 -8787
- data/vendor/bundle/gems/domain_name-0.5.20190701/lib/domain_name/etld_data.rb.erb +0 -11
- data/vendor/bundle/gems/domain_name-0.5.20190701/lib/domain_name/punycode.rb +0 -283
- data/vendor/bundle/gems/domain_name-0.5.20190701/lib/domain_name/version.rb +0 -3
- data/vendor/bundle/gems/domain_name-0.5.20190701/lib/domain_name.rb +0 -297
- data/vendor/bundle/gems/domain_name-0.5.20190701/test/helper.rb +0 -17
- data/vendor/bundle/gems/domain_name-0.5.20190701/test/test_domain_name-punycode.rb +0 -97
- data/vendor/bundle/gems/domain_name-0.5.20190701/test/test_domain_name.rb +0 -317
- data/vendor/bundle/gems/domain_name-0.5.20190701/tool/gen_etld_data.rb +0 -63
- data/vendor/bundle/gems/http-cookie-1.0.3/.gitignore +0 -17
- data/vendor/bundle/gems/http-cookie-1.0.3/.travis.yml +0 -21
- data/vendor/bundle/gems/http-cookie-1.0.3/CHANGELOG.md +0 -22
- data/vendor/bundle/gems/http-cookie-1.0.3/Gemfile +0 -4
- data/vendor/bundle/gems/http-cookie-1.0.3/LICENSE.txt +0 -24
- data/vendor/bundle/gems/http-cookie-1.0.3/README.md +0 -235
- data/vendor/bundle/gems/http-cookie-1.0.3/Rakefile +0 -20
- data/vendor/bundle/gems/http-cookie-1.0.3/http-cookie.gemspec +0 -34
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie/ruby_compat.rb +0 -63
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie/scanner.rb +0 -231
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie/version.rb +0 -5
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie.rb +0 -685
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie_jar/abstract_saver.rb +0 -65
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie_jar/abstract_store.rb +0 -124
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie_jar/cookiestxt_saver.rb +0 -106
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie_jar/hash_store.rb +0 -163
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie_jar/mozilla_store.rb +0 -458
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie_jar/yaml_saver.rb +0 -76
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http/cookie_jar.rb +0 -344
- data/vendor/bundle/gems/http-cookie-1.0.3/lib/http-cookie.rb +0 -1
- data/vendor/bundle/gems/http-cookie-1.0.3/test/helper.rb +0 -55
- data/vendor/bundle/gems/http-cookie-1.0.3/test/mechanize.yml +0 -101
- data/vendor/bundle/gems/http-cookie-1.0.3/test/simplecov_start.rb +0 -2
- data/vendor/bundle/gems/http-cookie-1.0.3/test/test_http_cookie.rb +0 -1122
- data/vendor/bundle/gems/http-cookie-1.0.3/test/test_http_cookie_jar.rb +0 -985
- data/vendor/bundle/gems/mechanize-2.7.6/.autotest +0 -6
- data/vendor/bundle/gems/mechanize-2.7.6/.gitignore +0 -15
- data/vendor/bundle/gems/mechanize-2.7.6/.travis.yml +0 -36
- data/vendor/bundle/gems/mechanize-2.7.6/CHANGELOG.rdoc +0 -999
- data/vendor/bundle/gems/mechanize-2.7.6/EXAMPLES.rdoc +0 -192
- data/vendor/bundle/gems/mechanize-2.7.6/GUIDE.rdoc +0 -168
- data/vendor/bundle/gems/mechanize-2.7.6/Gemfile +0 -6
- data/vendor/bundle/gems/mechanize-2.7.6/LICENSE.rdoc +0 -20
- data/vendor/bundle/gems/mechanize-2.7.6/README.rdoc +0 -77
- data/vendor/bundle/gems/mechanize-2.7.6/Rakefile +0 -41
- data/vendor/bundle/gems/mechanize-2.7.6/examples/flickr_upload.rb +0 -22
- data/vendor/bundle/gems/mechanize-2.7.6/examples/mech-dump.rb +0 -5
- data/vendor/bundle/gems/mechanize-2.7.6/examples/proxy_req.rb +0 -7
- data/vendor/bundle/gems/mechanize-2.7.6/examples/rubygems.rb +0 -23
- data/vendor/bundle/gems/mechanize-2.7.6/examples/spider.rb +0 -22
- data/vendor/bundle/gems/mechanize-2.7.6/examples/wikipedia_links_to_philosophy.rb +0 -159
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/chunked_termination_error.rb +0 -7
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/content_type_error.rb +0 -13
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/cookie.rb +0 -73
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/cookie_jar.rb +0 -190
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/directory_saver.rb +0 -77
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/download.rb +0 -84
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/element_matcher.rb +0 -68
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/element_not_found_error.rb +0 -19
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/file.rb +0 -93
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/file_connection.rb +0 -17
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/file_request.rb +0 -30
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/file_response.rb +0 -80
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/file_saver.rb +0 -39
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/button.rb +0 -6
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/check_box.rb +0 -19
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/field.rb +0 -124
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/file_upload.rb +0 -21
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/hidden.rb +0 -3
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/image_button.rb +0 -19
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/keygen.rb +0 -34
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/multi_select_list.rb +0 -93
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/option.rb +0 -51
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/radio_button.rb +0 -69
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/reset.rb +0 -3
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/select_list.rb +0 -44
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/submit.rb +0 -3
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/text.rb +0 -3
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form/textarea.rb +0 -3
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/form.rb +0 -724
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/headers.rb +0 -23
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/history.rb +0 -82
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/http/agent.rb +0 -1281
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/http/auth_challenge.rb +0 -65
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/http/auth_realm.rb +0 -31
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/http/auth_store.rb +0 -123
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/http/content_disposition_parser.rb +0 -191
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/http/www_authenticate_parser.rb +0 -178
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/http.rb +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/image.rb +0 -6
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/page/base.rb +0 -7
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/page/frame.rb +0 -29
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/page/image.rb +0 -182
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/page/label.rb +0 -20
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/page/link.rb +0 -108
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/page/meta_refresh.rb +0 -78
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/page.rb +0 -648
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/parser.rb +0 -182
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/pluggable_parsers.rb +0 -179
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/prependable.rb +0 -89
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/redirect_limit_reached_error.rb +0 -19
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/redirect_not_get_or_head_error.rb +0 -21
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/response_code_error.rb +0 -26
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/response_read_error.rb +0 -38
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/robots_disallowed_error.rb +0 -28
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/.document +0 -1
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/bad_chunking_servlet.rb +0 -14
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/basic_auth_servlet.rb +0 -24
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/content_type_servlet.rb +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/digest_auth_servlet.rb +0 -33
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/file_upload_servlet.rb +0 -20
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/form_servlet.rb +0 -55
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/gzip_servlet.rb +0 -32
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/header_servlet.rb +0 -14
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/http_refresh_servlet.rb +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/infinite_redirect_servlet.rb +0 -10
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/infinite_refresh_servlet.rb +0 -9
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/many_cookies_as_string_servlet.rb +0 -37
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/many_cookies_servlet.rb +0 -33
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/modified_since_servlet.rb +0 -21
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/ntlm_servlet.rb +0 -30
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/one_cookie_no_spaces_servlet.rb +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/one_cookie_servlet.rb +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/quoted_value_cookie_servlet.rb +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/redirect_servlet.rb +0 -13
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/referer_servlet.rb +0 -12
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/refresh_with_empty_url.rb +0 -15
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/refresh_without_url.rb +0 -14
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/response_code_servlet.rb +0 -15
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/robots_txt_servlet.rb +0 -14
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/send_cookies_servlet.rb +0 -19
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/server.rb +0 -36
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/servlets.rb +0 -58
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case/verb_servlet.rb +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/test_case.rb +0 -330
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/unauthorized_error.rb +0 -22
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/unsupported_scheme_error.rb +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/util.rb +0 -161
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/version.rb +0 -3
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize/xml_file.rb +0 -47
- data/vendor/bundle/gems/mechanize-2.7.6/lib/mechanize.rb +0 -1369
- data/vendor/bundle/gems/mechanize-2.7.6/mechanize.gemspec +0 -66
- data/vendor/bundle/gems/mechanize-2.7.6/test/data/htpasswd +0 -1
- data/vendor/bundle/gems/mechanize-2.7.6/test/data/server.crt +0 -16
- data/vendor/bundle/gems/mechanize-2.7.6/test/data/server.csr +0 -12
- data/vendor/bundle/gems/mechanize-2.7.6/test/data/server.key +0 -15
- data/vendor/bundle/gems/mechanize-2.7.6/test/data/server.pem +0 -15
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/alt_text.html +0 -10
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/bad_form_test.html +0 -9
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/button.jpg +0 -0
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/canonical_uri.html +0 -9
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/dir with spaces/foo.html +0 -1
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/empty_form.html +0 -6
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/file_upload.html +0 -26
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/find_link.html +0 -38
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/form_multi_select.html +0 -16
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/form_multival.html +0 -37
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/form_no_action.html +0 -18
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/form_no_input_name.html +0 -16
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/form_order_test.html +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/form_select.html +0 -16
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/form_set_fields.html +0 -14
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/form_test.html +0 -188
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/frame_referer_test.html +0 -10
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/frame_test.html +0 -30
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/google.html +0 -13
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/index.html +0 -6
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/link with space.html +0 -5
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/meta_cookie.html +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/no_title_test.html +0 -6
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/noindex.html +0 -9
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/rails_3_encoding_hack_form_test.html +0 -27
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/relative/tc_relative_links.html +0 -21
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/robots.html +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_bad_charset.html +0 -9
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_bad_links.html +0 -5
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_base_link.html +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_blank_form.html +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_charset.html +0 -6
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_checkboxes.html +0 -19
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_encoded_links.html +0 -5
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_field_precedence.html +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_follow_meta.html +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_follow_meta_loop_1.html +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_follow_meta_loop_2.html +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_form_action.html +0 -48
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_links.html +0 -21
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_meta_in_body.html +0 -9
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_pretty_print.html +0 -17
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_referer.html +0 -16
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_relative_links.html +0 -19
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/tc_textarea.html +0 -23
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/test_click.html +0 -11
- data/vendor/bundle/gems/mechanize-2.7.6/test/htdocs/unusual______.html +0 -5
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize.rb +0 -1361
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_cookie.rb +0 -547
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_cookie_jar.rb +0 -582
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_directory_saver.rb +0 -59
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_download.rb +0 -89
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_element_not_found_error.rb +0 -15
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_file.rb +0 -107
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_file_connection.rb +0 -21
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_file_request.rb +0 -25
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_file_response.rb +0 -23
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_file_saver.rb +0 -21
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form.rb +0 -1012
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_check_box.rb +0 -48
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_encoding.rb +0 -109
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_field.rb +0 -77
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_file_upload.rb +0 -20
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_image_button.rb +0 -12
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_keygen.rb +0 -32
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_multi_select_list.rb +0 -97
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_option.rb +0 -59
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_radio_button.rb +0 -95
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_select_list.rb +0 -80
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_form_textarea.rb +0 -52
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_headers.rb +0 -35
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_history.rb +0 -103
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_http_agent.rb +0 -1754
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_http_auth_challenge.rb +0 -63
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_http_auth_realm.rb +0 -55
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_http_auth_store.rb +0 -232
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_http_content_disposition_parser.rb +0 -139
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_http_www_authenticate_parser.rb +0 -203
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_image.rb +0 -8
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_link.rb +0 -146
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_page.rb +0 -280
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_page_encoding.rb +0 -187
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_page_frame.rb +0 -16
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_page_image.rb +0 -190
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_page_link.rb +0 -373
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_page_meta_refresh.rb +0 -150
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_parser.rb +0 -315
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_pluggable_parser.rb +0 -67
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_redirect_limit_reached_error.rb +0 -24
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_redirect_not_get_or_head_error.rb +0 -14
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_response_read_error.rb +0 -28
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_subclass.rb +0 -22
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_util.rb +0 -143
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_mechanize_xml_file.rb +0 -29
- data/vendor/bundle/gems/mechanize-2.7.6/test/test_multi_select.rb +0 -119
- data/vendor/bundle/gems/mime-types-3.3.1/Code-of-Conduct.md +0 -73
- data/vendor/bundle/gems/mime-types-3.3.1/Contributing.md +0 -143
- data/vendor/bundle/gems/mime-types-3.3.1/History.md +0 -240
- data/vendor/bundle/gems/mime-types-3.3.1/Licence.md +0 -25
- data/vendor/bundle/gems/mime-types-3.3.1/Manifest.txt +0 -31
- data/vendor/bundle/gems/mime-types-3.3.1/README.rdoc +0 -193
- data/vendor/bundle/gems/mime-types-3.3.1/Rakefile +0 -284
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/type/columnar.rb +0 -57
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/type.rb +0 -587
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/_columnar.rb +0 -136
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/cache.rb +0 -58
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/columnar.rb +0 -3
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/container.rb +0 -96
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/deprecations.rb +0 -32
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/full.rb +0 -19
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/loader.rb +0 -146
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/logger.rb +0 -39
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types/registry.rb +0 -90
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime/types.rb +0 -231
- data/vendor/bundle/gems/mime-types-3.3.1/lib/mime-types.rb +0 -3
- data/vendor/bundle/gems/mime-types-3.3.1/test/bad-fixtures/malformed +0 -9
- data/vendor/bundle/gems/mime-types-3.3.1/test/fixture/json.json +0 -1
- data/vendor/bundle/gems/mime-types-3.3.1/test/fixture/old-data +0 -9
- data/vendor/bundle/gems/mime-types-3.3.1/test/fixture/yaml.yaml +0 -55
- data/vendor/bundle/gems/mime-types-3.3.1/test/minitest_helper.rb +0 -13
- data/vendor/bundle/gems/mime-types-3.3.1/test/test_mime_type.rb +0 -610
- data/vendor/bundle/gems/mime-types-3.3.1/test/test_mime_types.rb +0 -169
- data/vendor/bundle/gems/mime-types-3.3.1/test/test_mime_types_cache.rb +0 -118
- data/vendor/bundle/gems/mime-types-3.3.1/test/test_mime_types_class.rb +0 -159
- data/vendor/bundle/gems/mime-types-3.3.1/test/test_mime_types_lazy.rb +0 -49
- data/vendor/bundle/gems/mime-types-3.3.1/test/test_mime_types_loader.rb +0 -32
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/Code-of-Conduct.md +0 -75
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/Contributing.md +0 -162
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/History.md +0 -406
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/Licence.md +0 -25
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/Manifest.txt +0 -31
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/README.md +0 -63
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/Rakefile +0 -94
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime-types.json +0 -1
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime.content_type.column +0 -2215
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime.docs.column +0 -2215
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime.encoding.column +0 -2215
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime.flags.column +0 -2215
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime.friendly.column +0 -2215
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime.pext.column +0 -2215
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime.use_instead.column +0 -2215
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/data/mime.xrefs.column +0 -2215
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/lib/mime/types/data.rb +0 -21
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/lib/mime-types-data.rb +0 -3
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/application.yaml +0 -16361
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/audio.yaml +0 -1644
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/chemical.yaml +0 -71
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/conference.yaml +0 -9
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/drawing.yaml +0 -15
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/font.yaml +0 -65
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/image.yaml +0 -1069
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/message.yaml +0 -200
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/model.yaml +0 -302
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/multipart.yaml +0 -179
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/text.yaml +0 -1055
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/video.yaml +0 -1070
- data/vendor/bundle/gems/mime-types-data-3.2019.1009/types/world.yaml +0 -8
- data/vendor/bundle/gems/mini_portile2-2.4.0/.concourse.yml +0 -83
- data/vendor/bundle/gems/mini_portile2-2.4.0/.gitignore +0 -7
- data/vendor/bundle/gems/mini_portile2-2.4.0/.travis.yml +0 -15
- data/vendor/bundle/gems/mini_portile2-2.4.0/CHANGELOG.md +0 -209
- data/vendor/bundle/gems/mini_portile2-2.4.0/Gemfile +0 -4
- data/vendor/bundle/gems/mini_portile2-2.4.0/LICENSE.txt +0 -20
- data/vendor/bundle/gems/mini_portile2-2.4.0/README.md +0 -245
- data/vendor/bundle/gems/mini_portile2-2.4.0/Rakefile +0 -29
- data/vendor/bundle/gems/mini_portile2-2.4.0/appveyor.yml +0 -25
- data/vendor/bundle/gems/mini_portile2-2.4.0/concourse/mini_portile.yml +0 -141
- data/vendor/bundle/gems/mini_portile2-2.4.0/concourse/tasks/rake-test/task.ps1 +0 -11
- data/vendor/bundle/gems/mini_portile2-2.4.0/concourse/tasks/rake-test/task.sh +0 -13
- data/vendor/bundle/gems/mini_portile2-2.4.0/lib/mini_portile2/mini_portile.rb +0 -556
- data/vendor/bundle/gems/mini_portile2-2.4.0/lib/mini_portile2/mini_portile_cmake.rb +0 -40
- data/vendor/bundle/gems/mini_portile2-2.4.0/lib/mini_portile2/version.rb +0 -3
- data/vendor/bundle/gems/mini_portile2-2.4.0/lib/mini_portile2.rb +0 -3
- data/vendor/bundle/gems/mini_portile2-2.4.0/mini_portile2.gemspec +0 -42
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/git/config +0 -4
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/gpg-fixtures/data +0 -1
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/gpg-fixtures/data.asc +0 -9
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/gpg-fixtures/data.invalid.asc +0 -9
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/patch 1.diff +0 -7
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/test mini portile-1.0.0/configure +0 -11
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/test-cmake-1.0/CMakeLists.txt +0 -7
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/test-cmake-1.0/hello.c +0 -4
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/assets/test-download-archive.tar.gz +0 -1
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/helper.rb +0 -60
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/test_cmake.rb +0 -64
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/test_cook.rb +0 -115
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/test_digest.rb +0 -215
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/test_download.rb +0 -71
- data/vendor/bundle/gems/mini_portile2-2.4.0/test/test_proxy.rb +0 -121
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/.autotest +0 -8
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/.travis.yml +0 -16
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/History.txt +0 -52
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/Manifest.txt +0 -10
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/README.txt +0 -44
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/Rakefile +0 -25
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/lib/net/http/digest_auth.rb +0 -173
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/sample/auth_server.rb +0 -47
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/sample/net_http_example.rb +0 -27
- data/vendor/bundle/gems/net-http-digest_auth-1.4.1/test/test_net_http_digest_auth.rb +0 -130
- data/vendor/bundle/gems/net-http-persistent-3.1.0/.autotest +0 -9
- data/vendor/bundle/gems/net-http-persistent-3.1.0/.gemtest +0 -0
- data/vendor/bundle/gems/net-http-persistent-3.1.0/.travis.yml +0 -24
- data/vendor/bundle/gems/net-http-persistent-3.1.0/Gemfile +0 -15
- data/vendor/bundle/gems/net-http-persistent-3.1.0/History.txt +0 -391
- data/vendor/bundle/gems/net-http-persistent-3.1.0/Manifest.txt +0 -14
- data/vendor/bundle/gems/net-http-persistent-3.1.0/README.rdoc +0 -82
- data/vendor/bundle/gems/net-http-persistent-3.1.0/Rakefile +0 -31
- data/vendor/bundle/gems/net-http-persistent-3.1.0/lib/net/http/persistent/connection.rb +0 -40
- data/vendor/bundle/gems/net-http-persistent-3.1.0/lib/net/http/persistent/pool.rb +0 -53
- data/vendor/bundle/gems/net-http-persistent-3.1.0/lib/net/http/persistent/timed_stack_multi.rb +0 -79
- data/vendor/bundle/gems/net-http-persistent-3.1.0/lib/net/http/persistent.rb +0 -1202
- data/vendor/bundle/gems/net-http-persistent-3.1.0/test/test_net_http_persistent.rb +0 -1621
- data/vendor/bundle/gems/net-http-persistent-3.1.0/test/test_net_http_persistent_timed_stack_multi.rb +0 -151
- data/vendor/bundle/gems/nokogiri-1.10.7/LICENSE-DEPENDENCIES.md +0 -1614
- data/vendor/bundle/gems/nokogiri-1.10.7/LICENSE.md +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/README.md +0 -198
- data/vendor/bundle/gems/nokogiri-1.10.7/bin/nokogiri +0 -118
- data/vendor/bundle/gems/nokogiri-1.10.7/dependencies.yml +0 -74
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/.sitearchdir.-.nokogiri.time +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/Makefile +0 -629
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/depend +0 -358
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/extconf.rb +0 -686
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_document.c +0 -170
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_document.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_document.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_element_description.c +0 -279
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_element_description.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_element_description.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_entity_lookup.c +0 -32
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_entity_lookup.h +0 -8
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_entity_lookup.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_sax_parser_context.c +0 -116
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_sax_parser_context.h +0 -11
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_sax_parser_context.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_sax_push_parser.c +0 -87
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_sax_push_parser.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/html_sax_push_parser.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/nokogiri.bundle +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/nokogiri.c +0 -141
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/nokogiri.h +0 -121
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/nokogiri.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_attr.c +0 -103
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_attr.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_attr.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_attribute_decl.c +0 -70
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_attribute_decl.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_attribute_decl.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_cdata.c +0 -62
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_cdata.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_cdata.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_comment.c +0 -69
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_comment.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_comment.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_document.c +0 -608
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_document.h +0 -23
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_document.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_document_fragment.c +0 -48
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_document_fragment.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_document_fragment.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_dtd.c +0 -202
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_dtd.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_dtd.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_element_content.c +0 -123
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_element_content.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_element_content.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_element_decl.c +0 -69
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_element_decl.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_element_decl.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_encoding_handler.c +0 -79
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_encoding_handler.h +0 -8
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_encoding_handler.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_entity_decl.c +0 -110
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_entity_decl.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_entity_decl.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_entity_reference.c +0 -52
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_entity_reference.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_entity_reference.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_io.c +0 -61
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_io.h +0 -11
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_io.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_libxml2_hacks.c +0 -112
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_libxml2_hacks.h +0 -12
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_libxml2_hacks.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_namespace.c +0 -111
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_namespace.h +0 -14
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_namespace.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_node.c +0 -1753
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_node.h +0 -13
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_node.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_node_set.c +0 -486
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_node_set.h +0 -12
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_node_set.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_processing_instruction.c +0 -56
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_processing_instruction.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_processing_instruction.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_reader.c +0 -668
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_reader.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_reader.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_relax_ng.c +0 -161
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_relax_ng.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_relax_ng.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_parser.c +0 -310
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_parser.h +0 -39
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_parser.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_parser_context.c +0 -262
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_parser_context.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_parser_context.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_push_parser.c +0 -159
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_push_parser.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_sax_push_parser.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_schema.c +0 -205
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_schema.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_schema.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_syntax_error.c +0 -64
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_syntax_error.h +0 -13
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_syntax_error.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_text.c +0 -52
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_text.h +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_text.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_xpath_context.c +0 -298
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_xpath_context.h +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xml_xpath_context.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xslt_stylesheet.c +0 -270
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xslt_stylesheet.h +0 -14
- data/vendor/bundle/gems/nokogiri-1.10.7/ext/nokogiri/xslt_stylesheet.o +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css/node.rb +0 -52
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css/parser.rb +0 -750
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css/parser.y +0 -272
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css/parser_extras.rb +0 -91
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css/syntax_error.rb +0 -7
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css/tokenizer.rb +0 -153
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css/tokenizer.rex +0 -55
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css/xpath_visitor.rb +0 -230
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/css.rb +0 -27
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/decorators/slop.rb +0 -42
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/builder.rb +0 -35
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/document.rb +0 -335
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/document_fragment.rb +0 -49
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/element_description.rb +0 -23
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/element_description_defaults.rb +0 -671
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/entity_lookup.rb +0 -13
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/sax/parser.rb +0 -62
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/sax/parser_context.rb +0 -16
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html/sax/push_parser.rb +0 -36
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/html.rb +0 -37
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/nokogiri.bundle +0 -0
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/syntax_error.rb +0 -4
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/version.rb +0 -109
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/attr.rb +0 -14
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/attribute_decl.rb +0 -18
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/builder.rb +0 -446
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/cdata.rb +0 -11
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/character_data.rb +0 -7
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/document.rb +0 -285
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/document_fragment.rb +0 -160
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/dtd.rb +0 -32
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/element_content.rb +0 -36
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/element_decl.rb +0 -13
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/entity_decl.rb +0 -19
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/entity_reference.rb +0 -18
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/namespace.rb +0 -13
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/node/save_options.rb +0 -61
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/node.rb +0 -902
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/node_set.rb +0 -371
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/notation.rb +0 -6
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/parse_options.rb +0 -120
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/pp/character_data.rb +0 -18
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/pp/node.rb +0 -56
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/pp.rb +0 -2
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/processing_instruction.rb +0 -8
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/reader.rb +0 -112
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/relax_ng.rb +0 -32
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/sax/document.rb +0 -171
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/sax/parser.rb +0 -122
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/sax/parser_context.rb +0 -16
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/sax/push_parser.rb +0 -60
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/sax.rb +0 -4
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/schema.rb +0 -63
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/searchable.rb +0 -230
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/syntax_error.rb +0 -70
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/text.rb +0 -9
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/xpath/syntax_error.rb +0 -11
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/xpath.rb +0 -10
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml/xpath_context.rb +0 -16
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xml.rb +0 -75
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xslt/stylesheet.rb +0 -25
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri/xslt.rb +0 -56
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/nokogiri.rb +0 -144
- data/vendor/bundle/gems/nokogiri-1.10.7/lib/xsd/xmlparser/nokogiri.rb +0 -102
- data/vendor/bundle/gems/nokogiri-1.10.7/patches/libxml2/0001-Revert-Do-not-URI-escape-in-server-side-includes.patch +0 -78
- data/vendor/bundle/gems/nokogiri-1.10.7/patches/libxml2/0002-Remove-script-macro-support.patch +0 -40
- data/vendor/bundle/gems/nokogiri-1.10.7/patches/libxml2/0003-Update-entities-to-remove-handling-of-ssi.patch +0 -44
- data/vendor/bundle/gems/nokogiri-1.10.7/patches/libxml2/0004-libxml2.la-is-in-top_builddir.patch +0 -25
- data/vendor/bundle/gems/ntlm-http-0.1.1/README +0 -25
- data/vendor/bundle/gems/ntlm-http-0.1.1/Rakefile +0 -66
- data/vendor/bundle/gems/ntlm-http-0.1.1/examples/http.rb +0 -86
- data/vendor/bundle/gems/ntlm-http-0.1.1/examples/imap.rb +0 -73
- data/vendor/bundle/gems/ntlm-http-0.1.1/examples/smtp.rb +0 -94
- data/vendor/bundle/gems/ntlm-http-0.1.1/lib/net/ntlm.rb +0 -774
- data/vendor/bundle/gems/ntlm-http-0.1.1/lib/net/ntlm_http.rb +0 -854
- data/vendor/bundle/gems/ntlm-http-0.1.1/ntlm-http-0.1.1.gemspec +0 -16
- data/vendor/bundle/gems/ntlm-http-0.1.1/test/function_test.rb +0 -111
- data/vendor/bundle/gems/rake-12.3.3/CONTRIBUTING.rdoc +0 -43
- data/vendor/bundle/gems/rake-12.3.3/Gemfile +0 -3
- data/vendor/bundle/gems/rake-12.3.3/History.rdoc +0 -2344
- data/vendor/bundle/gems/rake-12.3.3/MIT-LICENSE +0 -21
- data/vendor/bundle/gems/rake-12.3.3/README.rdoc +0 -156
- data/vendor/bundle/gems/rake-12.3.3/Rakefile +0 -41
- data/vendor/bundle/gems/rake-12.3.3/azure-pipelines.yml +0 -11
- data/vendor/bundle/gems/rake-12.3.3/bin/bundle +0 -105
- data/vendor/bundle/gems/rake-12.3.3/bin/console +0 -7
- data/vendor/bundle/gems/rake-12.3.3/bin/rake +0 -29
- data/vendor/bundle/gems/rake-12.3.3/bin/rdoc +0 -29
- data/vendor/bundle/gems/rake-12.3.3/bin/rubocop +0 -29
- data/vendor/bundle/gems/rake-12.3.3/bin/setup +0 -6
- data/vendor/bundle/gems/rake-12.3.3/doc/command_line_usage.rdoc +0 -158
- data/vendor/bundle/gems/rake-12.3.3/doc/example/Rakefile1 +0 -38
- data/vendor/bundle/gems/rake-12.3.3/doc/example/Rakefile2 +0 -35
- data/vendor/bundle/gems/rake-12.3.3/doc/example/a.c +0 -6
- data/vendor/bundle/gems/rake-12.3.3/doc/example/b.c +0 -6
- data/vendor/bundle/gems/rake-12.3.3/doc/example/main.c +0 -11
- data/vendor/bundle/gems/rake-12.3.3/doc/glossary.rdoc +0 -42
- data/vendor/bundle/gems/rake-12.3.3/doc/jamis.rb +0 -592
- data/vendor/bundle/gems/rake-12.3.3/doc/proto_rake.rdoc +0 -127
- data/vendor/bundle/gems/rake-12.3.3/doc/rake.1 +0 -156
- data/vendor/bundle/gems/rake-12.3.3/doc/rakefile.rdoc +0 -622
- data/vendor/bundle/gems/rake-12.3.3/doc/rational.rdoc +0 -151
- data/vendor/bundle/gems/rake-12.3.3/exe/rake +0 -27
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/application.rb +0 -824
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/backtrace.rb +0 -24
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/clean.rb +0 -78
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/cloneable.rb +0 -17
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/cpu_counter.rb +0 -107
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/default_loader.rb +0 -15
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/dsl_definition.rb +0 -195
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/early_time.rb +0 -22
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/ext/core.rb +0 -26
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/ext/string.rb +0 -176
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/file_creation_task.rb +0 -25
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/file_list.rb +0 -435
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/file_task.rb +0 -54
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/file_utils.rb +0 -137
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/file_utils_ext.rb +0 -145
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/invocation_chain.rb +0 -57
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/invocation_exception_mixin.rb +0 -17
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/late_time.rb +0 -18
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/linked_list.rb +0 -112
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/loaders/makefile.rb +0 -54
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/multi_task.rb +0 -14
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/name_space.rb +0 -38
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/packagetask.rb +0 -207
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/phony.rb +0 -16
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/private_reader.rb +0 -21
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/promise.rb +0 -100
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/pseudo_status.rb +0 -30
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/rake_module.rb +0 -67
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/rake_test_loader.rb +0 -27
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/rule_recursion_overflow_error.rb +0 -20
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/scope.rb +0 -43
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/task.rb +0 -413
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/task_argument_error.rb +0 -8
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/task_arguments.rb +0 -109
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/task_manager.rb +0 -324
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/tasklib.rb +0 -12
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/testtask.rb +0 -224
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/thread_history_display.rb +0 -49
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/thread_pool.rb +0 -163
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/trace_output.rb +0 -23
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/version.rb +0 -10
- data/vendor/bundle/gems/rake-12.3.3/lib/rake/win32.rb +0 -51
- data/vendor/bundle/gems/rake-12.3.3/lib/rake.rb +0 -71
- data/vendor/bundle/gems/rake-12.3.3/rake.gemspec +0 -42
- data/vendor/bundle/gems/rspec-3.9.0/LICENSE.md +0 -27
- data/vendor/bundle/gems/rspec-3.9.0/README.md +0 -43
- data/vendor/bundle/gems/rspec-3.9.0/lib/rspec/version.rb +0 -5
- data/vendor/bundle/gems/rspec-3.9.0/lib/rspec.rb +0 -3
- data/vendor/bundle/gems/rspec-core-3.9.1/.document +0 -5
- data/vendor/bundle/gems/rspec-core-3.9.1/.yardopts +0 -8
- data/vendor/bundle/gems/rspec-core-3.9.1/Changelog.md +0 -2274
- data/vendor/bundle/gems/rspec-core-3.9.1/LICENSE.md +0 -26
- data/vendor/bundle/gems/rspec-core-3.9.1/README.md +0 -384
- data/vendor/bundle/gems/rspec-core-3.9.1/exe/rspec +0 -4
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/autorun.rb +0 -3
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/backtrace_formatter.rb +0 -65
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/bisect/coordinator.rb +0 -62
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/bisect/example_minimizer.rb +0 -173
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/bisect/fork_runner.rb +0 -135
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/bisect/server.rb +0 -61
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/bisect/shell_command.rb +0 -126
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/bisect/shell_runner.rb +0 -73
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/bisect/utilities.rb +0 -58
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/configuration.rb +0 -2336
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/configuration_options.rb +0 -233
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/did_you_mean.rb +0 -46
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/drb.rb +0 -113
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/dsl.rb +0 -98
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/example.rb +0 -656
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/example_group.rb +0 -889
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/example_status_persister.rb +0 -235
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/filter_manager.rb +0 -231
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/flat_map.rb +0 -20
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/base_bisect_formatter.rb +0 -45
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/base_formatter.rb +0 -70
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/base_text_formatter.rb +0 -75
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/bisect_drb_formatter.rb +0 -29
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/bisect_progress_formatter.rb +0 -157
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/console_codes.rb +0 -68
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/deprecation_formatter.rb +0 -223
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/documentation_formatter.rb +0 -102
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/exception_presenter.rb +0 -508
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/failure_list_formatter.rb +0 -23
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/fallback_message_formatter.rb +0 -28
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/helpers.rb +0 -110
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/html_formatter.rb +0 -153
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/html_printer.rb +0 -414
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/html_snippet_extractor.rb +0 -120
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/json_formatter.rb +0 -102
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/profile_formatter.rb +0 -68
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/progress_formatter.rb +0 -29
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/protocol.rb +0 -182
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/snippet_extractor.rb +0 -134
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters/syntax_highlighter.rb +0 -91
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/formatters.rb +0 -272
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/hooks.rb +0 -632
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/invocations.rb +0 -87
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/memoized_helpers.rb +0 -554
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/metadata.rb +0 -498
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/metadata_filter.rb +0 -255
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/minitest_assertions_adapter.rb +0 -31
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/mocking_adapters/flexmock.rb +0 -31
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/mocking_adapters/mocha.rb +0 -57
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/mocking_adapters/null.rb +0 -14
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/mocking_adapters/rr.rb +0 -31
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/mocking_adapters/rspec.rb +0 -32
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/notifications.rb +0 -521
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/option_parser.rb +0 -316
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/ordering.rb +0 -158
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/output_wrapper.rb +0 -29
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/pending.rb +0 -165
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/profiler.rb +0 -34
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/project_initializer/.rspec +0 -1
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/project_initializer/spec/spec_helper.rb +0 -100
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/project_initializer.rb +0 -48
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/rake_task.rb +0 -188
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/reporter.rb +0 -265
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/ruby_project.rb +0 -53
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/runner.rb +0 -204
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/sandbox.rb +0 -37
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/set.rb +0 -54
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/shared_context.rb +0 -55
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/shared_example_group.rb +0 -269
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/shell_escape.rb +0 -49
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/test_unit_assertions_adapter.rb +0 -30
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/version.rb +0 -9
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/warnings.rb +0 -40
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core/world.rb +0 -275
- data/vendor/bundle/gems/rspec-core-3.9.1/lib/rspec/core.rb +0 -186
- data/vendor/bundle/gems/rspec-expectations-3.9.0/.document +0 -5
- data/vendor/bundle/gems/rspec-expectations-3.9.0/.yardopts +0 -6
- data/vendor/bundle/gems/rspec-expectations-3.9.0/Changelog.md +0 -1170
- data/vendor/bundle/gems/rspec-expectations-3.9.0/LICENSE.md +0 -25
- data/vendor/bundle/gems/rspec-expectations-3.9.0/README.md +0 -320
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/block_snippet_extractor.rb +0 -253
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/configuration.rb +0 -215
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/expectation_target.rb +0 -127
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/fail_with.rb +0 -39
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/failure_aggregator.rb +0 -194
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/handler.rb +0 -170
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/minitest_integration.rb +0 -58
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/syntax.rb +0 -132
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations/version.rb +0 -8
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/expectations.rb +0 -82
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/aliased_matcher.rb +0 -116
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/all.rb +0 -86
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/base_matcher.rb +0 -193
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/be.rb +0 -288
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/be_between.rb +0 -77
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/be_instance_of.rb +0 -26
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/be_kind_of.rb +0 -20
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/be_within.rb +0 -72
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/change.rb +0 -428
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/compound.rb +0 -276
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/contain_exactly.rb +0 -302
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/cover.rb +0 -24
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/eq.rb +0 -40
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/eql.rb +0 -34
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/equal.rb +0 -81
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/exist.rb +0 -90
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/has.rb +0 -103
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/have_attributes.rb +0 -114
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/include.rb +0 -149
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/match.rb +0 -106
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/operators.rb +0 -128
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/output.rb +0 -200
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/raise_error.rb +0 -230
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/respond_to.rb +0 -174
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/satisfy.rb +0 -60
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/start_or_end_with.rb +0 -94
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/throw_symbol.rb +0 -132
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in/yield.rb +0 -432
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/built_in.rb +0 -52
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/composable.rb +0 -171
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/dsl.rb +0 -534
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/english_phrasing.rb +0 -58
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/expecteds_for_multiple_diffs.rb +0 -82
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/fail_matchers.rb +0 -42
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/generated_descriptions.rb +0 -41
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/matcher_delegator.rb +0 -35
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers/matcher_protocol.rb +0 -99
- data/vendor/bundle/gems/rspec-expectations-3.9.0/lib/rspec/matchers.rb +0 -1038
- data/vendor/bundle/gems/rspec-mocks-3.9.1/.document +0 -5
- data/vendor/bundle/gems/rspec-mocks-3.9.1/.yardopts +0 -6
- data/vendor/bundle/gems/rspec-mocks-3.9.1/Changelog.md +0 -1133
- data/vendor/bundle/gems/rspec-mocks-3.9.1/LICENSE.md +0 -25
- data/vendor/bundle/gems/rspec-mocks-3.9.1/README.md +0 -463
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/chain.rb +0 -111
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/error_generator.rb +0 -31
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/expect_chain_chain.rb +0 -31
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/expectation_chain.rb +0 -50
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/message_chains.rb +0 -83
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/proxy.rb +0 -116
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/recorder.rb +0 -294
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/stub_chain.rb +0 -51
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance/stub_chain_chain.rb +0 -23
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/any_instance.rb +0 -11
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/argument_list_matcher.rb +0 -100
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/argument_matchers.rb +0 -322
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/configuration.rb +0 -212
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/error_generator.rb +0 -369
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/example_methods.rb +0 -434
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/instance_method_stasher.rb +0 -146
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/marshal_extension.rb +0 -41
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/matchers/expectation_customization.rb +0 -20
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/matchers/have_received.rb +0 -134
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/matchers/receive.rb +0 -132
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/matchers/receive_message_chain.rb +0 -82
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/matchers/receive_messages.rb +0 -77
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/message_chain.rb +0 -87
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/message_expectation.rb +0 -751
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/method_double.rb +0 -287
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/method_reference.rb +0 -202
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/minitest_integration.rb +0 -68
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/mutate_const.rb +0 -339
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/object_reference.rb +0 -149
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/order_group.rb +0 -81
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/proxy.rb +0 -503
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/space.rb +0 -238
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/standalone.rb +0 -3
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/syntax.rb +0 -325
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/targets.rb +0 -124
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/test_double.rb +0 -171
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/verifying_double.rb +0 -129
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/verifying_message_expectation.rb +0 -54
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/verifying_proxy.rb +0 -220
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks/version.rb +0 -9
- data/vendor/bundle/gems/rspec-mocks-3.9.1/lib/rspec/mocks.rb +0 -130
- data/vendor/bundle/gems/rspec-support-3.9.2/Changelog.md +0 -292
- data/vendor/bundle/gems/rspec-support-3.9.2/LICENSE.md +0 -23
- data/vendor/bundle/gems/rspec-support-3.9.2/README.md +0 -40
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/caller_filter.rb +0 -83
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/comparable_version.rb +0 -46
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/differ.rb +0 -215
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/directory_maker.rb +0 -63
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/encoded_string.rb +0 -161
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/fuzzy_matcher.rb +0 -48
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/hunk_generator.rb +0 -47
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/matcher_definition.rb +0 -42
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/method_signature_verifier.rb +0 -438
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/mutex.rb +0 -73
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/object_formatter.rb +0 -275
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/recursive_const_methods.rb +0 -76
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/reentrant_mutex.rb +0 -53
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/ruby_features.rb +0 -185
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/source/location.rb +0 -21
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/source/node.rb +0 -110
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/source/token.rb +0 -87
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/source.rb +0 -75
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/deprecation_helpers.rb +0 -64
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/formatting_support.rb +0 -9
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/in_sub_process.rb +0 -69
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/library_wide_checks.rb +0 -150
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/shell_out.rb +0 -89
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/stderr_splitter.rb +0 -67
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/string_matcher.rb +0 -46
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/with_isolated_directory.rb +0 -13
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec/with_isolated_stderr.rb +0 -13
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/spec.rb +0 -81
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/version.rb +0 -7
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support/warnings.rb +0 -39
- data/vendor/bundle/gems/rspec-support-3.9.2/lib/rspec/support.rb +0 -149
- data/vendor/bundle/gems/unf-0.1.4/.gitignore +0 -17
- data/vendor/bundle/gems/unf-0.1.4/.travis.yml +0 -17
- data/vendor/bundle/gems/unf-0.1.4/CHANGELOG.md +0 -46
- data/vendor/bundle/gems/unf-0.1.4/Gemfile +0 -4
- data/vendor/bundle/gems/unf-0.1.4/LICENSE +0 -24
- data/vendor/bundle/gems/unf-0.1.4/README.md +0 -39
- data/vendor/bundle/gems/unf-0.1.4/Rakefile +0 -21
- data/vendor/bundle/gems/unf-0.1.4/lib/unf/normalizer.rb +0 -35
- data/vendor/bundle/gems/unf-0.1.4/lib/unf/normalizer_cruby.rb +0 -1
- data/vendor/bundle/gems/unf-0.1.4/lib/unf/normalizer_jruby.rb +0 -30
- data/vendor/bundle/gems/unf-0.1.4/lib/unf/version.rb +0 -3
- data/vendor/bundle/gems/unf-0.1.4/lib/unf.rb +0 -38
- data/vendor/bundle/gems/unf-0.1.4/test/helper.rb +0 -18
- data/vendor/bundle/gems/unf-0.1.4/test/normalization-test.txt +0 -108816
- data/vendor/bundle/gems/unf-0.1.4/test/test_unf.rb +0 -41
- data/vendor/bundle/gems/unf-0.1.4/unf.gemspec +0 -35
- data/vendor/bundle/gems/unf_ext-0.0.7.6/.document +0 -5
- data/vendor/bundle/gems/unf_ext-0.0.7.6/.gitignore +0 -19
- data/vendor/bundle/gems/unf_ext-0.0.7.6/.travis.yml +0 -24
- data/vendor/bundle/gems/unf_ext-0.0.7.6/CHANGELOG.md +0 -42
- data/vendor/bundle/gems/unf_ext-0.0.7.6/Gemfile +0 -4
- data/vendor/bundle/gems/unf_ext-0.0.7.6/LICENSE.txt +0 -22
- data/vendor/bundle/gems/unf_ext-0.0.7.6/README.md +0 -57
- data/vendor/bundle/gems/unf_ext-0.0.7.6/Rakefile +0 -31
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/.sitearchdir.time +0 -0
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/extconf.rb +0 -50
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf/normalizer.hh +0 -139
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf/table.hh +0 -13617
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf/trie/char_stream.hh +0 -150
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf/trie/node.hh +0 -25
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf/trie/searcher.hh +0 -194
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf/util.hh +0 -24
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf.cc +0 -75
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf.o +0 -0
- data/vendor/bundle/gems/unf_ext-0.0.7.6/ext/unf_ext/unf_ext.bundle +0 -0
- data/vendor/bundle/gems/unf_ext-0.0.7.6/lib/unf_ext/version.rb +0 -5
- data/vendor/bundle/gems/unf_ext-0.0.7.6/lib/unf_ext.bundle +0 -0
- data/vendor/bundle/gems/unf_ext-0.0.7.6/lib/unf_ext.rb +0 -5
- data/vendor/bundle/gems/unf_ext-0.0.7.6/test/helper.rb +0 -18
- data/vendor/bundle/gems/unf_ext-0.0.7.6/test/normalization-test.txt +0 -112332
- data/vendor/bundle/gems/unf_ext-0.0.7.6/test/test_unf_ext.rb +0 -41
- data/vendor/bundle/gems/unf_ext-0.0.7.6/unf_ext.gemspec +0 -42
- data/vendor/bundle/gems/webrobots-0.1.2/.document +0 -4
- data/vendor/bundle/gems/webrobots-0.1.2/.gitignore +0 -11
- data/vendor/bundle/gems/webrobots-0.1.2/.travis.yml +0 -17
- data/vendor/bundle/gems/webrobots-0.1.2/Gemfile +0 -4
- data/vendor/bundle/gems/webrobots-0.1.2/LICENSE.txt +0 -24
- data/vendor/bundle/gems/webrobots-0.1.2/README.rdoc +0 -38
- data/vendor/bundle/gems/webrobots-0.1.2/Rakefile +0 -29
- data/vendor/bundle/gems/webrobots-0.1.2/lib/webrobots/nokogiri.rb +0 -32
- data/vendor/bundle/gems/webrobots-0.1.2/lib/webrobots/robotstxt.rb +0 -752
- data/vendor/bundle/gems/webrobots-0.1.2/lib/webrobots/robotstxt.ry +0 -487
- data/vendor/bundle/gems/webrobots-0.1.2/lib/webrobots/version.rb +0 -3
- data/vendor/bundle/gems/webrobots-0.1.2/lib/webrobots.rb +0 -213
- data/vendor/bundle/gems/webrobots-0.1.2/test/helper.rb +0 -25
- data/vendor/bundle/gems/webrobots-0.1.2/test/simplecov_start.rb +0 -9
- data/vendor/bundle/gems/webrobots-0.1.2/test/test_webrobots.rb +0 -806
- data/vendor/bundle/gems/webrobots-0.1.2/test/vcr_cassettes/major_sites.yml +0 -2006
- data/vendor/bundle/gems/webrobots-0.1.2/webrobots.gemspec +0 -46
- data/vendor/bundle/specifications/connection_pool-2.2.2.gemspec +0 -38
- data/vendor/bundle/specifications/diff-lcs-1.3.gemspec +0 -61
- data/vendor/bundle/specifications/domain_name-0.5.20190701.gemspec +0 -46
- data/vendor/bundle/specifications/http-cookie-1.0.3.gemspec +0 -52
- data/vendor/bundle/specifications/mechanize-2.7.6.gemspec +0 -69
- data/vendor/bundle/specifications/mime-types-3.3.1.gemspec +0 -85
- data/vendor/bundle/specifications/mime-types-data-3.2019.1009.gemspec +0 -60
- data/vendor/bundle/specifications/mini_portile2-2.4.0.gemspec +0 -48
- data/vendor/bundle/specifications/net-http-digest_auth-1.4.1.gemspec +0 -43
- data/vendor/bundle/specifications/net-http-persistent-3.1.0.gemspec +0 -52
- data/vendor/bundle/specifications/nokogiri-1.10.7.gemspec +0 -85
- data/vendor/bundle/specifications/ntlm-http-0.1.1.gemspec +0 -24
- data/vendor/bundle/specifications/rake-12.3.3.gemspec +0 -49
- data/vendor/bundle/specifications/rspec-3.9.0.gemspec +0 -43
- data/vendor/bundle/specifications/rspec-core-3.9.1.gemspec +0 -63
- data/vendor/bundle/specifications/rspec-expectations-3.9.0.gemspec +0 -51
- data/vendor/bundle/specifications/rspec-mocks-3.9.1.gemspec +0 -51
- data/vendor/bundle/specifications/rspec-support-3.9.2.gemspec +0 -39
- data/vendor/bundle/specifications/unf-0.1.4.gemspec +0 -46
- data/vendor/bundle/specifications/unf_ext-0.0.7.6.gemspec +0 -51
- data/vendor/bundle/specifications/webrobots-0.1.2.gemspec +0 -65
@@ -1,1754 +0,0 @@
|
|
1
|
-
# coding: utf-8
|
2
|
-
|
3
|
-
require 'mechanize/test_case'
|
4
|
-
|
5
|
-
class TestMechanizeHttpAgent < Mechanize::TestCase
|
6
|
-
|
7
|
-
def setup
|
8
|
-
super
|
9
|
-
|
10
|
-
@agent = @mech.agent
|
11
|
-
|
12
|
-
@uri = URI.parse 'http://example/'
|
13
|
-
|
14
|
-
@req = Net::HTTP::Get.new '/'
|
15
|
-
@res = Net::HTTPOK.allocate
|
16
|
-
@res.instance_variable_set :@code, 200
|
17
|
-
@res.instance_variable_set :@header, {}
|
18
|
-
|
19
|
-
@headers = if RUBY_VERSION >= '2.0.0' then
|
20
|
-
%w[accept accept-encoding user-agent]
|
21
|
-
else
|
22
|
-
%w[accept user-agent]
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
def auth_realm uri, scheme, type
|
27
|
-
base_uri = uri + '/'
|
28
|
-
realm = Mechanize::HTTP::AuthRealm.new scheme, base_uri, 'r'
|
29
|
-
@agent.authenticate_methods[base_uri][type] << realm
|
30
|
-
|
31
|
-
realm
|
32
|
-
end
|
33
|
-
|
34
|
-
def jruby_zlib?
|
35
|
-
if RUBY_ENGINE == 'jruby'
|
36
|
-
meth = caller[0][/`(\w+)/, 1]
|
37
|
-
warn "#{meth}: skipped because how Zlib handles error is different in JRuby"
|
38
|
-
true
|
39
|
-
else
|
40
|
-
false
|
41
|
-
end
|
42
|
-
end
|
43
|
-
|
44
|
-
def test_agent_is_named
|
45
|
-
assert_equal 'mechanize', Mechanize::HTTP::Agent.new.http.name
|
46
|
-
assert_equal 'unique', Mechanize::HTTP::Agent.new('unique').http.name
|
47
|
-
end
|
48
|
-
|
49
|
-
def test_auto_io
|
50
|
-
Tempfile.open 'input' do |input_io|
|
51
|
-
input_io.binmode
|
52
|
-
input_io.write '12345'
|
53
|
-
input_io.rewind
|
54
|
-
|
55
|
-
out_io = @agent.auto_io @NAME, 1024, input_io
|
56
|
-
|
57
|
-
assert_equal '12345', out_io.string
|
58
|
-
|
59
|
-
assert_equal Encoding::BINARY, out_io.string.encoding if
|
60
|
-
Object.const_defined? :Encoding
|
61
|
-
end
|
62
|
-
end
|
63
|
-
|
64
|
-
def test_auto_io_chunk
|
65
|
-
Tempfile.open 'input' do |input_io|
|
66
|
-
chunks = []
|
67
|
-
|
68
|
-
input_io.binmode
|
69
|
-
input_io.write '12345'
|
70
|
-
input_io.rewind
|
71
|
-
|
72
|
-
@agent.auto_io @NAME, 1, input_io do |chunk|
|
73
|
-
chunks << chunk
|
74
|
-
end
|
75
|
-
|
76
|
-
assert_equal %w[1 2 3 4 5], chunks
|
77
|
-
end
|
78
|
-
end
|
79
|
-
|
80
|
-
def test_auto_io_tempfile
|
81
|
-
@agent.max_file_buffer = 3
|
82
|
-
|
83
|
-
Tempfile.open 'input' do |input_io|
|
84
|
-
input_io.binmode
|
85
|
-
input_io.write '12345'
|
86
|
-
input_io.rewind
|
87
|
-
|
88
|
-
out_io = @agent.auto_io @NAME, 1, input_io
|
89
|
-
|
90
|
-
result = out_io.read
|
91
|
-
assert_equal '12345', result
|
92
|
-
|
93
|
-
assert_equal Encoding::BINARY, result.encoding if
|
94
|
-
Object.const_defined? :Encoding
|
95
|
-
end
|
96
|
-
end
|
97
|
-
|
98
|
-
def test_auto_io_yield
|
99
|
-
Tempfile.open 'input' do |input_io|
|
100
|
-
input_io.binmode
|
101
|
-
input_io.write '12345'
|
102
|
-
input_io.rewind
|
103
|
-
|
104
|
-
out_io = @agent.auto_io @NAME, 1024, input_io do |chunk|
|
105
|
-
"x#{chunk}"
|
106
|
-
end
|
107
|
-
|
108
|
-
assert_equal 'x12345', out_io.string
|
109
|
-
end
|
110
|
-
end
|
111
|
-
|
112
|
-
def test_certificate_equals
|
113
|
-
cert_path = File.expand_path '../data/server.crt', __FILE__
|
114
|
-
cert = OpenSSL::X509::Certificate.new File.read cert_path
|
115
|
-
|
116
|
-
@agent.certificate = cert
|
117
|
-
|
118
|
-
assert_equal cert.to_pem, @agent.certificate.to_pem
|
119
|
-
end
|
120
|
-
|
121
|
-
def test_certificate_equals_file
|
122
|
-
cert_path = File.expand_path '../data/server.crt', __FILE__
|
123
|
-
|
124
|
-
cert = OpenSSL::X509::Certificate.new File.read cert_path
|
125
|
-
|
126
|
-
@agent.certificate = cert_path
|
127
|
-
|
128
|
-
assert_equal cert.to_pem, @agent.certificate.to_pem
|
129
|
-
end
|
130
|
-
|
131
|
-
def test_connection_for_file
|
132
|
-
uri = URI.parse 'file:///nonexistent'
|
133
|
-
conn = @agent.connection_for uri
|
134
|
-
|
135
|
-
assert_equal Mechanize::FileConnection.new, conn
|
136
|
-
end
|
137
|
-
|
138
|
-
def test_connection_for_http
|
139
|
-
conn = @agent.connection_for @uri
|
140
|
-
|
141
|
-
assert_equal @agent.http, conn
|
142
|
-
end
|
143
|
-
|
144
|
-
def test_disable_keep_alive
|
145
|
-
@agent.disable_keep_alive @req
|
146
|
-
|
147
|
-
refute @req['connection']
|
148
|
-
end
|
149
|
-
|
150
|
-
def test_disable_keep_alive_no
|
151
|
-
@agent.keep_alive = false
|
152
|
-
|
153
|
-
@agent.disable_keep_alive @req
|
154
|
-
|
155
|
-
assert_equal 'close', @req['connection']
|
156
|
-
end
|
157
|
-
|
158
|
-
def test_enable_gzip
|
159
|
-
@agent.enable_gzip @req
|
160
|
-
|
161
|
-
assert_equal 'gzip,deflate,identity', @req['accept-encoding']
|
162
|
-
end
|
163
|
-
|
164
|
-
def test_enable_gzip_no
|
165
|
-
@agent.gzip_enabled = false
|
166
|
-
|
167
|
-
@agent.enable_gzip @req
|
168
|
-
|
169
|
-
assert_equal 'identity', @req['accept-encoding']
|
170
|
-
end
|
171
|
-
|
172
|
-
def test_fetch_file_nonexistent
|
173
|
-
in_tmpdir do
|
174
|
-
nonexistent = File.join Dir.pwd, 'nonexistent'
|
175
|
-
|
176
|
-
uri = URI.parse "file:///#{nonexistent}"
|
177
|
-
|
178
|
-
e = assert_raises Mechanize::ResponseCodeError do
|
179
|
-
@agent.fetch uri
|
180
|
-
end
|
181
|
-
|
182
|
-
assert_match "404 => Net::HTTPNotFound for #{uri}", e.message
|
183
|
-
end
|
184
|
-
end
|
185
|
-
|
186
|
-
def test_fetch_file_plus
|
187
|
-
Tempfile.open '++plus++' do |io|
|
188
|
-
content = 'plusses +++'
|
189
|
-
io.write content
|
190
|
-
io.rewind
|
191
|
-
|
192
|
-
uri = URI.parse "file://#{Mechanize::Util.uri_escape io.path}"
|
193
|
-
|
194
|
-
page = @agent.fetch uri
|
195
|
-
|
196
|
-
assert_equal content, page.body
|
197
|
-
assert_kind_of Mechanize::File, page
|
198
|
-
end
|
199
|
-
end
|
200
|
-
|
201
|
-
def test_fetch_file_space
|
202
|
-
foo = File.expand_path("../htdocs/dir with spaces/foo.html", __FILE__)
|
203
|
-
|
204
|
-
uri = URI.parse "file://#{Mechanize::Util.uri_escape foo}"
|
205
|
-
|
206
|
-
page = @agent.fetch uri
|
207
|
-
|
208
|
-
assert_equal File.read(foo), page.body
|
209
|
-
assert_kind_of Mechanize::Page, page
|
210
|
-
end
|
211
|
-
|
212
|
-
def test_fetch_head_gzip
|
213
|
-
uri = @uri + '/gzip?file=index.html'
|
214
|
-
|
215
|
-
page = @agent.fetch uri, :head
|
216
|
-
|
217
|
-
assert_kind_of Mechanize::Page, page
|
218
|
-
end
|
219
|
-
|
220
|
-
def test_fetch_hooks
|
221
|
-
@agent.pre_connect_hooks << proc do |agent, request|
|
222
|
-
assert_equal '/index.html', request.path
|
223
|
-
assert_equal @agent, agent
|
224
|
-
end
|
225
|
-
|
226
|
-
@agent.post_connect_hooks << proc do |agent, uri, response, body|
|
227
|
-
assert_equal @agent, agent
|
228
|
-
assert_equal URI('http://example/index.html'), uri
|
229
|
-
assert_equal '200', response.code
|
230
|
-
assert_kind_of String, body
|
231
|
-
end
|
232
|
-
|
233
|
-
@agent.fetch URI 'http://example/index.html'
|
234
|
-
end
|
235
|
-
|
236
|
-
def test_fetch_ignore_bad_chunking
|
237
|
-
@agent.ignore_bad_chunking = true
|
238
|
-
|
239
|
-
file = @agent.fetch 'http://example/bad_chunking'
|
240
|
-
|
241
|
-
assert_equal '0123456789', file.content
|
242
|
-
end
|
243
|
-
|
244
|
-
def test_fetch_post_connect_hook
|
245
|
-
response = nil
|
246
|
-
@agent.post_connect_hooks << lambda { |_, _, res, _| response = res }
|
247
|
-
|
248
|
-
@agent.fetch 'http://localhost/'
|
249
|
-
|
250
|
-
assert response
|
251
|
-
end
|
252
|
-
|
253
|
-
def test_fetch_redirect_header
|
254
|
-
page = @agent.fetch('http://example/redirect', :get,
|
255
|
-
'X-Location' => '/http_headers',
|
256
|
-
'Range' => 'bytes=0-99999')
|
257
|
-
|
258
|
-
assert_match 'range|bytes=0-999', page.body
|
259
|
-
end
|
260
|
-
|
261
|
-
def test_fetch_server_error
|
262
|
-
e = assert_raises Mechanize::ResponseCodeError do
|
263
|
-
@mech.get 'http://localhost/response_code?code=500'
|
264
|
-
end
|
265
|
-
|
266
|
-
assert_equal '500', e.response_code
|
267
|
-
end
|
268
|
-
|
269
|
-
def test_fetch_allowed_error_codes
|
270
|
-
@agent.allowed_error_codes = ['500']
|
271
|
-
|
272
|
-
page = @mech.get 'http://localhost/response_code?code=500'
|
273
|
-
|
274
|
-
assert_equal '500', page.code
|
275
|
-
end
|
276
|
-
|
277
|
-
def test_fetch_allowed_error_codes_int
|
278
|
-
@agent.allowed_error_codes = [500]
|
279
|
-
|
280
|
-
page = @mech.get 'http://localhost/response_code?code=500'
|
281
|
-
|
282
|
-
assert_equal '500', page.code
|
283
|
-
end
|
284
|
-
|
285
|
-
def test_get_meta_refresh_header_follow_self
|
286
|
-
@agent.follow_meta_refresh = true
|
287
|
-
@agent.follow_meta_refresh_self = true
|
288
|
-
|
289
|
-
page = Mechanize::Page.new(@uri, nil, '', 200, @mech)
|
290
|
-
@res.instance_variable_set :@header, 'refresh' => ['0']
|
291
|
-
|
292
|
-
refresh = @agent.get_meta_refresh @res, @uri, page
|
293
|
-
|
294
|
-
assert_equal [0.0, URI('http://example/')], refresh
|
295
|
-
end
|
296
|
-
|
297
|
-
def test_get_meta_refresh_header_no_follow
|
298
|
-
page = Mechanize::Page.new(@uri, nil, '', 200, @mech)
|
299
|
-
@res.instance_variable_set :@header, 'refresh' => ['0']
|
300
|
-
|
301
|
-
refresh = @agent.get_meta_refresh @res, @uri, page
|
302
|
-
|
303
|
-
assert_nil refresh
|
304
|
-
end
|
305
|
-
|
306
|
-
def test_get_meta_refresh_header_no_follow_self
|
307
|
-
@agent.follow_meta_refresh = true
|
308
|
-
|
309
|
-
page = Mechanize::Page.new(@uri, nil, '', 200, @mech)
|
310
|
-
@res.instance_variable_set :@header, 'refresh' => ['0']
|
311
|
-
|
312
|
-
refresh = @agent.get_meta_refresh @res, @uri, page
|
313
|
-
|
314
|
-
assert_nil refresh
|
315
|
-
end
|
316
|
-
|
317
|
-
def test_get_meta_refresh_meta_follow_self
|
318
|
-
@agent.follow_meta_refresh = true
|
319
|
-
@agent.follow_meta_refresh_self = true
|
320
|
-
|
321
|
-
body = <<-BODY
|
322
|
-
<title></title>
|
323
|
-
<meta http-equiv="refresh" content="0">
|
324
|
-
BODY
|
325
|
-
|
326
|
-
page = Mechanize::Page.new(@uri, nil, body, 200, @mech)
|
327
|
-
|
328
|
-
refresh = @agent.get_meta_refresh @res, @uri, page
|
329
|
-
|
330
|
-
assert_equal [0, nil], refresh
|
331
|
-
end
|
332
|
-
|
333
|
-
def test_get_meta_refresh_meta_no_follow
|
334
|
-
body = <<-BODY
|
335
|
-
<title></title>
|
336
|
-
<meta http-equiv="refresh" content="0">
|
337
|
-
BODY
|
338
|
-
|
339
|
-
page = Mechanize::Page.new(@uri, nil, body, 200, @mech)
|
340
|
-
|
341
|
-
refresh = @agent.get_meta_refresh @res, @uri, page
|
342
|
-
|
343
|
-
assert_nil refresh
|
344
|
-
end
|
345
|
-
|
346
|
-
def test_get_meta_refresh_meta_no_follow_self
|
347
|
-
@agent.follow_meta_refresh = true
|
348
|
-
|
349
|
-
body = <<-BODY
|
350
|
-
<title></title>
|
351
|
-
<meta http-equiv="refresh" content="0">
|
352
|
-
BODY
|
353
|
-
|
354
|
-
page = Mechanize::Page.new(@uri, nil, body, 200, @mech)
|
355
|
-
|
356
|
-
refresh = @agent.get_meta_refresh @res, @uri, page
|
357
|
-
|
358
|
-
assert_nil refresh
|
359
|
-
end
|
360
|
-
|
361
|
-
def test_get_robots
|
362
|
-
robotstxt = @agent.get_robots 'http://localhost/robots.txt'
|
363
|
-
refute_equal '', robotstxt
|
364
|
-
|
365
|
-
robotstxt = @agent.get_robots 'http://localhost/response_code?code=404'
|
366
|
-
assert_equal '', robotstxt
|
367
|
-
end
|
368
|
-
|
369
|
-
def test_hook_content_encoding_response
|
370
|
-
@mech.content_encoding_hooks << lambda{|agent, uri, response, response_body_io|
|
371
|
-
response['content-encoding'] = 'gzip' if response['content-encoding'] == 'agzip'}
|
372
|
-
|
373
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[agzip]
|
374
|
-
body_io = StringIO.new 'part'
|
375
|
-
@agent.hook_content_encoding @res, @uri, body_io
|
376
|
-
|
377
|
-
assert_equal 'gzip', @res['content-encoding']
|
378
|
-
end
|
379
|
-
|
380
|
-
def test_http_request_file
|
381
|
-
uri = URI.parse 'file:///nonexistent'
|
382
|
-
request = @agent.http_request uri, :get
|
383
|
-
|
384
|
-
assert_kind_of Mechanize::FileRequest, request
|
385
|
-
assert_equal '/nonexistent', request.path
|
386
|
-
end
|
387
|
-
|
388
|
-
def test_http_request_get
|
389
|
-
request = @agent.http_request @uri, :get
|
390
|
-
|
391
|
-
assert_kind_of Net::HTTP::Get, request
|
392
|
-
assert_equal '/', request.path
|
393
|
-
end
|
394
|
-
|
395
|
-
def test_http_request_post
|
396
|
-
request = @agent.http_request @uri, :post
|
397
|
-
|
398
|
-
assert_kind_of Net::HTTP::Post, request
|
399
|
-
assert_equal '/', request.path
|
400
|
-
end
|
401
|
-
|
402
|
-
def test_idle_timeout_equals
|
403
|
-
@agent.idle_timeout = 1
|
404
|
-
|
405
|
-
assert_equal 1, @agent.http.idle_timeout
|
406
|
-
end
|
407
|
-
|
408
|
-
def test_inflate
|
409
|
-
body_io = StringIO.new "x\x9C+H,*\x01\x00\x04?\x01\xB8"
|
410
|
-
|
411
|
-
result = @agent.inflate body_io
|
412
|
-
|
413
|
-
assert_equal 'part', result.read
|
414
|
-
end
|
415
|
-
|
416
|
-
def test_post_connect
|
417
|
-
@agent.post_connect_hooks << proc { |agent, uri, response, body|
|
418
|
-
assert_equal @agent, agent
|
419
|
-
assert_equal @res, response
|
420
|
-
assert_equal 'body', body
|
421
|
-
throw :called
|
422
|
-
}
|
423
|
-
|
424
|
-
io = StringIO.new 'body'
|
425
|
-
|
426
|
-
assert_throws :called do
|
427
|
-
@agent.post_connect @uri, @res, io
|
428
|
-
end
|
429
|
-
|
430
|
-
assert_equal 0, io.pos
|
431
|
-
end
|
432
|
-
|
433
|
-
def test_pre_connect
|
434
|
-
@agent.pre_connect_hooks << proc { |agent, request|
|
435
|
-
assert_equal @agent, agent
|
436
|
-
assert_equal @req, request
|
437
|
-
throw :called
|
438
|
-
}
|
439
|
-
|
440
|
-
assert_throws :called do
|
441
|
-
@agent.pre_connect @req
|
442
|
-
end
|
443
|
-
end
|
444
|
-
|
445
|
-
def test_request_add_headers
|
446
|
-
@agent.request_add_headers @req, 'Content-Length' => 300
|
447
|
-
|
448
|
-
assert_equal '300', @req['content-length']
|
449
|
-
end
|
450
|
-
|
451
|
-
def test_request_add_headers_etag
|
452
|
-
@agent.request_add_headers @req, :etag => '300'
|
453
|
-
|
454
|
-
assert_equal '300', @req['etag']
|
455
|
-
end
|
456
|
-
|
457
|
-
def test_request_add_headers_if_modified_since
|
458
|
-
@agent.request_add_headers @req, :if_modified_since => 'some_date'
|
459
|
-
|
460
|
-
assert_equal 'some_date', @req['if-modified-since']
|
461
|
-
end
|
462
|
-
|
463
|
-
def test_request_add_headers_none
|
464
|
-
@agent.request_add_headers @req
|
465
|
-
|
466
|
-
assert_equal @headers, @req.to_hash.keys.sort
|
467
|
-
end
|
468
|
-
|
469
|
-
def test_request_add_headers_request_headers
|
470
|
-
@agent.request_headers['X-Foo'] = 'bar'
|
471
|
-
|
472
|
-
@agent.request_add_headers @req
|
473
|
-
|
474
|
-
assert_equal @headers + %w[x-foo], @req.to_hash.keys.sort
|
475
|
-
end
|
476
|
-
|
477
|
-
def test_request_add_headers_symbol
|
478
|
-
e = assert_raises ArgumentError do
|
479
|
-
@agent.request_add_headers @req, :content_length => 300
|
480
|
-
end
|
481
|
-
|
482
|
-
assert_equal 'unknown header symbol content_length', e.message
|
483
|
-
end
|
484
|
-
|
485
|
-
def test_request_auth_basic
|
486
|
-
@agent.add_auth @uri, 'user', 'password'
|
487
|
-
|
488
|
-
auth_realm @uri, 'Basic', :basic
|
489
|
-
|
490
|
-
@agent.request_auth @req, @uri
|
491
|
-
|
492
|
-
assert_match %r%^Basic %, @req['Authorization']
|
493
|
-
end
|
494
|
-
|
495
|
-
def test_request_auth_digest
|
496
|
-
@agent.add_auth @uri, 'user', 'password'
|
497
|
-
|
498
|
-
realm = auth_realm @uri, 'Digest', :digest
|
499
|
-
@agent.digest_challenges[realm] = 'Digest realm=r, qop="auth"'
|
500
|
-
|
501
|
-
@agent.request_auth @req, @uri
|
502
|
-
|
503
|
-
assert_match %r%^Digest %, @req['Authorization']
|
504
|
-
assert_match %r%qop=auth%, @req['Authorization']
|
505
|
-
|
506
|
-
@req['Authorization'] = nil
|
507
|
-
@agent.request_auth @req, @uri
|
508
|
-
|
509
|
-
assert_match %r%^Digest %, @req['Authorization']
|
510
|
-
assert_match %r%qop=auth%, @req['Authorization']
|
511
|
-
end
|
512
|
-
|
513
|
-
def test_request_auth_iis_digest
|
514
|
-
@agent.add_auth @uri, 'user', 'password'
|
515
|
-
|
516
|
-
realm = auth_realm @uri, 'Digest', :digest
|
517
|
-
@agent.digest_challenges[realm] = 'Digest realm=r, qop="auth"'
|
518
|
-
|
519
|
-
@agent.request_auth @req, @uri
|
520
|
-
|
521
|
-
assert_match %r%^Digest %, @req['Authorization']
|
522
|
-
assert_match %r%qop=auth%, @req['Authorization']
|
523
|
-
end
|
524
|
-
|
525
|
-
def test_request_auth_none
|
526
|
-
@agent.request_auth @req, @uri
|
527
|
-
|
528
|
-
assert_nil @req['Authorization']
|
529
|
-
end
|
530
|
-
|
531
|
-
def test_request_cookies
|
532
|
-
uri = URI.parse 'http://host.example.com'
|
533
|
-
@agent.cookie_jar.parse 'hello=world domain=.example.com', uri
|
534
|
-
|
535
|
-
@agent.request_cookies @req, uri
|
536
|
-
|
537
|
-
assert_equal 'hello="world domain=.example.com"', @req['Cookie']
|
538
|
-
end
|
539
|
-
|
540
|
-
def test_request_cookies_many
|
541
|
-
uri = URI.parse 'http://host.example.com'
|
542
|
-
cookie_str = 'a=b domain=.example.com, c=d domain=.example.com'
|
543
|
-
@agent.cookie_jar.parse cookie_str, uri
|
544
|
-
|
545
|
-
@agent.request_cookies @req, uri
|
546
|
-
|
547
|
-
expected_variant1 = /a="b domain=\.example\.com"; c="d domain=\.example\.com"/
|
548
|
-
expected_variant2 = /c="d domain=\.example\.com"; a="b domain=\.example\.com"/
|
549
|
-
|
550
|
-
assert_match(/^(#{expected_variant1}|#{expected_variant2})$/, @req['Cookie'])
|
551
|
-
end
|
552
|
-
|
553
|
-
def test_request_cookies_none
|
554
|
-
@agent.request_cookies @req, @uri
|
555
|
-
|
556
|
-
assert_nil @req['Cookie']
|
557
|
-
end
|
558
|
-
|
559
|
-
def test_request_cookies_wrong_domain
|
560
|
-
uri = URI.parse 'http://host.example.com'
|
561
|
-
@agent.cookie_jar.parse 'hello=world domain=.example.com', uri
|
562
|
-
|
563
|
-
@agent.request_cookies @req, @uri
|
564
|
-
|
565
|
-
assert_nil @req['Cookie']
|
566
|
-
end
|
567
|
-
|
568
|
-
def test_request_host
|
569
|
-
@agent.request_host @req, @uri
|
570
|
-
|
571
|
-
assert_equal 'example', @req['host']
|
572
|
-
end
|
573
|
-
|
574
|
-
def test_request_host_nonstandard
|
575
|
-
@uri.port = 81
|
576
|
-
|
577
|
-
@agent.request_host @req, @uri
|
578
|
-
|
579
|
-
assert_equal 'example:81', @req['host']
|
580
|
-
end
|
581
|
-
|
582
|
-
def test_request_language_charset
|
583
|
-
@agent.request_language_charset @req
|
584
|
-
|
585
|
-
assert_equal 'en-us,en;q=0.5', @req['accept-language']
|
586
|
-
assert_equal 'ISO-8859-1,utf-8;q=0.7,*;q=0.7', @req['accept-charset']
|
587
|
-
end
|
588
|
-
|
589
|
-
def test_request_referer
|
590
|
-
referer = URI.parse 'http://old.example'
|
591
|
-
|
592
|
-
@agent.request_referer @req, @uri, referer
|
593
|
-
|
594
|
-
assert_equal 'http://old.example', @req['referer']
|
595
|
-
end
|
596
|
-
|
597
|
-
def test_request_referer_https
|
598
|
-
uri = URI.parse 'https://example'
|
599
|
-
referer = URI.parse 'https://old.example'
|
600
|
-
|
601
|
-
@agent.request_referer @req, uri, referer
|
602
|
-
|
603
|
-
assert_equal 'https://old.example', @req['referer']
|
604
|
-
end
|
605
|
-
|
606
|
-
def test_request_referer_https_downgrade
|
607
|
-
referer = URI.parse 'https://old.example'
|
608
|
-
|
609
|
-
@agent.request_referer @req, @uri, referer
|
610
|
-
|
611
|
-
assert_nil @req['referer']
|
612
|
-
end
|
613
|
-
|
614
|
-
def test_request_referer_https_downgrade_case
|
615
|
-
uri = URI.parse 'http://example'
|
616
|
-
referer = URI.parse 'httpS://old.example'
|
617
|
-
|
618
|
-
@agent.request_referer @req, uri, referer
|
619
|
-
|
620
|
-
assert_nil @req['referer']
|
621
|
-
end
|
622
|
-
|
623
|
-
def test_request_referer_https_upgrade
|
624
|
-
uri = URI.parse 'https://example'
|
625
|
-
referer = URI.parse 'http://old.example'
|
626
|
-
|
627
|
-
@agent.request_referer @req, uri, referer
|
628
|
-
|
629
|
-
assert_equal 'http://old.example', @req['referer']
|
630
|
-
end
|
631
|
-
|
632
|
-
def test_request_referer_none
|
633
|
-
@agent.request_referer @req, @uri, nil
|
634
|
-
|
635
|
-
assert_nil @req['referer']
|
636
|
-
end
|
637
|
-
|
638
|
-
def test_request_referer_strip
|
639
|
-
uri = URI.parse 'http://example.com/index.html'
|
640
|
-
|
641
|
-
host_path = "old.example/page.html?q=x"
|
642
|
-
referer = "http://#{host_path}"
|
643
|
-
|
644
|
-
[
|
645
|
-
"",
|
646
|
-
"@",
|
647
|
-
"user1@",
|
648
|
-
":@",
|
649
|
-
"user1:@",
|
650
|
-
":password1@",
|
651
|
-
"user1:password1@",
|
652
|
-
].each { |userinfo|
|
653
|
-
['', '#frag'].each { |frag|
|
654
|
-
url = URI.parse "http://#{userinfo}#{host_path}#{frag}"
|
655
|
-
|
656
|
-
@agent.request_referer @req, uri, url
|
657
|
-
|
658
|
-
assert_equal referer, @req['referer'], url
|
659
|
-
}
|
660
|
-
}
|
661
|
-
end
|
662
|
-
|
663
|
-
def test_request_user_agent
|
664
|
-
@agent.request_user_agent @req
|
665
|
-
|
666
|
-
assert_match %r%^Mechanize/#{Mechanize::VERSION}%, @req['user-agent']
|
667
|
-
|
668
|
-
ruby_version = if RUBY_PATCHLEVEL >= 0 then
|
669
|
-
"#{RUBY_VERSION}p#{RUBY_PATCHLEVEL}"
|
670
|
-
else
|
671
|
-
"#{RUBY_VERSION}dev#{RUBY_REVISION}"
|
672
|
-
end
|
673
|
-
|
674
|
-
assert_match %r%Ruby/#{ruby_version}%, @req['user-agent']
|
675
|
-
end
|
676
|
-
|
677
|
-
def test_resolve_bad_uri
|
678
|
-
e = assert_raises ArgumentError do
|
679
|
-
@agent.resolve 'google'
|
680
|
-
end
|
681
|
-
|
682
|
-
assert_equal 'absolute URL needed (not google)', e.message
|
683
|
-
end
|
684
|
-
|
685
|
-
def test_resolve_uri_without_path
|
686
|
-
e = assert_raises ArgumentError do
|
687
|
-
@agent.resolve 'http:%5C%5Cfoo'
|
688
|
-
end
|
689
|
-
|
690
|
-
assert_equal 'hierarchical URL needed (not http:%5C%5Cfoo)', e.message
|
691
|
-
end
|
692
|
-
|
693
|
-
def test_resolve_utf8
|
694
|
-
uri = 'http://example?q=ü'
|
695
|
-
|
696
|
-
resolved = @agent.resolve uri
|
697
|
-
|
698
|
-
assert_equal '/?q=%C3%BC', resolved.request_uri
|
699
|
-
end
|
700
|
-
|
701
|
-
def test_resolve_parameters_body
|
702
|
-
input_params = { :q => 'hello' }
|
703
|
-
|
704
|
-
uri, params = @agent.resolve_parameters @uri, :post, input_params
|
705
|
-
|
706
|
-
assert_equal 'http://example/', uri.to_s
|
707
|
-
assert_equal input_params, params
|
708
|
-
end
|
709
|
-
|
710
|
-
def test_resolve_parameters_query
|
711
|
-
uri, params = @agent.resolve_parameters @uri, :get, :q => 'hello'
|
712
|
-
|
713
|
-
assert_equal 'http://example/?q=hello', uri.to_s
|
714
|
-
assert_nil params
|
715
|
-
end
|
716
|
-
|
717
|
-
def test_resolve_parameters_query_append
|
718
|
-
input_params = { :q => 'hello' }
|
719
|
-
@uri.query = 'a=b'
|
720
|
-
|
721
|
-
uri, params = @agent.resolve_parameters @uri, :get, input_params
|
722
|
-
|
723
|
-
assert_equal 'http://example/?a=b&q=hello', uri.to_s
|
724
|
-
assert_nil params
|
725
|
-
end
|
726
|
-
|
727
|
-
def test_resolve_slashes
|
728
|
-
page = Mechanize::Page.new URI('http://example/foo/'), nil, '', 200, @mech
|
729
|
-
uri = '/bar/http://example/test/'
|
730
|
-
|
731
|
-
resolved = @agent.resolve uri, page
|
732
|
-
|
733
|
-
assert_equal 'http://example/bar/http://example/test/', resolved.to_s
|
734
|
-
end
|
735
|
-
|
736
|
-
def test_response_authenticate
|
737
|
-
@agent.add_auth @uri, 'user', 'password'
|
738
|
-
|
739
|
-
@res.instance_variable_set :@header, 'www-authenticate' => ['Basic realm=r']
|
740
|
-
|
741
|
-
@agent.response_authenticate @res, nil, @uri, @req, {}, nil, nil
|
742
|
-
|
743
|
-
base_uri = @uri + '/'
|
744
|
-
realm = Mechanize::HTTP::AuthRealm.new 'Basic', base_uri, 'r'
|
745
|
-
assert_equal [realm], @agent.authenticate_methods[base_uri][:basic]
|
746
|
-
end
|
747
|
-
|
748
|
-
def test_response_authenticate_digest
|
749
|
-
@agent.add_auth @uri, 'user', 'password'
|
750
|
-
|
751
|
-
@res.instance_variable_set(:@header,
|
752
|
-
'www-authenticate' => ['Digest realm=r'])
|
753
|
-
|
754
|
-
@agent.response_authenticate @res, nil, @uri, @req, {}, nil, nil
|
755
|
-
|
756
|
-
base_uri = @uri + '/'
|
757
|
-
realm = Mechanize::HTTP::AuthRealm.new 'Digest', base_uri, 'r'
|
758
|
-
assert_equal [realm], @agent.authenticate_methods[base_uri][:digest]
|
759
|
-
|
760
|
-
challenge = Mechanize::HTTP::AuthChallenge.new('Digest',
|
761
|
-
{ 'realm' => 'r' },
|
762
|
-
'Digest realm=r')
|
763
|
-
|
764
|
-
assert_equal challenge, @agent.digest_challenges[realm]
|
765
|
-
end
|
766
|
-
|
767
|
-
def test_response_authenticate_digest_iis
|
768
|
-
@agent.add_auth @uri, 'user', 'password'
|
769
|
-
|
770
|
-
@res.instance_variable_set(:@header,
|
771
|
-
'www-authenticate' => ['Digest realm=r'],
|
772
|
-
'server' => ['Microsoft-IIS'])
|
773
|
-
@agent.response_authenticate @res, nil, @uri, @req, {}, nil, nil
|
774
|
-
|
775
|
-
base_uri = @uri + '/'
|
776
|
-
realm = Mechanize::HTTP::AuthRealm.new 'Digest', base_uri, 'r'
|
777
|
-
assert_equal [realm], @agent.authenticate_methods[base_uri][:iis_digest]
|
778
|
-
end
|
779
|
-
|
780
|
-
def test_response_authenticate_multiple
|
781
|
-
@agent.add_auth @uri, 'user', 'password'
|
782
|
-
|
783
|
-
@res.instance_variable_set(:@header,
|
784
|
-
'www-authenticate' =>
|
785
|
-
['Basic realm=r, Digest realm=r'])
|
786
|
-
|
787
|
-
@agent.response_authenticate @res, nil, @uri, @req, {}, nil, nil
|
788
|
-
|
789
|
-
base_uri = @uri + '/'
|
790
|
-
realm = Mechanize::HTTP::AuthRealm.new 'Digest', base_uri, 'r'
|
791
|
-
assert_equal [realm], @agent.authenticate_methods[base_uri][:digest]
|
792
|
-
|
793
|
-
assert_empty @agent.authenticate_methods[base_uri][:basic]
|
794
|
-
end
|
795
|
-
|
796
|
-
def test_response_authenticate_no_credentials
|
797
|
-
@res.instance_variable_set :@header, 'www-authenticate' => ['Basic realm=r']
|
798
|
-
|
799
|
-
e = assert_raises Mechanize::UnauthorizedError do
|
800
|
-
@agent.response_authenticate @res, fake_page, @uri, @req, {}, nil, nil
|
801
|
-
end
|
802
|
-
|
803
|
-
assert_match 'no credentials', e.message
|
804
|
-
assert_match 'available realms: r', e.message
|
805
|
-
end
|
806
|
-
|
807
|
-
def test_response_authenticate_no_www_authenticate
|
808
|
-
@agent.add_auth @uri, 'user', 'password'
|
809
|
-
|
810
|
-
denied_uri = URI('http://example/denied')
|
811
|
-
|
812
|
-
denied = page denied_uri, 'text/html', '', 401
|
813
|
-
|
814
|
-
e = assert_raises Mechanize::UnauthorizedError do
|
815
|
-
@agent.response_authenticate @res, denied, @uri, @req, {}, nil, nil
|
816
|
-
end
|
817
|
-
|
818
|
-
assert_equal "401 => Net::HTTPUnauthorized for #{denied_uri} -- " \
|
819
|
-
"WWW-Authenticate header missing in response",
|
820
|
-
e.message
|
821
|
-
end
|
822
|
-
|
823
|
-
def test_response_authenticate_ntlm
|
824
|
-
@uri += '/ntlm'
|
825
|
-
@agent.add_auth @uri, 'user', 'password'
|
826
|
-
|
827
|
-
@res.instance_variable_set(:@header,
|
828
|
-
'www-authenticate' => ['Negotiate, NTLM'])
|
829
|
-
|
830
|
-
page = @agent.response_authenticate @res, nil, @uri, @req, {}, nil, nil
|
831
|
-
|
832
|
-
assert_equal 'ok', page.body # lame test
|
833
|
-
end
|
834
|
-
|
835
|
-
def test_response_authenticate_unknown
|
836
|
-
@agent.add_auth @uri, 'user', 'password'
|
837
|
-
|
838
|
-
page = Mechanize::File.new nil, nil, nil, 401
|
839
|
-
@res.instance_variable_set(:@header,
|
840
|
-
'www-authenticate' => ['Unknown realm=r'])
|
841
|
-
|
842
|
-
assert_raises Mechanize::UnauthorizedError do
|
843
|
-
@agent.response_authenticate @res, page, @uri, @req, nil, nil, nil
|
844
|
-
end
|
845
|
-
end
|
846
|
-
|
847
|
-
def test_response_content_encoding_7_bit
|
848
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[7bit]
|
849
|
-
|
850
|
-
body = @agent.response_content_encoding @res, StringIO.new('part')
|
851
|
-
|
852
|
-
assert_equal 'part', body.read
|
853
|
-
end
|
854
|
-
|
855
|
-
def test_response_content_encoding_deflate
|
856
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[deflate]
|
857
|
-
body_io = StringIO.new "x\x9C+H,*\x01\x00\x04?\x01\xB8"
|
858
|
-
|
859
|
-
body = @agent.response_content_encoding @res, body_io
|
860
|
-
|
861
|
-
assert_equal 'part', body.read
|
862
|
-
|
863
|
-
assert body_io.closed?
|
864
|
-
end
|
865
|
-
|
866
|
-
def test_response_content_encoding_deflate_chunked
|
867
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[deflate]
|
868
|
-
body_io = StringIO.new "x\x9C+H,*\x01\x00\x04?\x01\xB8"
|
869
|
-
|
870
|
-
body = @agent.response_content_encoding @res, body_io
|
871
|
-
|
872
|
-
assert_equal 'part', body.read
|
873
|
-
end
|
874
|
-
|
875
|
-
def test_response_content_encoding_deflate_corrupt
|
876
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[deflate]
|
877
|
-
body_io = StringIO.new "x\x9C+H,*\x01\x00\x04?\x01" # missing 1 byte
|
878
|
-
|
879
|
-
e = assert_raises Mechanize::Error do
|
880
|
-
@agent.response_content_encoding @res, body_io
|
881
|
-
end
|
882
|
-
|
883
|
-
assert_match %r%error handling content-encoding deflate:%, e.message
|
884
|
-
assert_match %r%Zlib%, e.message
|
885
|
-
|
886
|
-
assert body_io.closed?
|
887
|
-
end
|
888
|
-
|
889
|
-
def test_response_content_encoding_deflate_empty
|
890
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[deflate]
|
891
|
-
|
892
|
-
body = @agent.response_content_encoding @res, StringIO.new
|
893
|
-
|
894
|
-
assert_equal '', body.read
|
895
|
-
end
|
896
|
-
|
897
|
-
# IIS/6.0 ASP.NET/2.0.50727 does not wrap deflate with zlib, WTF?
|
898
|
-
def test_response_content_encoding_deflate_no_zlib
|
899
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[deflate]
|
900
|
-
|
901
|
-
body = @agent.response_content_encoding @res, StringIO.new("+H,*\001\000")
|
902
|
-
|
903
|
-
assert_equal 'part', body.read
|
904
|
-
end
|
905
|
-
|
906
|
-
def test_response_content_encoding_gzip
|
907
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[gzip]
|
908
|
-
body_io = StringIO.new \
|
909
|
-
"\037\213\b\0002\002\225M\000\003+H,*\001\000\306p\017I\004\000\000\000"
|
910
|
-
|
911
|
-
body = @agent.response_content_encoding @res, body_io
|
912
|
-
|
913
|
-
assert_equal 'part', body.read
|
914
|
-
|
915
|
-
assert body_io.closed?
|
916
|
-
end
|
917
|
-
|
918
|
-
def test_response_content_encoding_gzip_chunked
|
919
|
-
def @res.content_length() nil end
|
920
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[gzip]
|
921
|
-
body_io = StringIO.new \
|
922
|
-
"\037\213\b\0002\002\225M\000\003+H,*\001\000\306p\017I\004\000\000\000"
|
923
|
-
|
924
|
-
body = @agent.response_content_encoding @res, body_io
|
925
|
-
|
926
|
-
assert_equal 'part', body.read
|
927
|
-
end
|
928
|
-
|
929
|
-
def test_response_content_encoding_gzip_corrupt
|
930
|
-
log = StringIO.new
|
931
|
-
logger = Logger.new log
|
932
|
-
@agent.context.log = logger
|
933
|
-
|
934
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[gzip]
|
935
|
-
body_io = StringIO.new \
|
936
|
-
"\037\213\b\0002\002\225M\000\003+H,*\001"
|
937
|
-
|
938
|
-
return if jruby_zlib?
|
939
|
-
|
940
|
-
e = assert_raises Mechanize::Error do
|
941
|
-
@agent.response_content_encoding @res, body_io
|
942
|
-
end
|
943
|
-
|
944
|
-
assert_match %r%error handling content-encoding gzip:%, e.message
|
945
|
-
assert_match %r%Zlib%, e.message
|
946
|
-
|
947
|
-
assert_match %r%unable to gunzip response: unexpected end of file%,
|
948
|
-
log.string
|
949
|
-
assert_match %r%unable to inflate response: buffer error%,
|
950
|
-
log.string
|
951
|
-
|
952
|
-
assert body_io.closed?
|
953
|
-
end
|
954
|
-
|
955
|
-
def test_response_content_encoding_gzip_checksum_corrupt_crc
|
956
|
-
log = StringIO.new
|
957
|
-
logger = Logger.new log
|
958
|
-
@agent.context.log = logger
|
959
|
-
|
960
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[gzip]
|
961
|
-
body_io = StringIO.new \
|
962
|
-
"\037\213\b\0002\002\225M\000\003+H,*\001\000\306p\017J\004\000\000\000"
|
963
|
-
|
964
|
-
body = @agent.response_content_encoding @res, body_io
|
965
|
-
|
966
|
-
assert_equal 'part', body.read
|
967
|
-
|
968
|
-
assert body_io.closed?
|
969
|
-
|
970
|
-
assert_match %r%invalid compressed data -- crc error%, log.string
|
971
|
-
rescue IOError
|
972
|
-
raise unless jruby_zlib?
|
973
|
-
end
|
974
|
-
|
975
|
-
def test_response_content_encoding_gzip_checksum_corrupt_length
|
976
|
-
log = StringIO.new
|
977
|
-
logger = Logger.new log
|
978
|
-
@agent.context.log = logger
|
979
|
-
|
980
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[gzip]
|
981
|
-
body_io = StringIO.new \
|
982
|
-
"\037\213\b\0002\002\225M\000\003+H,*\001\000\306p\017I\005\000\000\000"
|
983
|
-
|
984
|
-
@agent.response_content_encoding @res, body_io
|
985
|
-
|
986
|
-
assert body_io.closed?
|
987
|
-
|
988
|
-
assert_match %r%invalid compressed data -- length error%, log.string
|
989
|
-
rescue IOError
|
990
|
-
raise unless jruby_zlib?
|
991
|
-
end
|
992
|
-
|
993
|
-
def test_response_content_encoding_gzip_checksum_truncated
|
994
|
-
log = StringIO.new
|
995
|
-
logger = Logger.new log
|
996
|
-
@agent.context.log = logger
|
997
|
-
|
998
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[gzip]
|
999
|
-
body_io = StringIO.new \
|
1000
|
-
"\037\213\b\0002\002\225M\000\003+H,*\001\000\306p\017I\004\000\000"
|
1001
|
-
|
1002
|
-
@agent.response_content_encoding @res, body_io
|
1003
|
-
|
1004
|
-
assert body_io.closed?
|
1005
|
-
|
1006
|
-
assert_match %r%unable to gunzip response: footer is not found%, log.string
|
1007
|
-
rescue IOError
|
1008
|
-
raise unless jruby_zlib?
|
1009
|
-
end
|
1010
|
-
|
1011
|
-
def test_response_content_encoding_gzip_empty
|
1012
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[gzip]
|
1013
|
-
|
1014
|
-
body = @agent.response_content_encoding @res, StringIO.new
|
1015
|
-
|
1016
|
-
assert_equal '', body.read
|
1017
|
-
end
|
1018
|
-
|
1019
|
-
def test_response_content_encoding_gzip_encoding_bad
|
1020
|
-
@res.instance_variable_set(:@header,
|
1021
|
-
'content-encoding' => %w[gzip],
|
1022
|
-
'content-type' => 'text/html; charset=UTF-8')
|
1023
|
-
|
1024
|
-
# "test\xB2"
|
1025
|
-
body_io = StringIO.new \
|
1026
|
-
"\037\213\b\000*+\314N\000\003+I-.\331\004\000x\016\003\376\005\000\000\000"
|
1027
|
-
|
1028
|
-
body = @agent.response_content_encoding @res, body_io
|
1029
|
-
|
1030
|
-
expected = "test\xB2"
|
1031
|
-
expected.force_encoding Encoding::BINARY if have_encoding?
|
1032
|
-
|
1033
|
-
content = body.read
|
1034
|
-
assert_equal expected, content
|
1035
|
-
assert_equal Encoding::BINARY, content.encoding if have_encoding?
|
1036
|
-
end
|
1037
|
-
|
1038
|
-
def test_response_content_encoding_gzip_no_footer
|
1039
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[gzip]
|
1040
|
-
body_io = StringIO.new \
|
1041
|
-
"\037\213\b\0002\002\225M\000\003+H,*\001\000"
|
1042
|
-
|
1043
|
-
body = @agent.response_content_encoding @res, body_io
|
1044
|
-
|
1045
|
-
assert_equal 'part', body.read
|
1046
|
-
|
1047
|
-
assert body_io.closed?
|
1048
|
-
rescue IOError
|
1049
|
-
raise unless jruby_zlib?
|
1050
|
-
end
|
1051
|
-
|
1052
|
-
def test_response_content_encoding_none
|
1053
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[none]
|
1054
|
-
|
1055
|
-
body = @agent.response_content_encoding @res, StringIO.new('part')
|
1056
|
-
|
1057
|
-
assert_equal 'part', body.read
|
1058
|
-
end
|
1059
|
-
|
1060
|
-
def test_response_content_encoding_empty_string
|
1061
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[]
|
1062
|
-
|
1063
|
-
body = @agent.response_content_encoding @res, StringIO.new('part')
|
1064
|
-
|
1065
|
-
assert_equal 'part', body.read
|
1066
|
-
end
|
1067
|
-
|
1068
|
-
def test_response_content_encoding_identity
|
1069
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[identity]
|
1070
|
-
|
1071
|
-
body = @agent.response_content_encoding @res, StringIO.new('part')
|
1072
|
-
|
1073
|
-
assert_equal 'part', body.read
|
1074
|
-
end
|
1075
|
-
|
1076
|
-
def test_response_content_encoding_tempfile_7_bit
|
1077
|
-
body_io = tempfile 'part'
|
1078
|
-
|
1079
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[7bit]
|
1080
|
-
|
1081
|
-
body = @agent.response_content_encoding @res, body_io
|
1082
|
-
|
1083
|
-
assert_equal 'part', body.read
|
1084
|
-
refute body_io.closed?
|
1085
|
-
ensure
|
1086
|
-
begin
|
1087
|
-
body_io.close! if body_io and not body_io.closed?
|
1088
|
-
rescue IOError
|
1089
|
-
# HACK for ruby 1.8
|
1090
|
-
end
|
1091
|
-
end
|
1092
|
-
|
1093
|
-
def test_response_content_encoding_tempfile_gzip
|
1094
|
-
body_io = tempfile "x\x9C+H,*\x01\x00\x04?\x01\xB8"
|
1095
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[deflate]
|
1096
|
-
|
1097
|
-
body = @agent.response_content_encoding @res, body_io
|
1098
|
-
|
1099
|
-
assert_equal 'part', body.read
|
1100
|
-
assert body_io.closed?
|
1101
|
-
ensure
|
1102
|
-
body_io.close! if body_io and not body_io.closed?
|
1103
|
-
end
|
1104
|
-
|
1105
|
-
def test_response_content_encoding_unknown
|
1106
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[unknown]
|
1107
|
-
body = StringIO.new 'part'
|
1108
|
-
|
1109
|
-
e = assert_raises Mechanize::Error do
|
1110
|
-
@agent.response_content_encoding @res, body
|
1111
|
-
end
|
1112
|
-
|
1113
|
-
assert_equal 'unsupported content-encoding: unknown', e.message
|
1114
|
-
end
|
1115
|
-
|
1116
|
-
def test_response_content_encoding_x_gzip
|
1117
|
-
@res.instance_variable_set :@header, 'content-encoding' => %w[x-gzip]
|
1118
|
-
body_io = StringIO.new \
|
1119
|
-
"\037\213\b\0002\002\225M\000\003+H,*\001\000\306p\017I\004\000\000\000"
|
1120
|
-
|
1121
|
-
body = @agent.response_content_encoding @res, body_io
|
1122
|
-
|
1123
|
-
assert_equal 'part', body.read
|
1124
|
-
end
|
1125
|
-
|
1126
|
-
def test_response_cookies
|
1127
|
-
uri = URI.parse 'http://host.example.com'
|
1128
|
-
cookie_str = 'a=b domain=.example.com'
|
1129
|
-
@res.instance_variable_set(:@header,
|
1130
|
-
'set-cookie' => [cookie_str],
|
1131
|
-
'content-type' => %w[text/html])
|
1132
|
-
page = Mechanize::Page.new uri, @res, '', 200, @mech
|
1133
|
-
|
1134
|
-
@agent.response_cookies @res, uri, page
|
1135
|
-
|
1136
|
-
assert_equal ['a="b domain=.example.com"'],
|
1137
|
-
@agent.cookie_jar.cookies(uri).map { |c| c.to_s }
|
1138
|
-
end
|
1139
|
-
|
1140
|
-
def test_response_cookies_many
|
1141
|
-
uri = URI.parse 'http://host.example.com'
|
1142
|
-
cookie1 = 'a=b domain=.example.com'
|
1143
|
-
cookie2 = 'c=d domain=.example.com'
|
1144
|
-
cookies = [cookie1, cookie2]
|
1145
|
-
@res.instance_variable_set(:@header,
|
1146
|
-
'set-cookie' => cookies,
|
1147
|
-
'content-type' => %w[text/html])
|
1148
|
-
page = Mechanize::Page.new uri, @res, '', 200, @mech
|
1149
|
-
|
1150
|
-
@agent.response_cookies @res, uri, page
|
1151
|
-
|
1152
|
-
cookies_from_jar = @agent.cookie_jar.cookies(uri)
|
1153
|
-
|
1154
|
-
assert_equal 2, cookies_from_jar.length
|
1155
|
-
assert_equal [
|
1156
|
-
'a="b domain=.example.com"',
|
1157
|
-
'c="d domain=.example.com"',
|
1158
|
-
], cookies_from_jar.sort_by { |c| c.name }.map(&:to_s)
|
1159
|
-
end
|
1160
|
-
|
1161
|
-
def test_response_cookies_meta
|
1162
|
-
uri = URI.parse 'http://host.example.com'
|
1163
|
-
cookie_str = 'a=b domain=.example.com'
|
1164
|
-
|
1165
|
-
body = <<-BODY
|
1166
|
-
<head>
|
1167
|
-
<meta http-equiv="Set-Cookie" content="#{cookie_str}">
|
1168
|
-
</head>"
|
1169
|
-
BODY
|
1170
|
-
|
1171
|
-
@res.instance_variable_set(:@header,
|
1172
|
-
'content-type' => %w[text/html])
|
1173
|
-
page = Mechanize::Page.new uri, @res, body, 200, @mech
|
1174
|
-
|
1175
|
-
@agent.response_cookies @res, uri, page
|
1176
|
-
|
1177
|
-
assert_equal ['a="b domain=.example.com"'],
|
1178
|
-
@agent.cookie_jar.cookies(uri).map { |c| c.to_s }
|
1179
|
-
end
|
1180
|
-
|
1181
|
-
def test_response_cookies_meta_bogus
|
1182
|
-
uri = URI.parse 'http://host.example.com'
|
1183
|
-
|
1184
|
-
body = <<-BODY
|
1185
|
-
<head>
|
1186
|
-
<meta http-equiv="Set-Cookie">
|
1187
|
-
</head>"
|
1188
|
-
BODY
|
1189
|
-
|
1190
|
-
@res.instance_variable_set(:@header,
|
1191
|
-
'content-type' => %w[text/html])
|
1192
|
-
page = Mechanize::Page.new uri, @res, body, 200, @mech
|
1193
|
-
|
1194
|
-
@agent.response_cookies @res, uri, page
|
1195
|
-
|
1196
|
-
assert_empty @agent.cookie_jar.cookies(uri)
|
1197
|
-
end
|
1198
|
-
|
1199
|
-
def test_response_follow_meta_refresh
|
1200
|
-
uri = URI.parse 'http://example/#id+1'
|
1201
|
-
|
1202
|
-
body = <<-BODY
|
1203
|
-
<title></title>
|
1204
|
-
<meta http-equiv="refresh" content="0">
|
1205
|
-
BODY
|
1206
|
-
|
1207
|
-
page = Mechanize::Page.new(uri, nil, body, 200, @mech)
|
1208
|
-
|
1209
|
-
@agent.follow_meta_refresh = true
|
1210
|
-
@agent.follow_meta_refresh_self = true
|
1211
|
-
|
1212
|
-
page = @agent.response_follow_meta_refresh @res, uri, page, 0
|
1213
|
-
|
1214
|
-
assert_equal uri, page.uri
|
1215
|
-
end
|
1216
|
-
|
1217
|
-
def test_response_follow_meta_refresh_limit
|
1218
|
-
uri = URI.parse 'http://example/#id+1'
|
1219
|
-
|
1220
|
-
body = <<-BODY
|
1221
|
-
<title></title>
|
1222
|
-
<meta http-equiv="refresh" content="0">
|
1223
|
-
BODY
|
1224
|
-
|
1225
|
-
page = Mechanize::Page.new(uri, nil, body, 200, @mech)
|
1226
|
-
|
1227
|
-
@agent.follow_meta_refresh = true
|
1228
|
-
@agent.follow_meta_refresh_self = true
|
1229
|
-
|
1230
|
-
assert_raises Mechanize::RedirectLimitReachedError do
|
1231
|
-
@agent.response_follow_meta_refresh(@res, uri, page,
|
1232
|
-
@agent.redirection_limit)
|
1233
|
-
end
|
1234
|
-
end
|
1235
|
-
|
1236
|
-
def test_response_meta_refresh_with_insecure_url
|
1237
|
-
uri = URI.parse 'http://example/#id+1'
|
1238
|
-
|
1239
|
-
body = <<-BODY
|
1240
|
-
<title></title>
|
1241
|
-
<meta http-equiv="refresh" content="0; url=file:///dev/zero">
|
1242
|
-
BODY
|
1243
|
-
|
1244
|
-
page = Mechanize::Page.new(uri, nil, body, 200, @mech)
|
1245
|
-
|
1246
|
-
@agent.follow_meta_refresh = true
|
1247
|
-
|
1248
|
-
assert_raises Mechanize::Error do
|
1249
|
-
@agent.response_follow_meta_refresh(@res, uri, page,
|
1250
|
-
@agent.redirection_limit)
|
1251
|
-
end
|
1252
|
-
end
|
1253
|
-
|
1254
|
-
def test_response_parse
|
1255
|
-
body = '<title>hi</title>'
|
1256
|
-
@res.instance_variable_set :@header, 'content-type' => %w[text/html]
|
1257
|
-
|
1258
|
-
page = @agent.response_parse @res, body, @uri
|
1259
|
-
|
1260
|
-
assert_instance_of Mechanize::Page, page
|
1261
|
-
assert_equal @mech, page.mech
|
1262
|
-
end
|
1263
|
-
|
1264
|
-
def test_response_parse_content_type_case
|
1265
|
-
body = '<title>hi</title>'
|
1266
|
-
@res.instance_variable_set(:@header, 'content-type' => %w[text/HTML])
|
1267
|
-
|
1268
|
-
page = @agent.response_parse @res, body, @uri
|
1269
|
-
|
1270
|
-
assert_instance_of Mechanize::Page, page
|
1271
|
-
|
1272
|
-
assert_equal 'text/HTML', page.content_type
|
1273
|
-
end
|
1274
|
-
|
1275
|
-
def test_response_parse_content_type_encoding
|
1276
|
-
body = '<title>hi</title>'
|
1277
|
-
@res.instance_variable_set(:@header,
|
1278
|
-
'content-type' =>
|
1279
|
-
%w[text/html;charset=ISO-8859-1])
|
1280
|
-
|
1281
|
-
page = @agent.response_parse @res, body, @uri
|
1282
|
-
|
1283
|
-
assert_instance_of Mechanize::Page, page
|
1284
|
-
assert_equal @mech, page.mech
|
1285
|
-
|
1286
|
-
assert_equal 'ISO-8859-1', page.encoding
|
1287
|
-
assert_equal 'ISO-8859-1', page.parser.encoding
|
1288
|
-
end
|
1289
|
-
|
1290
|
-
def test_response_parse_content_type_encoding_broken_iso_8859_1
|
1291
|
-
body = '<title>hi</title>'
|
1292
|
-
@res.instance_variable_set(:@header,
|
1293
|
-
'content-type' =>
|
1294
|
-
%w[text/html; charset=ISO_8859-1])
|
1295
|
-
|
1296
|
-
page = @agent.response_parse @res, body, @uri
|
1297
|
-
|
1298
|
-
assert_instance_of Mechanize::Page, page
|
1299
|
-
assert_equal 'ISO_8859-1', page.encoding
|
1300
|
-
end
|
1301
|
-
|
1302
|
-
def test_response_parse_content_type_encoding_broken_utf_8
|
1303
|
-
body = '<title>hi</title>'
|
1304
|
-
@res.instance_variable_set(:@header,
|
1305
|
-
'content-type' =>
|
1306
|
-
%w[text/html; charset=UTF8])
|
1307
|
-
|
1308
|
-
page = @agent.response_parse @res, body, @uri
|
1309
|
-
|
1310
|
-
assert_instance_of Mechanize::Page, page
|
1311
|
-
assert_equal 'UTF8', page.encoding
|
1312
|
-
assert_equal 'UTF8', page.parser.encoding
|
1313
|
-
end
|
1314
|
-
|
1315
|
-
def test_response_parse_content_type_encoding_garbage
|
1316
|
-
body = '<title>hi</title>'
|
1317
|
-
@res.instance_variable_set(:@header,
|
1318
|
-
'content-type' =>
|
1319
|
-
%w[text/html; charset=garbage_charset])
|
1320
|
-
|
1321
|
-
page = @agent.response_parse @res, body, @uri
|
1322
|
-
|
1323
|
-
assert_instance_of Mechanize::Page, page
|
1324
|
-
assert_equal @mech, page.mech
|
1325
|
-
end
|
1326
|
-
|
1327
|
-
def test_response_parse_content_type_encoding_semicolon
|
1328
|
-
body = '<title>hi</title>'
|
1329
|
-
@res.instance_variable_set(:@header,
|
1330
|
-
'content-type' =>
|
1331
|
-
%w[text/html;charset=UTF-8;])
|
1332
|
-
|
1333
|
-
page = @agent.response_parse @res, body, @uri
|
1334
|
-
|
1335
|
-
assert_instance_of Mechanize::Page, page
|
1336
|
-
|
1337
|
-
assert_equal 'UTF-8', page.encoding
|
1338
|
-
end
|
1339
|
-
|
1340
|
-
def test_response_read
|
1341
|
-
def @res.read_body() yield 'part' end
|
1342
|
-
def @res.content_length() 4 end
|
1343
|
-
|
1344
|
-
io = @agent.response_read @res, @req, @uri
|
1345
|
-
|
1346
|
-
body = io.read
|
1347
|
-
|
1348
|
-
assert_equal 'part', body
|
1349
|
-
assert_equal Encoding::BINARY, body.encoding
|
1350
|
-
end
|
1351
|
-
|
1352
|
-
def test_response_read_chunked_no_trailer
|
1353
|
-
@res['Transfer-Encoding'] = 'chunked'
|
1354
|
-
def @res.content_length() end
|
1355
|
-
def @res.read_body
|
1356
|
-
yield 'a' * 10
|
1357
|
-
raise EOFError
|
1358
|
-
end
|
1359
|
-
|
1360
|
-
e = assert_raises Mechanize::ChunkedTerminationError do
|
1361
|
-
@agent.response_read @res, @req, @uri
|
1362
|
-
end
|
1363
|
-
|
1364
|
-
assert_equal 'aaaaaaaaaa', e.body_io.read
|
1365
|
-
end
|
1366
|
-
|
1367
|
-
def test_response_read_content_length_head
|
1368
|
-
req = Net::HTTP::Head.new '/'
|
1369
|
-
|
1370
|
-
def @res.content_length() end
|
1371
|
-
def @res.read_body() end
|
1372
|
-
|
1373
|
-
io = @agent.response_read @res, req, @uri
|
1374
|
-
|
1375
|
-
assert_equal '', io.read
|
1376
|
-
end
|
1377
|
-
|
1378
|
-
def test_response_read_content_length_mismatch
|
1379
|
-
def @res.content_length() 5 end
|
1380
|
-
def @res.read_body() yield 'part' end
|
1381
|
-
|
1382
|
-
e = assert_raises Mechanize::ResponseReadError do
|
1383
|
-
@agent.response_read @res, @req, @uri
|
1384
|
-
end
|
1385
|
-
|
1386
|
-
assert_equal 'Content-Length (5) does not match response body length (4)' \
|
1387
|
-
' (Mechanize::ResponseReadError)', e.message
|
1388
|
-
end
|
1389
|
-
|
1390
|
-
def test_response_read_content_length_redirect
|
1391
|
-
res = Net::HTTPFound.allocate
|
1392
|
-
def res.content_length() 5 end
|
1393
|
-
def res.code() 302 end
|
1394
|
-
def res.read_body() yield 'part' end
|
1395
|
-
res.instance_variable_set :@header, {}
|
1396
|
-
|
1397
|
-
io = @agent.response_read res, @req, @uri
|
1398
|
-
|
1399
|
-
assert_equal 'part', io.read
|
1400
|
-
end
|
1401
|
-
|
1402
|
-
def test_response_read_error
|
1403
|
-
def @res.read_body()
|
1404
|
-
yield 'part'
|
1405
|
-
raise Net::HTTP::Persistent::Error
|
1406
|
-
end
|
1407
|
-
|
1408
|
-
e = assert_raises Mechanize::ResponseReadError do
|
1409
|
-
@agent.response_read @res, @req, @uri
|
1410
|
-
end
|
1411
|
-
|
1412
|
-
assert_equal @res, e.response
|
1413
|
-
assert_equal 'part', e.body_io.read
|
1414
|
-
assert_kind_of Net::HTTP::Persistent::Error, e.error
|
1415
|
-
end
|
1416
|
-
|
1417
|
-
def test_response_read_file
|
1418
|
-
Tempfile.open 'pi.txt' do |tempfile|
|
1419
|
-
tempfile.write "π\n"
|
1420
|
-
tempfile.flush
|
1421
|
-
tempfile.rewind
|
1422
|
-
|
1423
|
-
uri = URI.parse "file://#{tempfile.path}"
|
1424
|
-
req = Mechanize::FileRequest.new uri
|
1425
|
-
res = Mechanize::FileResponse.new tempfile.path
|
1426
|
-
|
1427
|
-
io = @agent.response_read res, req, uri
|
1428
|
-
|
1429
|
-
expected = "π\n".force_encoding(Encoding::BINARY)
|
1430
|
-
|
1431
|
-
# Ruby 1.8.7 doesn't let us set the write mode of the tempfile to binary,
|
1432
|
-
# so we should expect an inserted carriage return on some platforms
|
1433
|
-
expected_with_carriage_return = "π\r\n".force_encoding(Encoding::BINARY)
|
1434
|
-
|
1435
|
-
body = io.read
|
1436
|
-
assert_match(/^(#{expected}|#{expected_with_carriage_return})$/m, body)
|
1437
|
-
assert_equal Encoding::BINARY, body.encoding
|
1438
|
-
end
|
1439
|
-
end
|
1440
|
-
|
1441
|
-
def test_response_read_large
|
1442
|
-
@agent.max_file_buffer = 10240
|
1443
|
-
|
1444
|
-
def @res.read_body() yield 'a' * 10241 end
|
1445
|
-
def @res.content_length() 10241 end
|
1446
|
-
|
1447
|
-
io = @agent.response_read @res, @req, @uri
|
1448
|
-
|
1449
|
-
assert_kind_of Tempfile, io
|
1450
|
-
assert_equal 10241, io.stat.size
|
1451
|
-
end
|
1452
|
-
|
1453
|
-
def test_response_read_large_chunked
|
1454
|
-
@agent.max_file_buffer = 10240
|
1455
|
-
|
1456
|
-
def @res.read_body
|
1457
|
-
11.times do yield 'a' * 1024 end
|
1458
|
-
end
|
1459
|
-
def @res.content_length() end
|
1460
|
-
|
1461
|
-
io = @agent.response_read @res, @req, @uri
|
1462
|
-
|
1463
|
-
assert_kind_of Tempfile, io
|
1464
|
-
assert_equal 11264, io.stat.size
|
1465
|
-
end
|
1466
|
-
|
1467
|
-
def test_response_read_no_body
|
1468
|
-
req = Net::HTTP::Options.new '/'
|
1469
|
-
|
1470
|
-
def @res.content_length() end
|
1471
|
-
def @res.read_body() end
|
1472
|
-
|
1473
|
-
io = @agent.response_read @res, req, @uri
|
1474
|
-
|
1475
|
-
assert_equal '', io.read
|
1476
|
-
end
|
1477
|
-
|
1478
|
-
def test_response_read_unknown_code
|
1479
|
-
res = Net::HTTPUnknownResponse.allocate
|
1480
|
-
res.instance_variable_set :@code, 9999
|
1481
|
-
res.instance_variable_set :@header, {}
|
1482
|
-
def res.read_body() yield 'part' end
|
1483
|
-
|
1484
|
-
e = assert_raises Mechanize::ResponseCodeError do
|
1485
|
-
@agent.response_read res, @req, @uri
|
1486
|
-
end
|
1487
|
-
|
1488
|
-
assert_equal res, e.page
|
1489
|
-
end
|
1490
|
-
|
1491
|
-
def test_response_redirect
|
1492
|
-
@agent.redirect_ok = true
|
1493
|
-
referer = page 'http://example/referer'
|
1494
|
-
|
1495
|
-
page = fake_page
|
1496
|
-
page = @agent.response_redirect({ 'Location' => '/index.html' }, :get,
|
1497
|
-
page, 0, {}, referer)
|
1498
|
-
|
1499
|
-
assert_equal URI('http://fake.example/index.html'), page.uri
|
1500
|
-
|
1501
|
-
assert_equal 'http://example/referer', requests.first['Referer']
|
1502
|
-
end
|
1503
|
-
|
1504
|
-
def test_response_redirect_header
|
1505
|
-
@agent.redirect_ok = true
|
1506
|
-
referer = page 'http://example/referer'
|
1507
|
-
|
1508
|
-
headers = {
|
1509
|
-
'Range' => 'bytes=0-9999',
|
1510
|
-
'Content-Type' => 'application/x-www-form-urlencoded',
|
1511
|
-
'Content-Length' => '9999',
|
1512
|
-
}
|
1513
|
-
|
1514
|
-
page = fake_page
|
1515
|
-
page = @agent.response_redirect({ 'Location' => '/http_headers' }, :get,
|
1516
|
-
page, 0, headers, referer)
|
1517
|
-
|
1518
|
-
assert_equal URI('http://fake.example/http_headers'), page.uri
|
1519
|
-
|
1520
|
-
assert_match 'range|bytes=0-9999', page.body
|
1521
|
-
refute_match 'content-type|application/x-www-form-urlencoded', page.body
|
1522
|
-
refute_match 'content-length|9999', page.body
|
1523
|
-
end
|
1524
|
-
|
1525
|
-
def test_response_redirect_malformed
|
1526
|
-
@agent.redirect_ok = true
|
1527
|
-
referer = page 'http://example/referer'
|
1528
|
-
|
1529
|
-
page = fake_page
|
1530
|
-
page = @agent.response_redirect({ 'Location' => '/index.html?q=あ' }, :get,
|
1531
|
-
page, 0, {}, referer)
|
1532
|
-
|
1533
|
-
assert_equal URI('http://fake.example/index.html?q=%E3%81%82'), page.uri
|
1534
|
-
|
1535
|
-
assert_equal 'http://example/referer', requests.first['Referer']
|
1536
|
-
end
|
1537
|
-
|
1538
|
-
def test_response_redirect_insecure
|
1539
|
-
@agent.redirect_ok = true
|
1540
|
-
referer = page 'http://example/referer'
|
1541
|
-
|
1542
|
-
assert_raises Mechanize::Error do
|
1543
|
-
@agent.response_redirect({ 'Location' => 'file:///etc/passwd' }, :get,
|
1544
|
-
fake_page, 0, {}, referer)
|
1545
|
-
end
|
1546
|
-
end
|
1547
|
-
|
1548
|
-
def test_response_redirect_limit
|
1549
|
-
@agent.redirect_ok = true
|
1550
|
-
referer = page 'http://example/referer'
|
1551
|
-
|
1552
|
-
assert_raises Mechanize::RedirectLimitReachedError do
|
1553
|
-
@agent.response_redirect({ 'Location' => '/index.html' }, :get,
|
1554
|
-
fake_page, @agent.redirection_limit, {}, referer)
|
1555
|
-
end
|
1556
|
-
end
|
1557
|
-
|
1558
|
-
def test_response_redirect_not_ok
|
1559
|
-
@agent.redirect_ok = false
|
1560
|
-
|
1561
|
-
page = fake_page
|
1562
|
-
page = @agent.response_redirect({ 'Location' => '/other' }, :get, page, 0,
|
1563
|
-
{}, page)
|
1564
|
-
|
1565
|
-
assert_equal URI('http://fake.example'), page.uri
|
1566
|
-
end
|
1567
|
-
|
1568
|
-
def test_response_redirect_permanent
|
1569
|
-
@agent.redirect_ok = :permanent
|
1570
|
-
|
1571
|
-
response = Net::HTTPMovedPermanently.allocate
|
1572
|
-
response.instance_variable_set :@header, { 'location' => %w[/index.html] }
|
1573
|
-
|
1574
|
-
page = fake_page
|
1575
|
-
page = @agent.response_redirect response, :get, page, 0, {}, page
|
1576
|
-
|
1577
|
-
assert_equal URI('http://fake.example/index.html'), page.uri
|
1578
|
-
end
|
1579
|
-
|
1580
|
-
def test_response_redirect_permanent_temporary
|
1581
|
-
@agent.redirect_ok = :permanent
|
1582
|
-
|
1583
|
-
response = Net::HTTPMovedTemporarily.allocate
|
1584
|
-
response.instance_variable_set :@header, { 'location' => %w[/index.html] }
|
1585
|
-
|
1586
|
-
page = fake_page
|
1587
|
-
page = @agent.response_redirect response, :get, page, 0, {}, page
|
1588
|
-
|
1589
|
-
assert_equal URI('http://fake.example/'), page.uri
|
1590
|
-
end
|
1591
|
-
|
1592
|
-
def test_retry_change_request_equals
|
1593
|
-
refute @agent.http.retry_change_requests
|
1594
|
-
|
1595
|
-
@agent.retry_change_requests = true
|
1596
|
-
|
1597
|
-
assert @agent.http.retry_change_requests
|
1598
|
-
end
|
1599
|
-
|
1600
|
-
def test_robots_allowed_eh
|
1601
|
-
allowed = URI 'http://localhost/index.html'
|
1602
|
-
disallowed = URI 'http://localhost/norobots.html'
|
1603
|
-
|
1604
|
-
assert @agent.robots_allowed? allowed
|
1605
|
-
refute @agent.robots_allowed? disallowed
|
1606
|
-
|
1607
|
-
refute @agent.robots_disallowed? allowed
|
1608
|
-
assert @agent.robots_disallowed? disallowed
|
1609
|
-
end
|
1610
|
-
|
1611
|
-
def test_robots_allowed_eh_noindex
|
1612
|
-
@agent.robots = true
|
1613
|
-
|
1614
|
-
noindex = URI 'http://localhost/noindex.html'
|
1615
|
-
|
1616
|
-
assert @agent.robots_allowed? noindex
|
1617
|
-
|
1618
|
-
assert_raises Mechanize::RobotsDisallowedError do
|
1619
|
-
@agent.fetch noindex
|
1620
|
-
end
|
1621
|
-
end
|
1622
|
-
|
1623
|
-
def test_robots_infinite_loop
|
1624
|
-
@agent.robots = true
|
1625
|
-
@agent.redirect_ok = true
|
1626
|
-
|
1627
|
-
assert_raises Mechanize::RobotsDisallowedError do
|
1628
|
-
@agent.fetch URI('http://301/norobots.html')
|
1629
|
-
end
|
1630
|
-
|
1631
|
-
@agent.fetch URI('http://301/robots.html')
|
1632
|
-
end
|
1633
|
-
|
1634
|
-
def test_set_proxy
|
1635
|
-
@agent.set_proxy 'www.example.com', 9001, 'joe', 'lol'
|
1636
|
-
|
1637
|
-
assert_equal @agent.proxy_uri.host, 'www.example.com'
|
1638
|
-
assert_equal @agent.proxy_uri.port, 9001
|
1639
|
-
assert_equal @agent.proxy_uri.user, 'joe'
|
1640
|
-
assert_equal @agent.proxy_uri.password, 'lol'
|
1641
|
-
end
|
1642
|
-
|
1643
|
-
def test_set_proxy_port_string
|
1644
|
-
@agent.set_proxy 'www.example.com', '9001', 'joe', 'lol'
|
1645
|
-
|
1646
|
-
assert_equal @agent.proxy_uri.host, 'www.example.com'
|
1647
|
-
assert_equal @agent.proxy_uri.port, 9001
|
1648
|
-
assert_equal @agent.proxy_uri.user, 'joe'
|
1649
|
-
assert_equal @agent.proxy_uri.password, 'lol'
|
1650
|
-
end
|
1651
|
-
|
1652
|
-
def test_set_proxy_service_name
|
1653
|
-
@agent.set_proxy 'www.example.com', 'http', 'joe', 'lol'
|
1654
|
-
|
1655
|
-
assert_equal @agent.proxy_uri.host, 'www.example.com'
|
1656
|
-
assert_equal @agent.proxy_uri.port, 80
|
1657
|
-
assert_equal @agent.proxy_uri.user, 'joe'
|
1658
|
-
assert_equal @agent.proxy_uri.password, 'lol'
|
1659
|
-
end
|
1660
|
-
|
1661
|
-
def test_set_proxy_service_name_bad
|
1662
|
-
e = assert_raises ArgumentError do
|
1663
|
-
@agent.set_proxy 'www.example.com', 'nonexistent service', 'joe', 'lol'
|
1664
|
-
end
|
1665
|
-
|
1666
|
-
assert_equal 'invalid value for port: "nonexistent service"', e.message
|
1667
|
-
end
|
1668
|
-
|
1669
|
-
def test_set_proxy_with_scheme
|
1670
|
-
@agent.set_proxy 'http://www.example.com', 9001, 'joe', 'lol'
|
1671
|
-
|
1672
|
-
assert_equal @agent.proxy_uri.host, 'www.example.com'
|
1673
|
-
assert_equal @agent.proxy_uri.port, 9001
|
1674
|
-
assert_equal @agent.proxy_uri.user, 'joe'
|
1675
|
-
assert_equal @agent.proxy_uri.password, 'lol'
|
1676
|
-
end
|
1677
|
-
|
1678
|
-
def test_set_proxy_url
|
1679
|
-
@agent.set_proxy 'http://joe:lol@www.example.com:9001'
|
1680
|
-
|
1681
|
-
assert_equal @agent.proxy_uri.host, 'www.example.com'
|
1682
|
-
assert_equal @agent.proxy_uri.port, 9001
|
1683
|
-
assert_equal @agent.proxy_uri.user, 'joe'
|
1684
|
-
assert_equal @agent.proxy_uri.password, 'lol'
|
1685
|
-
end
|
1686
|
-
|
1687
|
-
def test_set_proxy_uri
|
1688
|
-
@agent.set_proxy URI('http://joe:lol@www.example.com:9001')
|
1689
|
-
|
1690
|
-
assert_equal @agent.proxy_uri.host, 'www.example.com'
|
1691
|
-
assert_equal @agent.proxy_uri.port, 9001
|
1692
|
-
assert_equal @agent.proxy_uri.user, 'joe'
|
1693
|
-
assert_equal @agent.proxy_uri.password, 'lol'
|
1694
|
-
end
|
1695
|
-
|
1696
|
-
def test_set_proxy_url_and_credentials
|
1697
|
-
@agent.set_proxy 'http://www.example.com:9001', nil, 'joe', 'lol'
|
1698
|
-
|
1699
|
-
assert_equal @agent.proxy_uri.host, 'www.example.com'
|
1700
|
-
assert_equal @agent.proxy_uri.port, 9001
|
1701
|
-
assert_equal @agent.proxy_uri.user, 'joe'
|
1702
|
-
assert_equal @agent.proxy_uri.password, 'lol'
|
1703
|
-
end
|
1704
|
-
|
1705
|
-
def test_setting_agent_name
|
1706
|
-
mech = Mechanize.new 'user-set-name'
|
1707
|
-
assert_equal 'user-set-name', mech.agent.http.name
|
1708
|
-
end
|
1709
|
-
|
1710
|
-
def test_ssl
|
1711
|
-
in_tmpdir do
|
1712
|
-
store = OpenSSL::X509::Store.new
|
1713
|
-
@agent.ca_file = '.'
|
1714
|
-
@agent.cert_store = store
|
1715
|
-
@agent.certificate = ssl_certificate
|
1716
|
-
@agent.private_key = ssl_private_key
|
1717
|
-
@agent.ssl_version = 'SSLv3'
|
1718
|
-
@agent.verify_callback = proc { |ok, context| }
|
1719
|
-
|
1720
|
-
http = @agent.http
|
1721
|
-
|
1722
|
-
assert_equal '.', http.ca_file
|
1723
|
-
assert_equal store, http.cert_store
|
1724
|
-
assert_equal ssl_certificate, http.certificate
|
1725
|
-
assert_equal ssl_private_key, http.private_key
|
1726
|
-
assert_equal 'SSLv3', http.ssl_version
|
1727
|
-
assert_equal OpenSSL::SSL::VERIFY_PEER, http.verify_mode
|
1728
|
-
assert http.verify_callback
|
1729
|
-
end
|
1730
|
-
end
|
1731
|
-
|
1732
|
-
def test_use_tempfile_eh
|
1733
|
-
refute @agent.use_tempfile? nil
|
1734
|
-
|
1735
|
-
@agent.max_file_buffer = 1
|
1736
|
-
|
1737
|
-
refute @agent.use_tempfile? 0
|
1738
|
-
assert @agent.use_tempfile? 1
|
1739
|
-
|
1740
|
-
@agent.max_file_buffer = nil
|
1741
|
-
|
1742
|
-
refute @agent.use_tempfile? 1
|
1743
|
-
end
|
1744
|
-
|
1745
|
-
def test_verify_none_equals
|
1746
|
-
@agent.verify_mode = OpenSSL::SSL::VERIFY_NONE
|
1747
|
-
|
1748
|
-
http = @agent.http
|
1749
|
-
|
1750
|
-
assert_equal OpenSSL::SSL::VERIFY_NONE, http.verify_mode
|
1751
|
-
end
|
1752
|
-
|
1753
|
-
end
|
1754
|
-
|