From ecf64d6dedb3ec4ac6d54f1922032c901cf4e24f Mon Sep 17 00:00:00 2001 From: Michel Boudreau Date: Thu, 31 May 2018 12:30:15 +1000 Subject: [PATCH] fix(windows-path): prevent locale file paths to be parsed by URI to stop errors in windows paths like spaces in paths --- lib/pact/consumer_contract/pact_file.rb | 46 +++++++++++-------------- 1 file changed, 21 insertions(+), 25 deletions(-) diff --git a/lib/pact/consumer_contract/pact_file.rb b/lib/pact/consumer_contract/pact_file.rb index a1fe400..81e30ca 100644 --- a/lib/pact/consumer_contract/pact_file.rb +++ b/lib/pact/consumer_contract/pact_file.rb @@ -36,39 +36,25 @@ def save_pactfile_to_tmp pact, name end def render_pact(uri_string, options) - uri_obj = URI(windows_safe(uri_string)) - if uri_obj.userinfo - options[:username] = uri_obj.user unless options[:username] - options[:password] = uri_obj.password unless options[:password] - end - get(uri_obj, options) + local?(uri_string) ? get_local(uri_string, options) : get_remote_with_retry(uri_string, options) end private - - def get(uri, options) - local?(uri) ? get_local(uri, options) : get_remote_with_retry(uri, options) - end - + def local? uri - !uri.host + !uri.start_with?("http://", "https://") end - def get_local(uri, _) - File.read uri.to_s + def get_local(filepath, _) + File.read windows_safe(filepath) end - def get_remote(uri, options) - request = Net::HTTP::Get.new(uri) - request.basic_auth(options[:username], options[:password]) if options[:username] - Net::HTTP.start(uri.host, uri.port, use_ssl: uri.scheme == 'https') do |http| - http.open_timeout = options[:open_timeout] || OPEN_TIMEOUT - http.read_timeout = options[:read_timeout] || READ_TIMEOUT - http.request(request) - end - end - - def get_remote_with_retry(uri, options) + def get_remote_with_retry(uri_string, options) + uri = URI(uri_string) + if uri.userinfo + options[:username] = uri.user unless options[:username] + options[:password] = uri.password unless options[:password] + end ((options[:retry_limit] || RETRY_LIMIT) + 1).times do |i| begin response = get_remote(uri, options) @@ -88,6 +74,16 @@ def get_remote_with_retry(uri, options) end end end + + def get_remote(uri, options) + request = Net::HTTP::Get.new(uri) + request.basic_auth(options[:username], options[:password]) if options[:username] + Net::HTTP.start(uri.host, uri.port, use_ssl: uri.scheme == 'https') do |http| + http.open_timeout = options[:open_timeout] || OPEN_TIMEOUT + http.read_timeout = options[:read_timeout] || READ_TIMEOUT + http.request(request) + end + end def success?(response) response.code.to_i == 200