mirror of
https://github.com/stripe/stripe-ruby.git
synced 2025-10-04 00:00:47 -04:00
191 lines
6.1 KiB
Ruby
191 lines
6.1 KiB
Ruby
require File.expand_path("../../test_helper", __FILE__)
|
|
|
|
module Stripe
|
|
class AccountTest < Test::Unit::TestCase
|
|
should "be listable" do
|
|
accounts = Stripe::Account.list
|
|
assert_requested :get, "#{Stripe.api_base}/v1/accounts"
|
|
assert accounts.data.is_a?(Array)
|
|
assert accounts.data[0].is_a?(Stripe::Account)
|
|
end
|
|
|
|
should "be retrievable using singular endpoint" do
|
|
account = Stripe::Account.retrieve
|
|
assert_requested :get, "#{Stripe.api_base}/v1/account"
|
|
assert account.is_a?(Stripe::Account)
|
|
end
|
|
|
|
should "be retrievable using plural endpoint" do
|
|
account = Stripe::Account.retrieve("acct_123")
|
|
assert_requested :get, "#{Stripe.api_base}/v1/accounts/acct_123"
|
|
assert account.is_a?(Stripe::Account)
|
|
end
|
|
|
|
should "be rejectable" do
|
|
account_data = { id: "acct_foo" }
|
|
stub_request(:get, "#{Stripe.api_base}/v1/accounts/acct_foo")
|
|
.to_return(body: JSON.generate(account_data))
|
|
|
|
stub_request(:post, "#{Stripe.api_base}/v1/accounts/acct_foo/reject")
|
|
.to_return(body: JSON.generate(account_data))
|
|
|
|
account = Stripe::Account.retrieve("acct_foo")
|
|
account.reject(reason: "fraud")
|
|
end
|
|
|
|
should "be creatable" do
|
|
account = Stripe::Account.create(metadata: {}, type: "standard")
|
|
assert_requested :post, "#{Stripe.api_base}/v1/accounts"
|
|
assert account.is_a?(Stripe::Account)
|
|
end
|
|
|
|
should "be saveable" do
|
|
account = Stripe::Account.retrieve("acct_123")
|
|
account.metadata["key"] = "value"
|
|
account.save
|
|
assert_requested :post, "#{Stripe.api_base}/v1/accounts/#{account.id}"
|
|
end
|
|
|
|
should "be updateable" do
|
|
account = Stripe::Account.update("acct_123", metadata: { foo: "bar" })
|
|
assert_requested :post, "#{Stripe.api_base}/v1/accounts/acct_123"
|
|
assert account.is_a?(Stripe::Account)
|
|
end
|
|
|
|
should "be deletable" do
|
|
account = Stripe::Account.retrieve("acct_123")
|
|
account = account.delete
|
|
assert_requested :delete, "#{Stripe.api_base}/v1/accounts/#{account.id}"
|
|
assert account.is_a?(Stripe::Account)
|
|
end
|
|
|
|
context "#bank_account=" do
|
|
should "warn that #bank_account= is deprecated" do
|
|
old_stderr = $stderr
|
|
$stderr = StringIO.new
|
|
begin
|
|
account = Stripe::Account.retrieve("acct_123")
|
|
account.bank_account = "tok_123"
|
|
message = "NOTE: Stripe::Account#bank_account= is " \
|
|
"deprecated; use #external_account= instead"
|
|
assert_match Regexp.new(message), $stderr.string
|
|
ensure
|
|
$stderr = old_stderr
|
|
end
|
|
end
|
|
end
|
|
|
|
context "#deauthorize" do
|
|
should "deauthorize an account" do
|
|
account = Stripe::Account.retrieve("acct_123")
|
|
|
|
# Unfortunately, the OpenAPI spec doesn't yet cover anything under the
|
|
# Connect endpoints, so for just stub this out with Webmock.
|
|
stub_request(:post, "#{Stripe.connect_base}/oauth/deauthorize")
|
|
.with(body: { "client_id" => "ca_1234", "stripe_user_id" => account.id })
|
|
.to_return(body: JSON.generate("stripe_user_id" => account.id))
|
|
account.deauthorize("ca_1234", "sk_test_1234")
|
|
end
|
|
end
|
|
|
|
context "#legal_entity=" do
|
|
should "disallow direct overrides" do
|
|
account = Stripe::Account.retrieve("acct_123")
|
|
|
|
assert_raise NoMethodError do
|
|
account.legal_entity = { first_name: "Blah" }
|
|
end
|
|
|
|
account.legal_entity.first_name = "Blah"
|
|
end
|
|
end
|
|
|
|
context "#serialize_params" do
|
|
should "serialize an a new additional_owners" do
|
|
obj = Stripe::Util.convert_to_stripe_object({
|
|
object: "account",
|
|
legal_entity: Stripe::StripeObject.construct_from({
|
|
}),
|
|
}, {})
|
|
obj.legal_entity.additional_owners = [
|
|
{ first_name: "Joe" },
|
|
{ first_name: "Jane" },
|
|
]
|
|
|
|
expected = {
|
|
legal_entity: {
|
|
additional_owners: {
|
|
"0" => { first_name: "Joe" },
|
|
"1" => { first_name: "Jane" },
|
|
},
|
|
},
|
|
}
|
|
assert_equal(expected, obj.serialize_params)
|
|
end
|
|
|
|
should "serialize on an partially changed additional_owners" do
|
|
obj = Stripe::Util.convert_to_stripe_object({
|
|
object: "account",
|
|
legal_entity: {
|
|
additional_owners: [
|
|
Stripe::StripeObject.construct_from(first_name: "Joe"),
|
|
Stripe::StripeObject.construct_from(first_name: "Jane"),
|
|
],
|
|
},
|
|
}, {})
|
|
obj.legal_entity.additional_owners[1].first_name = "Stripe"
|
|
|
|
expected = {
|
|
legal_entity: {
|
|
additional_owners: {
|
|
"1" => { first_name: "Stripe" },
|
|
},
|
|
},
|
|
}
|
|
assert_equal(expected, obj.serialize_params)
|
|
end
|
|
|
|
should "serialize on an unchanged additional_owners" do
|
|
obj = Stripe::Util.convert_to_stripe_object({
|
|
object: "account",
|
|
legal_entity: {
|
|
additional_owners: [
|
|
Stripe::StripeObject.construct_from(first_name: "Joe"),
|
|
Stripe::StripeObject.construct_from(first_name: "Jane"),
|
|
],
|
|
},
|
|
}, {})
|
|
|
|
expected = {
|
|
legal_entity: {
|
|
additional_owners: {},
|
|
},
|
|
}
|
|
assert_equal(expected, obj.serialize_params)
|
|
end
|
|
|
|
# Note that the empty string that we send for this one has a special
|
|
# meaning for the server, which interprets it as an array unset.
|
|
should "serialize on an unset additional_owners" do
|
|
obj = Stripe::Util.convert_to_stripe_object({
|
|
object: "account",
|
|
legal_entity: {
|
|
additional_owners: [
|
|
Stripe::StripeObject.construct_from(first_name: "Joe"),
|
|
Stripe::StripeObject.construct_from(first_name: "Jane"),
|
|
],
|
|
},
|
|
}, {})
|
|
obj.legal_entity.additional_owners = nil
|
|
|
|
expected = {
|
|
legal_entity: {
|
|
additional_owners: "",
|
|
},
|
|
}
|
|
assert_equal(expected, obj.serialize_params)
|
|
end
|
|
end
|
|
end
|
|
end
|