From 96f2924c85b7ad09eb5095f0688eb64b0e5ac1b5 Mon Sep 17 00:00:00 2001 From: Nick Carboni Date: Fri, 16 Nov 2018 15:16:59 -0500 Subject: [PATCH] Merge pull request #18210 from yrudman/accept-hash-object-as-result-of-inter-region-api-invocation Accept Hash object as result of inter region api invocation (cherry picked from commit 0f8599059c5cb192be92e3dc7fbb10382874ba56) Fixes https://bugzilla.redhat.com/show_bug.cgi?id=1650335 --- app/models/mixins/inter_region_api_method_relay.rb | 5 +++++ spec/models/mixins/inter_region_api_method_relay_spec.rb | 5 +++++ 2 files changed, 10 insertions(+) diff --git a/app/models/mixins/inter_region_api_method_relay.rb b/app/models/mixins/inter_region_api_method_relay.rb index 6327d506999..abddb73c7a9 100644 --- a/app/models/mixins/inter_region_api_method_relay.rb +++ b/app/models/mixins/inter_region_api_method_relay.rb @@ -80,6 +80,11 @@ def self.exec_api_call(region, collection_name, action, api_args = nil, id = nil result.attributes when ManageIQ::API::Client::Resource instance_for_resource(result) + when Hash + # Some of API invocation returning Hash object + # Example: retire_resource for Service + _log.warn("remote API invocation returned Hash object") + result else raise InterRegionApiMethodRelayError, "Got unexpected API result object #{result.class}" end diff --git a/spec/models/mixins/inter_region_api_method_relay_spec.rb b/spec/models/mixins/inter_region_api_method_relay_spec.rb index 4fb538fbfce..057cf499f17 100644 --- a/spec/models/mixins/inter_region_api_method_relay_spec.rb +++ b/spec/models/mixins/inter_region_api_method_relay_spec.rb @@ -228,6 +228,11 @@ def expect_api_call(expected_action, expected_args = nil) }.to raise_error(described_class::InterRegionApiMethodRelayError) end + it "accepts Hash object as api result" do + expect(api_collection).to receive(action).and_return({}) + expect { described_class.exec_api_call(region, collection_name, action) }.not_to raise_error + end + it "calls the given action with the given args" do args = {:my => "args", :here => 123} expect(api_collection).to receive(action).with(args).and_return(api_success_result)