diff --git a/lib/stripe/api_operations/nested_resource.rb b/lib/stripe/api_operations/nested_resource.rb index 09b570944..bfb741da9 100644 --- a/lib/stripe/api_operations/nested_resource.rb +++ b/lib/stripe/api_operations/nested_resource.rb @@ -53,12 +53,29 @@ def nested_resource_class_methods(resource, path: nil, operations: nil, ) end when :retrieve + # TODO: (Major) Split params_or_opts to params and opts and get rid of the complicated way to add params define_singleton_method(:"retrieve_#{resource}") \ - do |id, nested_id, opts = {}| + do |id, nested_id, params_or_opts = {}, definitely_opts = nil| + opts = nil + params = nil + if definitely_opts.nil? + unrecognized_key = params_or_opts.keys.find { |k| !Util::OPTS_USER_SPECIFIED.include?(k) } + if unrecognized_key + raise ArgumentError, + "Unrecognized request option: #{unrecognized_key}. Did you mean to specify this as retrieve params? " \ + "If so, you must explicitly pass an opts hash as a third argument. " \ + "For example: .retrieve({#{unrecognized_key}: 'foo'}, {})" + end + + opts = params_or_opts + else + opts = definitely_opts + params = params_or_opts + end request_stripe_object( method: :get, path: send(resource_url_method, id, nested_id), - params: {}, + params: params, opts: opts ) end diff --git a/test/stripe/transfer_test.rb b/test/stripe/transfer_test.rb index e3fb068fc..ae99c4f8b 100644 --- a/test/stripe/transfer_test.rb +++ b/test/stripe/transfer_test.rb @@ -84,5 +84,16 @@ class TransferTest < Test::Unit::TestCase assert reversals.data.is_a?(Array) end end + + should "retrieve a reversal with expand" do + reversal = Stripe::Transfer.retrieve_reversal( + "tr_123", + "trr_123", + {expand: %w[transfer]}, + {} + ) + assert_requested :get, "#{Stripe.api_base}/v1/transfers/tr_123/reversals/trr_123?expand%5B%5D=transfer" + assert reversal.is_a?(Stripe::Reversal) + end end end