forked from bblimke/webmock
-
Notifications
You must be signed in to change notification settings - Fork 0
/
patron_spec.rb
82 lines (66 loc) · 2.7 KB
/
patron_spec.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
require File.expand_path(File.dirname(__FILE__) + '/spec_helper')
require 'webmock_shared'
unless RUBY_PLATFORM =~ /java/
require 'patron_spec_helper'
require 'tmpdir'
require 'fileutils'
describe "Webmock with Patron" do
include PatronSpecHelper
it_should_behave_like "WebMock"
describe "when custom functionality is used" do
before(:each) do
@sess = Patron::Session.new
@sess.base_url = "http://www.example.com"
end
describe "file requests" do
before(:each) do
@dir_path = Dir.mktmpdir('webmock-')
@file_path = File.join(@dir_path, "webmock_temp_test_file")
FileUtils.rm_rf(@file_path) if File.exists?(@file_path)
end
after(:each) do
FileUtils.rm_rf(@dir_path) if File.exist?(@dir_path)
end
it "should work with get_file" do
stub_http_request(:get, "www.example.com").to_return(:body => "abc")
@sess.get_file("/", @file_path)
File.read(@file_path).should == "abc"
end
it "should raise same error as Patron if file is not readable for get request" do
stub_http_request(:get, "www.example.com")
lambda {
@sess.get_file("/", "/non_existing_file")
}.should raise_error(ArgumentError, "Unable to open specified file.")
end
it "should work with put_file" do
File.open(@file_path, "w") {|f| f.write "abc"}
stub_http_request(:put, "www.example.com").with(:body => "abc")
@sess.put_file("/", @file_path)
end
it "should work with post_file" do
File.open(@file_path, "w") {|f| f.write "abc"}
stub_http_request(:post, "www.example.com").with(:body => "abc")
@sess.post_file("/", @file_path)
end
it "should raise same error as Patron if file is not readable for post request" do
stub_http_request(:post, "www.example.com").with(:body => "abc")
lambda {
@sess.post_file("/", "/non_existing_file")
}.should raise_error(ArgumentError, "Unable to open specified file.")
end
end
describe "handling errors same way as patron" do
it "should raise error if put request has neither upload_data nor file_name" do
stub_http_request(:post, "www.example.com")
lambda {
@sess.post("/", nil)
}.should raise_error(ArgumentError, "Must provide either data or a filename when doing a PUT or POST")
end
end
it "should work with WebDAV copy request" do
stub_http_request(:copy, "www.example.com/abc").with(:headers => {'Destination' => "/def"})
@sess.copy("/abc", "/def")
end
end
end
end