diff --git a/lib/stripe/singleton_api_resource.rb b/lib/stripe/singleton_api_resource.rb index 44746eec9..205edbbc4 100644 --- a/lib/stripe/singleton_api_resource.rb +++ b/lib/stripe/singleton_api_resource.rb @@ -17,24 +17,24 @@ def resource_url self.class.resource_url end - def self.retrieve(paramsOrOpts = {}, definitelyOpts = nil) + def self.retrieve(params_or_opts = {}, definitely_opts = nil) opts = nil params = nil - if !definitelyOpts.nil? - opts = definitelyOpts - params = paramsOrOpts - else - unrecognized_key = paramsOrOpts.keys.find { |k| !Util::OPTS_USER_SPECIFIED.include?(k) } - if unrecognized_key + 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 second argument. For example: .retrieve({#{unrecognized_key}: 'foo'}, {})" + "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 second argument. " \ + "For example: .retrieve({#{unrecognized_key}: 'foo'}, {})" end - opts = paramsOrOpts + opts = params_or_opts + else + opts = definitely_opts + params = params_or_opts end - instance = new(params, Util.normalize_opts(opts)) instance.refresh instance diff --git a/test/stripe/balance_test.rb b/test/stripe/balance_test.rb index 4c99dc23d..3879ed7b6 100644 --- a/test/stripe/balance_test.rb +++ b/test/stripe/balance_test.rb @@ -10,7 +10,7 @@ class BalanceTest < Test::Unit::TestCase assert balance.is_a?(Stripe::Balance) end should "be retrievable with opts only" do - balance = Stripe::Balance.retrieve({stripe_account: "acct_123"}) + balance = Stripe::Balance.retrieve({ stripe_account: "acct_123" }) assert_requested :get, "#{Stripe.api_base}/v1/balance" do |req| assert_equal("acct_123", req.headers["Stripe-Account"]) true @@ -18,7 +18,7 @@ class BalanceTest < Test::Unit::TestCase assert balance.is_a?(Stripe::Balance) end should "be retrievable with opts and params" do - balance = Stripe::Balance.retrieve({expand: ["available"]}, {stripe_account: "acct_123"}) + balance = Stripe::Balance.retrieve({ expand: ["available"] }, { stripe_account: "acct_123" }) assert_requested :get, "#{Stripe.api_base}/v1/balance?expand[]=available" do |req| assert_equal("acct_123", req.headers["Stripe-Account"]) true @@ -26,7 +26,7 @@ class BalanceTest < Test::Unit::TestCase assert balance.is_a?(Stripe::Balance) end should "be retrievable with params and an explicitly empty opts" do - balance = Stripe::Balance.retrieve({expand: ["available"]}, {}) + balance = Stripe::Balance.retrieve({ expand: ["available"] }, {}) assert_requested :get, "#{Stripe.api_base}/v1/balance?expand[]=available" do |req| assert_nil(req.headers["Stripe-Account"]) true @@ -35,7 +35,7 @@ class BalanceTest < Test::Unit::TestCase end should "warn you if you are attempting to pass only params" do exception = assert_raises(ArgumentError) do - Stripe::Balance.retrieve({expand: ["available"]}) + Stripe::Balance.retrieve({ expand: ["available"] }) end assert_match(/Unrecognized request option/, exception.message) end