benschwarz-smoke 0.4.2 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +47 -0
- data/VERSION.yml +2 -2
- data/lib/core_ext/string.rb +6 -0
- data/lib/smoke/cache.rb +38 -23
- data/lib/smoke/request.rb +4 -8
- data/lib/smoke.rb +7 -2
- data/rdoc/classes/Smoke/Origin.html +340 -0
- data/rdoc/classes/Smoke/Source/Data.html +126 -0
- data/rdoc/classes/Smoke/Source/Feed.html +117 -0
- data/rdoc/classes/Smoke/Source/YQL.html +223 -0
- data/rdoc/classes/Smoke.html +260 -0
- data/rdoc/created.rid +1 -0
- data/rdoc/files/README_markdown.html +180 -0
- data/rdoc/files/lib/core_ext/hash_rb.html +49 -0
- data/rdoc/files/lib/smoke/origin_rb.html +49 -0
- data/rdoc/files/lib/smoke/request_rb.html +49 -0
- data/rdoc/files/lib/smoke/source/data_rb.html +49 -0
- data/rdoc/files/lib/smoke/source/feed_rb.html +49 -0
- data/rdoc/files/lib/smoke/source/join_rb.html +49 -0
- data/rdoc/files/lib/smoke/source/yql_rb.html +49 -0
- data/rdoc/files/lib/smoke_rb.html +65 -0
- data/rdoc/fr_class_index.html +21 -0
- data/rdoc/fr_file_index.html +28 -0
- data/rdoc/fr_method_index.html +4459 -0
- data/rdoc/index.html +15 -0
- data/rdoc/rdoc-style.css +319 -0
- data/spec/smoke/cache_spec.rb +28 -6
- data/vendor/crack/History +15 -0
- data/vendor/crack/LICENSE +20 -0
- data/vendor/crack/README.rdoc +42 -0
- data/vendor/crack/Rakefile +49 -0
- data/vendor/crack/VERSION.yml +4 -0
- data/vendor/crack/crack.gemspec +61 -0
- data/vendor/crack/lib/crack/core_extensions.rb +128 -0
- data/vendor/crack/lib/crack/json.rb +68 -0
- data/vendor/crack/lib/crack/xml.rb +214 -0
- data/vendor/crack/lib/crack.rb +7 -0
- data/vendor/crack/test/crack_test.rb +4 -0
- data/vendor/crack/test/data/twittersearch-firefox.json +1 -0
- data/vendor/crack/test/data/twittersearch-ie.json +1 -0
- data/vendor/crack/test/hash_test.rb +56 -0
- data/vendor/crack/test/json_test.rb +66 -0
- data/vendor/crack/test/string_test.rb +31 -0
- data/vendor/crack/test/test_helper.rb +12 -0
- data/vendor/crack/test/xml_test.rb +489 -0
- data/vendor/dependencies/README.markdown +113 -0
- data/vendor/dependencies/Rakefile +5 -0
- data/vendor/dependencies/bin/dep +83 -0
- data/vendor/dependencies/dependencies.gemspec +15 -0
- data/vendor/dependencies/dependencies.gemspec.erb +27 -0
- data/vendor/dependencies/lib/dependencies/dep.rb +99 -0
- data/vendor/dependencies/lib/dependencies.rb +5 -0
- data/vendor/dependencies/test/dependencies_test.rb +228 -0
- data/vendor/dependencies/test/foobaz-0.3.gem +0 -0
- data/vendor/fakeweb/CHANGELOG +163 -0
- data/vendor/fakeweb/LICENSE.txt +281 -0
- data/vendor/fakeweb/README.rdoc +193 -0
- data/vendor/fakeweb/Rakefile +76 -0
- data/vendor/fakeweb/fakeweb.gemspec +21 -0
- data/vendor/fakeweb/lib/fake_web/ext/net_http.rb +71 -0
- data/vendor/fakeweb/lib/fake_web/registry.rb +103 -0
- data/vendor/fakeweb/lib/fake_web/responder.rb +113 -0
- data/vendor/fakeweb/lib/fake_web/response.rb +10 -0
- data/vendor/fakeweb/lib/fake_web/stub_socket.rb +15 -0
- data/vendor/fakeweb/lib/fake_web/utility.rb +22 -0
- data/vendor/fakeweb/lib/fake_web.rb +172 -0
- data/vendor/fakeweb/lib/fakeweb.rb +2 -0
- data/vendor/fakeweb/test/fixtures/google_response_from_curl +12 -0
- data/vendor/fakeweb/test/fixtures/google_response_with_transfer_encoding +17 -0
- data/vendor/fakeweb/test/fixtures/google_response_without_transfer_encoding +11 -0
- data/vendor/fakeweb/test/fixtures/test_example.txt +1 -0
- data/vendor/fakeweb/test/fixtures/test_txt_file +3 -0
- data/vendor/fakeweb/test/test_allow_net_connect.rb +85 -0
- data/vendor/fakeweb/test/test_deprecations.rb +54 -0
- data/vendor/fakeweb/test/test_fake_authentication.rb +92 -0
- data/vendor/fakeweb/test/test_fake_web.rb +535 -0
- data/vendor/fakeweb/test/test_fake_web_open_uri.rb +58 -0
- data/vendor/fakeweb/test/test_helper.rb +74 -0
- data/vendor/fakeweb/test/test_missing_open_uri.rb +25 -0
- data/vendor/fakeweb/test/test_precedence.rb +51 -0
- data/vendor/fakeweb/test/test_query_string.rb +45 -0
- data/vendor/fakeweb/test/test_regexes.rb +103 -0
- data/vendor/fakeweb/test/test_response_headers.rb +73 -0
- data/vendor/fakeweb/test/test_trailing_slashes.rb +53 -0
- data/vendor/fakeweb/test/test_utility.rb +70 -0
- data/vendor/json-1.1.3/CHANGES +93 -0
- data/vendor/json-1.1.3/GPL +340 -0
- data/vendor/json-1.1.3/README +78 -0
- data/vendor/json-1.1.3/RUBY +58 -0
- data/vendor/json-1.1.3/Rakefile +309 -0
- data/vendor/json-1.1.3/TODO +1 -0
- data/vendor/json-1.1.3/VERSION +1 -0
- data/vendor/json-1.1.3/benchmarks/benchmark.txt +133 -0
- data/vendor/json-1.1.3/benchmarks/benchmark_generator.rb +48 -0
- data/vendor/json-1.1.3/benchmarks/benchmark_parser.rb +26 -0
- data/vendor/json-1.1.3/benchmarks/benchmark_rails.rb +26 -0
- data/vendor/json-1.1.3/bin/edit_json.rb +10 -0
- data/vendor/json-1.1.3/bin/prettify_json.rb +76 -0
- data/vendor/json-1.1.3/data/example.json +1 -0
- data/vendor/json-1.1.3/data/index.html +38 -0
- data/vendor/json-1.1.3/data/prototype.js +4184 -0
- data/vendor/json-1.1.3/ext/json/ext/generator/extconf.rb +9 -0
- data/vendor/json-1.1.3/ext/json/ext/generator/generator.c +875 -0
- data/vendor/json-1.1.3/ext/json/ext/generator/unicode.c +182 -0
- data/vendor/json-1.1.3/ext/json/ext/generator/unicode.h +53 -0
- data/vendor/json-1.1.3/ext/json/ext/parser/extconf.rb +9 -0
- data/vendor/json-1.1.3/ext/json/ext/parser/parser.c +1758 -0
- data/vendor/json-1.1.3/ext/json/ext/parser/parser.rl +638 -0
- data/vendor/json-1.1.3/ext/json/ext/parser/unicode.c +154 -0
- data/vendor/json-1.1.3/ext/json/ext/parser/unicode.h +58 -0
- data/vendor/json-1.1.3/install.rb +26 -0
- data/vendor/json-1.1.3/lib/json/Array.xpm +21 -0
- data/vendor/json-1.1.3/lib/json/FalseClass.xpm +21 -0
- data/vendor/json-1.1.3/lib/json/Hash.xpm +21 -0
- data/vendor/json-1.1.3/lib/json/Key.xpm +73 -0
- data/vendor/json-1.1.3/lib/json/NilClass.xpm +21 -0
- data/vendor/json-1.1.3/lib/json/Numeric.xpm +28 -0
- data/vendor/json-1.1.3/lib/json/String.xpm +96 -0
- data/vendor/json-1.1.3/lib/json/TrueClass.xpm +21 -0
- data/vendor/json-1.1.3/lib/json/add/core.rb +135 -0
- data/vendor/json-1.1.3/lib/json/add/rails.rb +58 -0
- data/vendor/json-1.1.3/lib/json/common.rb +354 -0
- data/vendor/json-1.1.3/lib/json/editor.rb +1362 -0
- data/vendor/json-1.1.3/lib/json/ext.rb +13 -0
- data/vendor/json-1.1.3/lib/json/json.xpm +1499 -0
- data/vendor/json-1.1.3/lib/json/pure/generator.rb +394 -0
- data/vendor/json-1.1.3/lib/json/pure/parser.rb +259 -0
- data/vendor/json-1.1.3/lib/json/pure.rb +75 -0
- data/vendor/json-1.1.3/lib/json/version.rb +9 -0
- data/vendor/json-1.1.3/lib/json.rb +235 -0
- data/vendor/json-1.1.3/tests/fixtures/fail1.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail10.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail11.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail12.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail13.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail14.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail18.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail19.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail2.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail20.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail21.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail22.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail23.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail24.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail25.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail27.json +2 -0
- data/vendor/json-1.1.3/tests/fixtures/fail28.json +2 -0
- data/vendor/json-1.1.3/tests/fixtures/fail3.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail4.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail5.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail6.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail7.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail8.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/fail9.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/pass1.json +56 -0
- data/vendor/json-1.1.3/tests/fixtures/pass15.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/pass16.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/pass17.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/pass2.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/pass26.json +1 -0
- data/vendor/json-1.1.3/tests/fixtures/pass3.json +6 -0
- data/vendor/json-1.1.3/tests/runner.rb +25 -0
- data/vendor/json-1.1.3/tests/test_json.rb +293 -0
- data/vendor/json-1.1.3/tests/test_json_addition.rb +161 -0
- data/vendor/json-1.1.3/tests/test_json_fixtures.rb +30 -0
- data/vendor/json-1.1.3/tests/test_json_generate.rb +100 -0
- data/vendor/json-1.1.3/tests/test_json_rails.rb +118 -0
- data/vendor/json-1.1.3/tests/test_json_unicode.rb +61 -0
- data/vendor/json-1.1.3/tools/fuzz.rb +140 -0
- data/vendor/json-1.1.3/tools/server.rb +62 -0
- data/vendor/moneta/LICENSE +20 -0
- data/vendor/moneta/README +51 -0
- data/vendor/moneta/Rakefile +60 -0
- data/vendor/moneta/TODO +4 -0
- data/vendor/moneta/benchmarks/various.rb +234 -0
- data/vendor/moneta/lib/moneta/basic_file.rb +111 -0
- data/vendor/moneta/lib/moneta/berkeley.rb +53 -0
- data/vendor/moneta/lib/moneta/couch.rb +63 -0
- data/vendor/moneta/lib/moneta/datamapper.rb +117 -0
- data/vendor/moneta/lib/moneta/file.rb +91 -0
- data/vendor/moneta/lib/moneta/lmc.rb +52 -0
- data/vendor/moneta/lib/moneta/memcache.rb +53 -0
- data/vendor/moneta/lib/moneta/memory.rb +11 -0
- data/vendor/moneta/lib/moneta/mongodb.rb +58 -0
- data/vendor/moneta/lib/moneta/redis.rb +49 -0
- data/vendor/moneta/lib/moneta/rufus.rb +41 -0
- data/vendor/moneta/lib/moneta/s3.rb +162 -0
- data/vendor/moneta/lib/moneta/sdbm.rb +33 -0
- data/vendor/moneta/lib/moneta/tyrant.rb +58 -0
- data/vendor/moneta/lib/moneta/xattr.rb +58 -0
- data/vendor/moneta/lib/moneta.rb +76 -0
- data/vendor/moneta/moneta.gemspec +32 -0
- data/vendor/moneta/script/destroy +14 -0
- data/vendor/moneta/script/generate +14 -0
- data/vendor/moneta/spec/moneta_basic_file_spec.rb +50 -0
- data/vendor/moneta/spec/moneta_berkeley_spec.rb +20 -0
- data/vendor/moneta/spec/moneta_couch_spec.rb +22 -0
- data/vendor/moneta/spec/moneta_datamapper_spec.rb +79 -0
- data/vendor/moneta/spec/moneta_file_spec.rb +21 -0
- data/vendor/moneta/spec/moneta_lmc_spec.rb +24 -0
- data/vendor/moneta/spec/moneta_memcache_spec.rb +16 -0
- data/vendor/moneta/spec/moneta_memory_spec.rb +12 -0
- data/vendor/moneta/spec/moneta_mongodb_spec.rb +16 -0
- data/vendor/moneta/spec/moneta_redis_spec.rb +16 -0
- data/vendor/moneta/spec/moneta_rufus_spec.rb +15 -0
- data/vendor/moneta/spec/moneta_s3_spec.rb +19 -0
- data/vendor/moneta/spec/moneta_sdbm_spec.rb +21 -0
- data/vendor/moneta/spec/moneta_tyrant_spec.rb +15 -0
- data/vendor/moneta/spec/moneta_xattr_spec.rb +21 -0
- data/vendor/moneta/spec/shared.rb +122 -0
- data/vendor/moneta/spec/spec_helper.rb +7 -0
- data/vendor/rest-client/README.rdoc +151 -0
- data/vendor/rest-client/Rakefile +58 -0
- data/vendor/rest-client/VERSION +1 -0
- data/vendor/rest-client/bin/restclient +87 -0
- data/vendor/rest-client/lib/rest_client.rb +2 -0
- data/vendor/rest-client/lib/restclient/exceptions.rb +88 -0
- data/vendor/rest-client/lib/restclient/mixin/response.rb +43 -0
- data/vendor/rest-client/lib/restclient/raw_response.rb +30 -0
- data/vendor/rest-client/lib/restclient/request.rb +238 -0
- data/vendor/rest-client/lib/restclient/resource.rb +146 -0
- data/vendor/rest-client/lib/restclient/response.rb +20 -0
- data/vendor/rest-client/lib/restclient.rb +99 -0
- data/vendor/rest-client/rest-client.gemspec +66 -0
- data/vendor/rest-client/spec/base.rb +4 -0
- data/vendor/rest-client/spec/exceptions_spec.rb +65 -0
- data/vendor/rest-client/spec/mixin/response_spec.rb +46 -0
- data/vendor/rest-client/spec/raw_response_spec.rb +17 -0
- data/vendor/rest-client/spec/request_spec.rb +476 -0
- data/vendor/rest-client/spec/resource_spec.rb +75 -0
- data/vendor/rest-client/spec/response_spec.rb +16 -0
- data/vendor/rest-client/spec/restclient_spec.rb +53 -0
- data/vendor/simple-rss/LICENSE +429 -0
- data/vendor/simple-rss/README +43 -0
- data/vendor/simple-rss/Rakefile +212 -0
- data/vendor/simple-rss/install.rb +40 -0
- data/vendor/simple-rss/lib/simple-rss.rb +150 -0
- data/vendor/simple-rss/simple-rss.gemspec +12 -0
- data/vendor/simple-rss/test/base/base_test.rb +51 -0
- data/vendor/simple-rss/test/data/atom.xml +45 -0
- data/vendor/simple-rss/test/data/not-rss.xml +8 -0
- data/vendor/simple-rss/test/data/rss09.rdf +79 -0
- data/vendor/simple-rss/test/data/rss20.xml +818 -0
- data/vendor/simple-rss/test/test_helper.rb +4 -0
- metadata +314 -40
@@ -0,0 +1,58 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), "test_helper")
|
2
|
+
|
3
|
+
class TestFakeWebOpenURI < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def test_content_for_registered_uri
|
6
|
+
FakeWeb.register_uri(:get, 'http://mock/test_example.txt', :body => File.dirname(__FILE__) + '/fixtures/test_example.txt')
|
7
|
+
assert_equal 'test example content', FakeWeb.response_for(:get, 'http://mock/test_example.txt').body
|
8
|
+
end
|
9
|
+
|
10
|
+
def test_mock_open
|
11
|
+
FakeWeb.register_uri(:get, 'http://mock/test_example.txt', :body => File.dirname(__FILE__) + '/fixtures/test_example.txt')
|
12
|
+
assert_equal 'test example content', open('http://mock/test_example.txt').read
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_mock_open_with_string_as_registered_uri
|
16
|
+
FakeWeb.register_uri(:get, 'http://mock/test_string.txt', :body => 'foo')
|
17
|
+
assert_equal 'foo', open('http://mock/test_string.txt').string
|
18
|
+
end
|
19
|
+
|
20
|
+
def test_real_open
|
21
|
+
FakeWeb.allow_net_connect = true
|
22
|
+
setup_expectations_for_real_apple_hot_news_request
|
23
|
+
resp = open('http://images.apple.com/main/rss/hotnews/hotnews.rss')
|
24
|
+
assert_equal "200", resp.status.first
|
25
|
+
body = resp.read
|
26
|
+
assert body.include?('Apple')
|
27
|
+
assert body.include?('News')
|
28
|
+
end
|
29
|
+
|
30
|
+
def test_mock_open_that_raises_exception
|
31
|
+
FakeWeb.register_uri(:get, 'http://mock/raising_exception.txt', :exception => StandardError)
|
32
|
+
assert_raises(StandardError) do
|
33
|
+
open('http://mock/raising_exception.txt')
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
def test_mock_open_that_raises_an_http_error
|
38
|
+
FakeWeb.register_uri(:get, 'http://mock/raising_exception.txt', :exception => OpenURI::HTTPError)
|
39
|
+
assert_raises(OpenURI::HTTPError) do
|
40
|
+
open('http://mock/raising_exception.txt')
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_mock_open_that_raises_an_http_error_with_a_specific_status
|
45
|
+
FakeWeb.register_uri(:get, 'http://mock/raising_exception.txt', :exception => OpenURI::HTTPError, :status => ['123', 'jodel'])
|
46
|
+
exception = assert_raises(OpenURI::HTTPError) do
|
47
|
+
open('http://mock/raising_exception.txt')
|
48
|
+
end
|
49
|
+
assert_equal '123', exception.io.code
|
50
|
+
assert_equal 'jodel', exception.io.message
|
51
|
+
end
|
52
|
+
|
53
|
+
def test_mock_open_with_block
|
54
|
+
FakeWeb.register_uri(:get, 'http://mock/test_example.txt', :body => File.dirname(__FILE__) + '/fixtures/test_example.txt')
|
55
|
+
body = open('http://mock/test_example.txt') { |f| f.readlines }
|
56
|
+
assert_equal 'test example content', body.first
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,74 @@
|
|
1
|
+
$:.unshift "#{File.dirname(__FILE__)}/../lib"
|
2
|
+
|
3
|
+
require 'test/unit'
|
4
|
+
require 'open-uri'
|
5
|
+
require 'fake_web'
|
6
|
+
require 'rubygems'
|
7
|
+
require 'mocha'
|
8
|
+
|
9
|
+
|
10
|
+
# Give all tests a common setup and teardown that prevents shared state
|
11
|
+
class Test::Unit::TestCase
|
12
|
+
def setup
|
13
|
+
FakeWeb.clean_registry
|
14
|
+
@original_allow_net_connect = FakeWeb.allow_net_connect?
|
15
|
+
FakeWeb.allow_net_connect = false
|
16
|
+
end
|
17
|
+
|
18
|
+
def teardown
|
19
|
+
FakeWeb.allow_net_connect = @original_allow_net_connect
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
|
24
|
+
module FakeWebTestHelper
|
25
|
+
|
26
|
+
def capture_stderr
|
27
|
+
$stderr = StringIO.new
|
28
|
+
yield
|
29
|
+
$stderr.rewind && $stderr.read
|
30
|
+
ensure
|
31
|
+
$stderr = STDERR
|
32
|
+
end
|
33
|
+
|
34
|
+
# Sets several expectations (using Mocha) that a real HTTP request makes it
|
35
|
+
# past FakeWeb to the socket layer. You can use this when you need to check
|
36
|
+
# that a request isn't handled by FakeWeb.
|
37
|
+
def setup_expectations_for_real_request(options = {})
|
38
|
+
# Socket handling
|
39
|
+
if options[:port] == 443
|
40
|
+
socket = mock("SSLSocket")
|
41
|
+
OpenSSL::SSL::SSLSocket.expects(:===).with(socket).returns(true).at_least_once
|
42
|
+
OpenSSL::SSL::SSLSocket.expects(:new).with(socket, instance_of(OpenSSL::SSL::SSLContext)).returns(socket).at_least_once
|
43
|
+
socket.stubs(:sync_close=).returns(true)
|
44
|
+
socket.expects(:connect).with().at_least_once
|
45
|
+
else
|
46
|
+
socket = mock("TCPSocket")
|
47
|
+
Socket.expects(:===).with(socket).returns(true)
|
48
|
+
end
|
49
|
+
|
50
|
+
TCPSocket.expects(:open).with(options[:host], options[:port]).returns(socket).at_least_once
|
51
|
+
socket.stubs(:closed?).returns(false)
|
52
|
+
socket.stubs(:close).returns(true)
|
53
|
+
|
54
|
+
# Request/response handling
|
55
|
+
request_parts = ["#{options[:method]} #{options[:path]} HTTP/1.1", "Host: #{options[:host]}"]
|
56
|
+
socket.expects(:write).with(all_of(includes(request_parts[0]), includes(request_parts[1]))).returns(100)
|
57
|
+
|
58
|
+
socket.expects(:sysread).at_least_once.returns("HTTP/1.1 #{options[:response_code]} #{options[:response_message]}\nContent-Length: #{options[:response_body].length}\n\n#{options[:response_body]}").then.raises(EOFError)
|
59
|
+
end
|
60
|
+
|
61
|
+
|
62
|
+
# A helper that calls #setup_expectations_for_real_request for you, using
|
63
|
+
# defaults for our commonly used test request to images.apple.com.
|
64
|
+
def setup_expectations_for_real_apple_hot_news_request(options = {})
|
65
|
+
defaults = { :host => "images.apple.com", :port => 80, :method => "GET",
|
66
|
+
:path => "/main/rss/hotnews/hotnews.rss",
|
67
|
+
:response_code => 200, :response_message => "OK",
|
68
|
+
:response_body => "<title>Apple Hot News</title>" }
|
69
|
+
setup_expectations_for_real_request(defaults.merge(options))
|
70
|
+
end
|
71
|
+
|
72
|
+
end
|
73
|
+
|
74
|
+
Test::Unit::TestCase.send(:include, FakeWebTestHelper)
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), "test_helper")
|
2
|
+
|
3
|
+
class TestMissingOpenURI < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def setup
|
6
|
+
super
|
7
|
+
@saved_open_uri = OpenURI
|
8
|
+
Object.send(:remove_const, :OpenURI)
|
9
|
+
end
|
10
|
+
|
11
|
+
def teardown
|
12
|
+
super
|
13
|
+
Object.const_set(:OpenURI, @saved_open_uri)
|
14
|
+
end
|
15
|
+
|
16
|
+
|
17
|
+
def test_register_using_exception_without_open_uri
|
18
|
+
# regression test for Responder needing OpenURI::HTTPError to be defined
|
19
|
+
FakeWeb.register_uri(:get, "http://example.com/", :exception => StandardError)
|
20
|
+
assert_raises(StandardError) do
|
21
|
+
Net::HTTP.start("example.com") { |http| http.get("/") }
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
@@ -0,0 +1,51 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), "test_helper")
|
2
|
+
|
3
|
+
class TestPrecedence < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def test_matching_get_strings_have_precedence_over_matching_get_regexes
|
6
|
+
FakeWeb.register_uri(:get, "http://example.com/test", :body => "string")
|
7
|
+
FakeWeb.register_uri(:get, %r|http://example\.com/test|, :body => "regex")
|
8
|
+
response = Net::HTTP.start("example.com") { |query| query.get('/test') }
|
9
|
+
assert_equal "string", response.body
|
10
|
+
end
|
11
|
+
|
12
|
+
def test_matching_any_strings_have_precedence_over_matching_any_regexes
|
13
|
+
FakeWeb.register_uri(:any, "http://example.com/test", :body => "string")
|
14
|
+
FakeWeb.register_uri(:any, %r|http://example\.com/test|, :body => "regex")
|
15
|
+
response = Net::HTTP.start("example.com") { |query| query.get('/test') }
|
16
|
+
assert_equal "string", response.body
|
17
|
+
end
|
18
|
+
|
19
|
+
def test_matching_get_strings_have_precedence_over_matching_any_strings
|
20
|
+
FakeWeb.register_uri(:get, "http://example.com/test", :body => "get method")
|
21
|
+
FakeWeb.register_uri(:any, "http://example.com/test", :body => "any method")
|
22
|
+
response = Net::HTTP.start("example.com") { |query| query.get('/test') }
|
23
|
+
assert_equal "get method", response.body
|
24
|
+
|
25
|
+
# registration order should not matter
|
26
|
+
FakeWeb.register_uri(:any, "http://example.com/test2", :body => "any method")
|
27
|
+
FakeWeb.register_uri(:get, "http://example.com/test2", :body => "get method")
|
28
|
+
response = Net::HTTP.start("example.com") { |query| query.get('/test2') }
|
29
|
+
assert_equal "get method", response.body
|
30
|
+
end
|
31
|
+
|
32
|
+
def test_matching_any_strings_have_precedence_over_matching_get_regexes
|
33
|
+
FakeWeb.register_uri(:any, "http://example.com/test", :body => "any string")
|
34
|
+
FakeWeb.register_uri(:get, %r|http://example\.com/test|, :body => "get regex")
|
35
|
+
response = Net::HTTP.start("example.com") { |query| query.get('/test') }
|
36
|
+
assert_equal "any string", response.body
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_registered_strings_and_uris_are_equivalent_so_second_takes_precedence
|
40
|
+
FakeWeb.register_uri(:get, "http://example.com/test", :body => "string")
|
41
|
+
FakeWeb.register_uri(:get, URI.parse("http://example.com/test"), :body => "uri")
|
42
|
+
response = Net::HTTP.start("example.com") { |query| query.get('/test') }
|
43
|
+
assert_equal "uri", response.body
|
44
|
+
|
45
|
+
FakeWeb.register_uri(:get, URI.parse("http://example.com/test2"), :body => "uri")
|
46
|
+
FakeWeb.register_uri(:get, "http://example.com/test2", :body => "string")
|
47
|
+
response = Net::HTTP.start("example.com") { |query| query.get('/test2') }
|
48
|
+
assert_equal "string", response.body
|
49
|
+
end
|
50
|
+
|
51
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), "test_helper")
|
2
|
+
|
3
|
+
class TestFakeWebQueryString < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def test_register_uri_string_with_query_params
|
6
|
+
FakeWeb.register_uri(:get, 'http://example.com/?a=1&b=1', :body => 'foo')
|
7
|
+
assert FakeWeb.registered_uri?(:get, 'http://example.com/?a=1&b=1')
|
8
|
+
|
9
|
+
FakeWeb.register_uri(:post, URI.parse("http://example.org/?a=1&b=1"), :body => "foo")
|
10
|
+
assert FakeWeb.registered_uri?(:post, "http://example.org/?a=1&b=1")
|
11
|
+
end
|
12
|
+
|
13
|
+
def test_register_uri_with_query_params_and_check_in_different_order
|
14
|
+
FakeWeb.register_uri(:get, 'http://example.com/?a=1&b=1', :body => 'foo')
|
15
|
+
assert FakeWeb.registered_uri?(:get, 'http://example.com/?b=1&a=1')
|
16
|
+
|
17
|
+
FakeWeb.register_uri(:post, URI.parse('http://example.org/?a=1&b=1'), :body => 'foo')
|
18
|
+
assert FakeWeb.registered_uri?(:post, 'http://example.org/?b=1&a=1')
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_registered_uri_gets_recognized_with_empty_query_params
|
22
|
+
FakeWeb.register_uri(:get, 'http://example.com/', :body => 'foo')
|
23
|
+
assert FakeWeb.registered_uri?(:get, 'http://example.com/?')
|
24
|
+
|
25
|
+
FakeWeb.register_uri(:post, URI.parse('http://example.org/'), :body => 'foo')
|
26
|
+
assert FakeWeb.registered_uri?(:post, 'http://example.org/?')
|
27
|
+
end
|
28
|
+
|
29
|
+
def test_register_uri_with_empty_query_params_and_check_with_none
|
30
|
+
FakeWeb.register_uri(:get, 'http://example.com/?', :body => 'foo')
|
31
|
+
assert FakeWeb.registered_uri?(:get, 'http://example.com/')
|
32
|
+
|
33
|
+
FakeWeb.register_uri(:post, URI.parse('http://example.org/?'), :body => 'foo')
|
34
|
+
assert FakeWeb.registered_uri?(:post, 'http://example.org/')
|
35
|
+
end
|
36
|
+
|
37
|
+
def test_registry_sort_query_params
|
38
|
+
assert_equal "a=1&b=2", FakeWeb::Registry.instance.send(:sort_query_params, "b=2&a=1")
|
39
|
+
end
|
40
|
+
|
41
|
+
def test_registry_sort_query_params_sorts_by_value_if_keys_collide
|
42
|
+
assert_equal "a=1&a=2&b=2", FakeWeb::Registry.instance.send(:sort_query_params, "a=2&b=2&a=1")
|
43
|
+
end
|
44
|
+
|
45
|
+
end
|
@@ -0,0 +1,103 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), "test_helper")
|
2
|
+
|
3
|
+
class TestRegexes < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def test_registered_uri_with_pattern
|
6
|
+
FakeWeb.register_uri(:get, %r|http://example.com/test_example/\d+|, :body => "example")
|
7
|
+
assert FakeWeb.registered_uri?(:get, "http://example.com/test_example/25")
|
8
|
+
assert !FakeWeb.registered_uri?(:get, "http://example.com/test_example/abc")
|
9
|
+
end
|
10
|
+
|
11
|
+
def test_response_for_with_matching_registered_uri
|
12
|
+
FakeWeb.register_uri(:get, %r|http://www.google.com|, :body => "Welcome to Google!")
|
13
|
+
assert_equal "Welcome to Google!", FakeWeb.response_for(:get, "http://www.google.com").body
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_response_for_with_matching_registered_uri_and_get_method_matching_to_any_method
|
17
|
+
FakeWeb.register_uri(:any, %r|http://www.example.com|, :body => "example")
|
18
|
+
assert_equal "example", FakeWeb.response_for(:get, "http://www.example.com").body
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_registered_uri_with_authentication_and_pattern
|
22
|
+
FakeWeb.register_uri(:get, %r|http://user:pass@mock/example\.\w+|i, :body => "example")
|
23
|
+
assert FakeWeb.registered_uri?(:get, 'http://user:pass@mock/example.txt')
|
24
|
+
end
|
25
|
+
|
26
|
+
def test_registered_uri_with_authentication_and_pattern_handles_case_insensitivity
|
27
|
+
FakeWeb.register_uri(:get, %r|http://user:pass@mock/example\.\w+|i, :body => "example")
|
28
|
+
assert FakeWeb.registered_uri?(:get, 'http://uSeR:PAss@mock/example.txt')
|
29
|
+
end
|
30
|
+
|
31
|
+
def test_request_with_authentication_and_pattern_handles_case_insensitivity
|
32
|
+
FakeWeb.register_uri(:get, %r|http://user:pass@mock/example\.\w+|i, :body => "example")
|
33
|
+
http = Net::HTTP.new('mock', 80)
|
34
|
+
req = Net::HTTP::Get.new('/example.txt')
|
35
|
+
req.basic_auth 'uSeR', 'PAss'
|
36
|
+
assert_equal "example", http.request(req).body
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_requesting_a_uri_that_matches_two_registered_regexes_raises_an_error
|
40
|
+
FakeWeb.register_uri(:get, %r|http://example\.com/|, :body => "first")
|
41
|
+
FakeWeb.register_uri(:get, %r|http://example\.com/a|, :body => "second")
|
42
|
+
assert_raise FakeWeb::MultipleMatchingRegexpsError do
|
43
|
+
Net::HTTP.start("example.com") { |query| query.get('/a') }
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
def test_requesting_a_uri_that_matches_two_registered_regexes_raises_an_error_including_request_info
|
48
|
+
FakeWeb.register_uri(:get, %r|http://example\.com/|, :body => "first")
|
49
|
+
FakeWeb.register_uri(:get, %r|http://example\.com/a|, :body => "second")
|
50
|
+
begin
|
51
|
+
Net::HTTP.start("example.com") { |query| query.get('/a') }
|
52
|
+
rescue FakeWeb::MultipleMatchingRegexpsError => exception
|
53
|
+
end
|
54
|
+
assert exception.message.include?("GET http://example.com/a")
|
55
|
+
end
|
56
|
+
|
57
|
+
def test_registry_does_not_find_using_mismatched_protocols_or_ports_when_registered_with_both
|
58
|
+
FakeWeb.register_uri(:get, %r|http://www.example.com:80|, :body => "example")
|
59
|
+
assert !FakeWeb.registered_uri?(:get, "https://www.example.com:80")
|
60
|
+
assert !FakeWeb.registered_uri?(:get, "http://www.example.com:443")
|
61
|
+
end
|
62
|
+
|
63
|
+
def test_registry_only_finds_using_default_port_when_registered_without_if_protocol_matches
|
64
|
+
FakeWeb.register_uri(:get, %r|http://www.example.com/test|, :body => "example")
|
65
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com:80/test")
|
66
|
+
assert !FakeWeb.registered_uri?(:get, "http://www.example.com:443/test")
|
67
|
+
assert !FakeWeb.registered_uri?(:get, "https://www.example.com:443/test")
|
68
|
+
FakeWeb.register_uri(:get, %r|https://www.example.org/test|, :body => "example")
|
69
|
+
assert FakeWeb.registered_uri?(:get, "https://www.example.org:443/test")
|
70
|
+
assert !FakeWeb.registered_uri?(:get, "https://www.example.org:80/test")
|
71
|
+
assert !FakeWeb.registered_uri?(:get, "http://www.example.org:80/test")
|
72
|
+
end
|
73
|
+
|
74
|
+
def test_registry_matches_using_mismatched_port_when_registered_without
|
75
|
+
FakeWeb.register_uri(:get, %r|http://www.example.com|, :body => "example")
|
76
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com:80")
|
77
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com:443")
|
78
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com:12345")
|
79
|
+
assert !FakeWeb.registered_uri?(:get, "https://www.example.com:443")
|
80
|
+
assert !FakeWeb.registered_uri?(:get, "https://www.example.com")
|
81
|
+
end
|
82
|
+
|
83
|
+
def test_registry_matches_using_any_protocol_and_port_when_registered_without_protocol_or_port
|
84
|
+
FakeWeb.register_uri(:get, %r|www.example.com|, :body => "example")
|
85
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com")
|
86
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com:80")
|
87
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com:443")
|
88
|
+
assert FakeWeb.registered_uri?(:get, "https://www.example.com")
|
89
|
+
assert FakeWeb.registered_uri?(:get, "https://www.example.com:80")
|
90
|
+
assert FakeWeb.registered_uri?(:get, "https://www.example.com:443")
|
91
|
+
end
|
92
|
+
|
93
|
+
def test_registry_matches_with_query_params
|
94
|
+
FakeWeb.register_uri(:get, %r[example.com/list\?(.*&|)important=1], :body => "example")
|
95
|
+
assert FakeWeb.registered_uri?(:get, "http://example.com/list?hash=123&important=1&unimportant=2")
|
96
|
+
assert FakeWeb.registered_uri?(:get, "http://example.com/list?hash=123&important=12&unimportant=2")
|
97
|
+
assert FakeWeb.registered_uri?(:get, "http://example.com/list?important=1&unimportant=2")
|
98
|
+
assert !FakeWeb.registered_uri?(:get, "http://example.com/list?important=2")
|
99
|
+
assert !FakeWeb.registered_uri?(:get, "http://example.com/list?important=2&unimportant=1")
|
100
|
+
assert !FakeWeb.registered_uri?(:get, "http://example.com/list?hash=123&important=2&unimportant=1")
|
101
|
+
assert !FakeWeb.registered_uri?(:get, "http://example.com/list?notimportant=1&unimportant=1")
|
102
|
+
end
|
103
|
+
end
|
@@ -0,0 +1,73 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), "test_helper")
|
2
|
+
|
3
|
+
class TestResponseHeaders < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def test_content_type_when_registering_with_string_and_content_type_header_as_symbol_option
|
6
|
+
FakeWeb.register_uri(:get, "http://example.com/users.json", :body => '[{"username": "chrisk"}]', :content_type => "application/json")
|
7
|
+
response = Net::HTTP.start("example.com") { |query| query.get("/users.json") }
|
8
|
+
assert_equal '[{"username": "chrisk"}]', response.body
|
9
|
+
assert_equal "application/json", response['Content-Type']
|
10
|
+
end
|
11
|
+
|
12
|
+
def test_content_type_when_registering_with_string_and_content_type_header_as_string_option
|
13
|
+
FakeWeb.register_uri(:get, "http://example.com/users.json", :body => '[{"username": "chrisk"}]', 'Content-Type' => "application/json")
|
14
|
+
response = Net::HTTP.start("example.com") { |query| query.get("/users.json") }
|
15
|
+
assert_equal "application/json", response['Content-Type']
|
16
|
+
end
|
17
|
+
|
18
|
+
def test_content_type_when_registering_with_string_only
|
19
|
+
FakeWeb.register_uri(:get, "http://example.com/users.json", :body => '[{"username": "chrisk"}]')
|
20
|
+
response = Net::HTTP.start("example.com") { |query| query.get("/users.json") }
|
21
|
+
assert_equal '[{"username": "chrisk"}]', response.body
|
22
|
+
assert_nil response['Content-Type']
|
23
|
+
end
|
24
|
+
|
25
|
+
def test_cookies_when_registering_with_file_and_set_cookie_header
|
26
|
+
FakeWeb.register_uri(:get, "http://example.com/", :body => File.dirname(__FILE__) + '/fixtures/test_example.txt',
|
27
|
+
:set_cookie => "user_id=1; example=yes")
|
28
|
+
response = Net::HTTP.start("example.com") { |query| query.get("/") }
|
29
|
+
assert_equal "test example content", response.body
|
30
|
+
assert_equal "user_id=1; example=yes", response['Set-Cookie']
|
31
|
+
end
|
32
|
+
|
33
|
+
def test_registering_with_baked_response_ignores_header_options
|
34
|
+
fake_response = Net::HTTPOK.new('1.1', '200', 'OK')
|
35
|
+
fake_response["Server"] = "Apache/1.3.27 (Unix)"
|
36
|
+
FakeWeb.register_uri(:get, "http://example.com/", :response => fake_response,
|
37
|
+
:server => "FakeWeb/1.2.3 (Ruby)")
|
38
|
+
response = Net::HTTP.start("example.com") { |query| query.get("/") }
|
39
|
+
assert_equal "200", response.code
|
40
|
+
assert_equal "OK", response.message
|
41
|
+
assert_equal "Apache/1.3.27 (Unix)", response["Server"]
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_headers_are_rotated_when_registering_with_response_rotation
|
45
|
+
FakeWeb.register_uri(:get, "http://example.com",
|
46
|
+
[{:body => 'test1', :expires => "Thu, 14 Jun 2009 16:00:00 GMT",
|
47
|
+
:content_type => "text/plain"},
|
48
|
+
{:body => 'test2', :expires => "Thu, 14 Jun 2009 16:00:01 GMT"}])
|
49
|
+
|
50
|
+
first_response = second_response = nil
|
51
|
+
Net::HTTP.start("example.com") do |query|
|
52
|
+
first_response = query.get("/")
|
53
|
+
second_response = query.get("/")
|
54
|
+
end
|
55
|
+
assert_equal 'test1', first_response.body
|
56
|
+
assert_equal "Thu, 14 Jun 2009 16:00:00 GMT", first_response['Expires']
|
57
|
+
assert_equal "text/plain", first_response['Content-Type']
|
58
|
+
assert_equal 'test2', second_response.body
|
59
|
+
assert_equal "Thu, 14 Jun 2009 16:00:01 GMT", second_response['Expires']
|
60
|
+
assert_nil second_response['Content-Type']
|
61
|
+
end
|
62
|
+
|
63
|
+
def test_registering_with_status_option_and_response_headers
|
64
|
+
FakeWeb.register_uri(:get, "http://example.com", :status => ["301", "Moved Permanently"],
|
65
|
+
:location => "http://www.example.com")
|
66
|
+
|
67
|
+
response = Net::HTTP.start("example.com") { |query| query.get("/") }
|
68
|
+
assert_equal "301", response.code
|
69
|
+
assert_equal "Moved Permanently", response.message
|
70
|
+
assert_equal "http://www.example.com", response["Location"]
|
71
|
+
end
|
72
|
+
|
73
|
+
end
|
@@ -0,0 +1,53 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), "test_helper")
|
2
|
+
|
3
|
+
class TestFakeWebTrailingSlashes < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def test_registering_root_without_slash_and_ask_predicate_method_with_slash
|
6
|
+
FakeWeb.register_uri(:get, "http://www.example.com", :body => "root")
|
7
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com/")
|
8
|
+
end
|
9
|
+
|
10
|
+
def test_registering_root_without_slash_and_request
|
11
|
+
FakeWeb.register_uri(:get, "http://www.example.com", :body => "root")
|
12
|
+
response = Net::HTTP.start("www.example.com") { |query| query.get('/') }
|
13
|
+
assert_equal "root", response.body
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_registering_root_with_slash_and_ask_predicate_method_without_slash
|
17
|
+
FakeWeb.register_uri(:get, "http://www.example.com/", :body => "root")
|
18
|
+
assert FakeWeb.registered_uri?(:get, "http://www.example.com")
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_registering_root_with_slash_and_request
|
22
|
+
FakeWeb.register_uri(:get, "http://www.example.com/", :body => "root")
|
23
|
+
response = Net::HTTP.start("www.example.com") { |query| query.get('/') }
|
24
|
+
assert_equal "root", response.body
|
25
|
+
end
|
26
|
+
|
27
|
+
def test_registering_path_without_slash_and_ask_predicate_method_with_slash
|
28
|
+
FakeWeb.register_uri(:get, "http://www.example.com/users", :body => "User list")
|
29
|
+
assert !FakeWeb.registered_uri?(:get, "http://www.example.com/users/")
|
30
|
+
end
|
31
|
+
|
32
|
+
def test_registering_path_without_slash_and_request_with_slash
|
33
|
+
FakeWeb.allow_net_connect = false
|
34
|
+
FakeWeb.register_uri(:get, "http://www.example.com/users", :body => "User list")
|
35
|
+
assert_raise FakeWeb::NetConnectNotAllowedError do
|
36
|
+
response = Net::HTTP.start("www.example.com") { |query| query.get('/users/') }
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
def test_registering_path_with_slash_and_ask_predicate_method_without_slash
|
41
|
+
FakeWeb.register_uri(:get, "http://www.example.com/users/", :body => "User list")
|
42
|
+
assert !FakeWeb.registered_uri?(:get, "http://www.example.com/users")
|
43
|
+
end
|
44
|
+
|
45
|
+
def test_registering_path_with_slash_and_request_without_slash
|
46
|
+
FakeWeb.allow_net_connect = false
|
47
|
+
FakeWeb.register_uri(:get, "http://www.example.com/users/", :body => "User list")
|
48
|
+
assert_raise FakeWeb::NetConnectNotAllowedError do
|
49
|
+
response = Net::HTTP.start("www.example.com") { |query| query.get('/users') }
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
end
|
@@ -0,0 +1,70 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), "test_helper")
|
2
|
+
|
3
|
+
class TestUtility < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def test_decode_userinfo_from_header_handles_basic_auth
|
6
|
+
authorization_header = "Basic dXNlcm5hbWU6c2VjcmV0"
|
7
|
+
userinfo = FakeWeb::Utility.decode_userinfo_from_header(authorization_header)
|
8
|
+
assert_equal "username:secret", userinfo
|
9
|
+
end
|
10
|
+
|
11
|
+
def test_encode_unsafe_chars_in_userinfo_does_not_encode_userinfo_safe_punctuation
|
12
|
+
userinfo = "user;&=+$,:secret"
|
13
|
+
assert_equal userinfo, FakeWeb::Utility.encode_unsafe_chars_in_userinfo(userinfo)
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_encode_unsafe_chars_in_userinfo_does_not_encode_rfc_3986_unreserved_characters
|
17
|
+
userinfo = "-_.!~*'()abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789:secret"
|
18
|
+
assert_equal userinfo, FakeWeb::Utility.encode_unsafe_chars_in_userinfo(userinfo)
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_encode_unsafe_chars_in_userinfo_does_encode_other_characters
|
22
|
+
userinfo, safe_userinfo = 'us#rn@me:sec//ret?"', 'us%23rn%40me:sec%2F%2Fret%3F%22'
|
23
|
+
assert_equal safe_userinfo, FakeWeb::Utility.encode_unsafe_chars_in_userinfo(userinfo)
|
24
|
+
end
|
25
|
+
|
26
|
+
def test_strip_default_port_from_uri_strips_80_from_http_with_path
|
27
|
+
uri = "http://example.com:80/foo/bar"
|
28
|
+
stripped_uri = FakeWeb::Utility.strip_default_port_from_uri(uri)
|
29
|
+
assert_equal "http://example.com/foo/bar", stripped_uri
|
30
|
+
end
|
31
|
+
|
32
|
+
def test_strip_default_port_from_uri_strips_80_from_http_without_path
|
33
|
+
uri = "http://example.com:80"
|
34
|
+
stripped_uri = FakeWeb::Utility.strip_default_port_from_uri(uri)
|
35
|
+
assert_equal "http://example.com", stripped_uri
|
36
|
+
end
|
37
|
+
|
38
|
+
def test_strip_default_port_from_uri_strips_443_from_https_without_path
|
39
|
+
uri = "https://example.com:443"
|
40
|
+
stripped_uri = FakeWeb::Utility.strip_default_port_from_uri(uri)
|
41
|
+
assert_equal "https://example.com", stripped_uri
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_strip_default_port_from_uri_strips_443_from_https
|
45
|
+
uri = "https://example.com:443/foo/bar"
|
46
|
+
stripped_uri = FakeWeb::Utility.strip_default_port_from_uri(uri)
|
47
|
+
assert_equal "https://example.com/foo/bar", stripped_uri
|
48
|
+
end
|
49
|
+
|
50
|
+
def test_strip_default_port_from_uri_does_not_strip_8080_from_http
|
51
|
+
uri = "http://example.com:8080/foo/bar"
|
52
|
+
assert_equal uri, FakeWeb::Utility.strip_default_port_from_uri(uri)
|
53
|
+
end
|
54
|
+
|
55
|
+
def test_strip_default_port_from_uri_does_not_strip_443_from_http
|
56
|
+
uri = "http://example.com:443/foo/bar"
|
57
|
+
assert_equal uri, FakeWeb::Utility.strip_default_port_from_uri(uri)
|
58
|
+
end
|
59
|
+
|
60
|
+
def test_strip_default_port_from_uri_does_not_strip_80_from_query_string
|
61
|
+
uri = "http://example.com/?a=:80&b=c"
|
62
|
+
assert_equal uri, FakeWeb::Utility.strip_default_port_from_uri(uri)
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_strip_default_port_from_uri_does_not_modify_strings_that_do_not_start_with_http_or_https
|
66
|
+
uri = "httpz://example.com:80/"
|
67
|
+
assert_equal uri, FakeWeb::Utility.strip_default_port_from_uri(uri)
|
68
|
+
end
|
69
|
+
|
70
|
+
end
|
@@ -0,0 +1,93 @@
|
|
1
|
+
2008-07-10 (1.1.3)
|
2
|
+
* Wesley Beary <monki@geemus.com> reported a bug in json/add/core's DateTime
|
3
|
+
handling: If the nominator and denominator of the offset were divisible by
|
4
|
+
each other Ruby's Rational#to_s returns them as an integer not a fraction
|
5
|
+
with '/'. This caused a ZeroDivisionError during parsing.
|
6
|
+
* Use Date#start and DateTime#start instead of sg method, while
|
7
|
+
remaining backwards compatible.
|
8
|
+
* Supports ragel >= 6.0 now.
|
9
|
+
* Corrected some tests.
|
10
|
+
* Some minor changes.
|
11
|
+
2007-11-27 (1.1.2)
|
12
|
+
* Remember default dir (last used directory) in editor.
|
13
|
+
* JSON::Editor.edit method added, the editor can now receive json texts from
|
14
|
+
the clipboard via C-v.
|
15
|
+
* Load json texts from an URL pasted via middle button press.
|
16
|
+
* Added :create_additions option to Parser. This makes it possible to disable
|
17
|
+
the creation of additions by force, in order to treat json texts as data
|
18
|
+
while having additions loaded.
|
19
|
+
* Jacob Maine <jmaine@blurb.com> reported, that JSON(:foo) outputs a JSON
|
20
|
+
object if the rails addition is enabled, which is wrong. It now outputs a
|
21
|
+
JSON string "foo" instead, like suggested by Jacob Maine.
|
22
|
+
* Discovered a bug in the Ruby Bugs Tracker on rubyforge, that was reported
|
23
|
+
by John Evans lgastako@gmail.com. He could produce a crash in the JSON
|
24
|
+
generator by returning something other than a String instance from a
|
25
|
+
to_json method. I now guard against this by doing a rather crude type
|
26
|
+
check, which raises an exception instead of crashing.
|
27
|
+
2007-07-06 (1.1.1)
|
28
|
+
* Yui NARUSE <naruse@airemix.com> sent some patches to fix tests for Ruby
|
29
|
+
1.9. I applied them and adapted some of them a bit to run both on 1.8 and
|
30
|
+
1.9.
|
31
|
+
* Introduced a JSON.parse! method without depth checking for people who like
|
32
|
+
danger.
|
33
|
+
* Made generate and pretty_generate methods configurable by an options hash.
|
34
|
+
* Added :allow_nan option to parser and generator in order to handle NaN,
|
35
|
+
Infinity, and -Infinity correctly - if requested. Floats, which aren't numbers,
|
36
|
+
aren't valid JSON according to RFC4627, so by default an exception will be
|
37
|
+
raised if any of these symbols are encountered. Thanks to Andrea Censi
|
38
|
+
<andrea.censi@dis.uniroma1.it> for his hint about this.
|
39
|
+
* Fixed some more tests for Ruby 1.9.
|
40
|
+
* Implemented dump/load interface of Marshal as suggested in ruby-core:11405
|
41
|
+
by murphy <murphy@rubychan.de>.
|
42
|
+
* Implemented the max_nesting feature for generate methods, too.
|
43
|
+
* Added some implementations for ruby core's custom objects for
|
44
|
+
serialisation/deserialisation purposes.
|
45
|
+
2007-05-21 (1.1.0)
|
46
|
+
* Implemented max_nesting feature for parser to avoid stack overflows for
|
47
|
+
data from untrusted sources. If you trust the source, you can disable it
|
48
|
+
with the option max_nesting => false.
|
49
|
+
* Piers Cawley <pdcawley@bofh.org.uk> reported a bug, that not every
|
50
|
+
character can be escaped by ?\ as required by RFC4627. There's a
|
51
|
+
contradiction between David Crockford's JSON checker test vectors (in
|
52
|
+
tests/fixtures) and RFC4627, though. I decided to stick to the RFC, because
|
53
|
+
the JSON checker seems to be a bit older than the RFC.
|
54
|
+
* Extended license to Ruby License, which includes the GPL.
|
55
|
+
* Added keyboard shortcuts, and 'Open location' menu item to edit_json.rb.
|
56
|
+
2007-05-09 (1.0.4)
|
57
|
+
* Applied a patch from Yui NARUSE <naruse@airemix.com> to make JSON compile
|
58
|
+
under Ruby 1.9. Thank you very much for mailing it to me!
|
59
|
+
* Made binary variants of JSON fail early, instead of falling back to the
|
60
|
+
pure version. This should avoid overshadowing of eventual problems while
|
61
|
+
loading of the binary.
|
62
|
+
2007-03-24 (1.0.3)
|
63
|
+
* Improved performance of pure variant a bit.
|
64
|
+
* The ext variant of this release supports the mswin32 platform. Ugh!
|
65
|
+
2007-03-24 (1.0.2)
|
66
|
+
* Ext Parser didn't parse 0e0 correctly into 0.0: Fixed!
|
67
|
+
2007-03-24 (1.0.1)
|
68
|
+
* Forgot some object files in the build dir. I really like that - not!
|
69
|
+
2007-03-24 (1.0.0)
|
70
|
+
* Added C implementations for the JSON generator and a ragel based JSON
|
71
|
+
parser in C.
|
72
|
+
* Much more tests, especially fixtures from json.org.
|
73
|
+
* Further improved conformance to RFC4627.
|
74
|
+
2007-02-09 (0.4.3)
|
75
|
+
* Conform more to RFC4627 for JSON: This means JSON strings
|
76
|
+
now always must contain exactly one object "{ ... }" or array "[ ... ]" in
|
77
|
+
order to be parsed without raising an exception. The definition of what
|
78
|
+
constitutes a whitespace is narrower in JSON than in Ruby ([ \t\r\n]), and
|
79
|
+
there are differences in floats and integers (no octals or hexadecimals) as
|
80
|
+
well.
|
81
|
+
* Added aliases generate and pretty_generate of unparse and pretty_unparse.
|
82
|
+
* Fixed a test case.
|
83
|
+
* Catch an Iconv::InvalidEncoding exception, that seems to occur on some Sun
|
84
|
+
boxes with SunOS 5.8, if iconv doesn't support utf16 conversions. This was
|
85
|
+
reported by Andrew R Jackson <andrewj@bcm.tmc.edu>, thanks a bunch!
|
86
|
+
2006-08-25 (0.4.2)
|
87
|
+
* Fixed a bug in handling solidi (/-characters), that was reported by
|
88
|
+
Kevin Gilpin <kevin.gilpin@alum.mit.edu>.
|
89
|
+
2006-02-06 (0.4.1)
|
90
|
+
* Fixed a bug related to escaping with backslashes. Thanks for the report go
|
91
|
+
to Florian Munz <surf@theflow.de>.
|
92
|
+
2005-09-23 (0.4.0)
|
93
|
+
* Initial Rubyforge Version
|