stripe 3.8.2 → 5.45.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (214) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.md +424 -1
  3. data/CODE_OF_CONDUCT.md +77 -0
  4. data/Gemfile +15 -20
  5. data/README.md +201 -58
  6. data/Rakefile +12 -9
  7. data/VERSION +1 -1
  8. data/bin/stripe-console +3 -1
  9. data/lib/stripe/api_operations/create.rb +3 -1
  10. data/lib/stripe/api_operations/delete.rb +30 -2
  11. data/lib/stripe/api_operations/list.rb +3 -12
  12. data/lib/stripe/api_operations/nested_resource.rb +40 -28
  13. data/lib/stripe/api_operations/request.rb +83 -9
  14. data/lib/stripe/api_operations/save.rb +19 -7
  15. data/lib/stripe/api_resource.rb +65 -4
  16. data/lib/stripe/connection_manager.rb +200 -0
  17. data/lib/stripe/error_object.rb +93 -0
  18. data/lib/stripe/errors.rb +47 -19
  19. data/lib/stripe/instrumentation.rb +84 -0
  20. data/lib/stripe/list_object.rb +43 -7
  21. data/lib/stripe/multipart_encoder.rb +131 -0
  22. data/lib/stripe/oauth.rb +14 -7
  23. data/lib/stripe/object_types.rb +110 -0
  24. data/lib/stripe/{account.rb → resources/account.rb} +60 -28
  25. data/lib/stripe/resources/account_link.rb +10 -0
  26. data/lib/stripe/resources/alipay_account.rb +34 -0
  27. data/lib/stripe/{apple_pay_domain.rb → resources/apple_pay_domain.rb} +4 -1
  28. data/lib/stripe/resources/application_fee.rb +14 -0
  29. data/lib/stripe/resources/application_fee_refund.rb +31 -0
  30. data/lib/stripe/resources/balance.rb +8 -0
  31. data/lib/stripe/resources/balance_transaction.rb +10 -0
  32. data/lib/stripe/resources/bank_account.rb +43 -0
  33. data/lib/stripe/resources/billing_portal/configuration.rb +14 -0
  34. data/lib/stripe/resources/billing_portal/session.rb +12 -0
  35. data/lib/stripe/{bitcoin_receiver.rb → resources/bitcoin_receiver.rb} +6 -6
  36. data/lib/stripe/resources/bitcoin_transaction.rb +16 -0
  37. data/lib/stripe/resources/capability.rb +34 -0
  38. data/lib/stripe/{card.rb → resources/card.rb} +15 -4
  39. data/lib/stripe/resources/charge.rb +23 -0
  40. data/lib/stripe/resources/checkout/session.rb +27 -0
  41. data/lib/stripe/resources/country_spec.rb +10 -0
  42. data/lib/stripe/{coupon.rb → resources/coupon.rb} +5 -2
  43. data/lib/stripe/resources/credit_note.rb +33 -0
  44. data/lib/stripe/resources/credit_note_line_item.rb +8 -0
  45. data/lib/stripe/resources/customer.rb +52 -0
  46. data/lib/stripe/resources/customer_balance_transaction.rb +31 -0
  47. data/lib/stripe/resources/discount.rb +8 -0
  48. data/lib/stripe/resources/dispute.rb +22 -0
  49. data/lib/stripe/resources/ephemeral_key.rb +20 -0
  50. data/lib/stripe/resources/event.rb +10 -0
  51. data/lib/stripe/resources/exchange_rate.rb +10 -0
  52. data/lib/stripe/resources/file.rb +36 -0
  53. data/lib/stripe/resources/file_link.rb +12 -0
  54. data/lib/stripe/resources/identity/verification_report.rb +12 -0
  55. data/lib/stripe/resources/identity/verification_session.rb +35 -0
  56. data/lib/stripe/resources/invoice.rb +74 -0
  57. data/lib/stripe/{invoice_item.rb → resources/invoice_item.rb} +5 -2
  58. data/lib/stripe/resources/invoice_line_item.rb +8 -0
  59. data/lib/stripe/resources/issuing/authorization.rb +34 -0
  60. data/lib/stripe/resources/issuing/card.rb +25 -0
  61. data/lib/stripe/resources/issuing/card_details.rb +10 -0
  62. data/lib/stripe/resources/issuing/cardholder.rb +14 -0
  63. data/lib/stripe/resources/issuing/dispute.rb +25 -0
  64. data/lib/stripe/resources/issuing/transaction.rb +13 -0
  65. data/lib/stripe/resources/line_item.rb +8 -0
  66. data/lib/stripe/resources/login_link.rb +15 -0
  67. data/lib/stripe/resources/mandate.rb +8 -0
  68. data/lib/stripe/resources/order.rb +33 -0
  69. data/lib/stripe/resources/order_return.rb +10 -0
  70. data/lib/stripe/resources/payment_intent.rb +53 -0
  71. data/lib/stripe/resources/payment_link.rb +23 -0
  72. data/lib/stripe/resources/payment_method.rb +33 -0
  73. data/lib/stripe/resources/payout.rb +33 -0
  74. data/lib/stripe/resources/person.rb +32 -0
  75. data/lib/stripe/{plan.rb → resources/plan.rb} +4 -1
  76. data/lib/stripe/resources/price.rb +12 -0
  77. data/lib/stripe/{product.rb → resources/product.rb} +6 -3
  78. data/lib/stripe/resources/promotion_code.rb +12 -0
  79. data/lib/stripe/resources/quote.rb +105 -0
  80. data/lib/stripe/resources/radar/early_fraud_warning.rb +12 -0
  81. data/lib/stripe/resources/radar/value_list.rb +15 -0
  82. data/lib/stripe/resources/radar/value_list_item.rb +14 -0
  83. data/lib/stripe/{recipient.rb → resources/recipient.rb} +5 -6
  84. data/lib/stripe/resources/recipient_transfer.rb +7 -0
  85. data/lib/stripe/{refund.rb → resources/refund.rb} +4 -1
  86. data/lib/stripe/resources/reporting/report_run.rb +13 -0
  87. data/lib/stripe/resources/reporting/report_type.rb +13 -0
  88. data/lib/stripe/resources/reversal.rb +30 -0
  89. data/lib/stripe/resources/review.rb +21 -0
  90. data/lib/stripe/resources/setup_attempt.rb +10 -0
  91. data/lib/stripe/resources/setup_intent.rb +43 -0
  92. data/lib/stripe/resources/shipping_rate.rb +12 -0
  93. data/lib/stripe/resources/sigma/scheduled_query_run.rb +16 -0
  94. data/lib/stripe/{sku.rb → resources/sku.rb} +6 -3
  95. data/lib/stripe/resources/source.rb +47 -0
  96. data/lib/stripe/resources/source_transaction.rb +8 -0
  97. data/lib/stripe/resources/subscription.rb +26 -0
  98. data/lib/stripe/resources/subscription_item.rb +26 -0
  99. data/lib/stripe/resources/subscription_schedule.rb +33 -0
  100. data/lib/stripe/resources/tax_code.rb +10 -0
  101. data/lib/stripe/resources/tax_id.rb +27 -0
  102. data/lib/stripe/resources/tax_rate.rb +12 -0
  103. data/lib/stripe/resources/terminal/connection_token.rb +12 -0
  104. data/lib/stripe/resources/terminal/location.rb +15 -0
  105. data/lib/stripe/resources/terminal/reader.rb +15 -0
  106. data/lib/stripe/resources/test_helpers/test_clock.rb +25 -0
  107. data/lib/stripe/{three_d_secure.rb → resources/three_d_secure.rb} +4 -1
  108. data/lib/stripe/resources/token.rb +10 -0
  109. data/lib/stripe/resources/topup.rb +23 -0
  110. data/lib/stripe/resources/transfer.rb +27 -0
  111. data/lib/stripe/resources/usage_record.rb +8 -0
  112. data/lib/stripe/resources/usage_record_summary.rb +8 -0
  113. data/lib/stripe/resources/webhook_endpoint.rb +13 -0
  114. data/lib/stripe/resources.rb +93 -0
  115. data/lib/stripe/singleton_api_resource.rb +8 -2
  116. data/lib/stripe/stripe_client.rb +712 -233
  117. data/lib/stripe/stripe_configuration.rb +194 -0
  118. data/lib/stripe/stripe_object.rb +180 -67
  119. data/lib/stripe/stripe_response.rb +89 -27
  120. data/lib/stripe/util.rb +87 -168
  121. data/lib/stripe/version.rb +3 -1
  122. data/lib/stripe/webhook.rb +45 -10
  123. data/lib/stripe.rb +47 -160
  124. data/stripe.gemspec +27 -8
  125. metadata +112 -178
  126. data/.gitattributes +0 -4
  127. data/.github/ISSUE_TEMPLATE.md +0 -5
  128. data/.gitignore +0 -6
  129. data/.rubocop.yml +0 -20
  130. data/.rubocop_todo.yml +0 -60
  131. data/.travis.yml +0 -38
  132. data/lib/stripe/alipay_account.rb +0 -25
  133. data/lib/stripe/application_fee.rb +0 -25
  134. data/lib/stripe/application_fee_refund.rb +0 -20
  135. data/lib/stripe/balance.rb +0 -5
  136. data/lib/stripe/balance_transaction.rb +0 -11
  137. data/lib/stripe/bank_account.rb +0 -30
  138. data/lib/stripe/bitcoin_transaction.rb +0 -13
  139. data/lib/stripe/charge.rb +0 -82
  140. data/lib/stripe/country_spec.rb +0 -11
  141. data/lib/stripe/customer.rb +0 -88
  142. data/lib/stripe/dispute.rb +0 -17
  143. data/lib/stripe/ephemeral_key.rb +0 -18
  144. data/lib/stripe/event.rb +0 -7
  145. data/lib/stripe/exchange_rate.rb +0 -11
  146. data/lib/stripe/file_upload.rb +0 -35
  147. data/lib/stripe/invoice.rb +0 -30
  148. data/lib/stripe/invoice_line_item.rb +0 -5
  149. data/lib/stripe/login_link.rb +0 -9
  150. data/lib/stripe/order.rb +0 -35
  151. data/lib/stripe/order_return.rb +0 -11
  152. data/lib/stripe/payout.rb +0 -18
  153. data/lib/stripe/recipient_transfer.rb +0 -5
  154. data/lib/stripe/reversal.rb +0 -20
  155. data/lib/stripe/source.rb +0 -36
  156. data/lib/stripe/source_transaction.rb +0 -5
  157. data/lib/stripe/subscription.rb +0 -43
  158. data/lib/stripe/subscription_item.rb +0 -14
  159. data/lib/stripe/token.rb +0 -7
  160. data/lib/stripe/transfer.rb +0 -21
  161. data/test/api_stub_helpers.rb +0 -0
  162. data/test/stripe/account_external_accounts_operations_test.rb +0 -66
  163. data/test/stripe/account_login_links_operations_test.rb +0 -19
  164. data/test/stripe/account_test.rb +0 -190
  165. data/test/stripe/alipay_account_test.rb +0 -35
  166. data/test/stripe/api_operations_test.rb +0 -76
  167. data/test/stripe/api_resource_test.rb +0 -522
  168. data/test/stripe/apple_pay_domain_test.rb +0 -31
  169. data/test/stripe/application_fee_refund_test.rb +0 -35
  170. data/test/stripe/application_fee_refunds_operations_test.rb +0 -54
  171. data/test/stripe/application_fee_test.rb +0 -12
  172. data/test/stripe/balance_test.rb +0 -11
  173. data/test/stripe/bank_account_test.rb +0 -34
  174. data/test/stripe/charge_test.rb +0 -57
  175. data/test/stripe/country_spec_test.rb +0 -18
  176. data/test/stripe/coupon_test.rb +0 -42
  177. data/test/stripe/customer_card_test.rb +0 -42
  178. data/test/stripe/customer_sources_operations_test.rb +0 -66
  179. data/test/stripe/customer_test.rb +0 -113
  180. data/test/stripe/dispute_test.rb +0 -40
  181. data/test/stripe/ephemeral_key_test.rb +0 -84
  182. data/test/stripe/errors_test.rb +0 -18
  183. data/test/stripe/exchange_rate_test.rb +0 -18
  184. data/test/stripe/file_upload_test.rb +0 -83
  185. data/test/stripe/invoice_item_test.rb +0 -53
  186. data/test/stripe/invoice_line_item_test.rb +0 -6
  187. data/test/stripe/invoice_test.rb +0 -111
  188. data/test/stripe/list_object_test.rb +0 -154
  189. data/test/stripe/login_link_test.rb +0 -35
  190. data/test/stripe/oauth_test.rb +0 -77
  191. data/test/stripe/order_return_test.rb +0 -19
  192. data/test/stripe/order_test.rb +0 -57
  193. data/test/stripe/payout_test.rb +0 -48
  194. data/test/stripe/plan_test.rb +0 -50
  195. data/test/stripe/product_test.rb +0 -45
  196. data/test/stripe/recipient_test.rb +0 -47
  197. data/test/stripe/refund_test.rb +0 -37
  198. data/test/stripe/reversal_test.rb +0 -41
  199. data/test/stripe/sku_test.rb +0 -48
  200. data/test/stripe/source_test.rb +0 -84
  201. data/test/stripe/source_transaction_test.rb +0 -28
  202. data/test/stripe/stripe_client_test.rb +0 -728
  203. data/test/stripe/stripe_object_test.rb +0 -448
  204. data/test/stripe/stripe_response_test.rb +0 -47
  205. data/test/stripe/subscription_item_test.rb +0 -52
  206. data/test/stripe/subscription_test.rb +0 -104
  207. data/test/stripe/three_d_secure_test.rb +0 -21
  208. data/test/stripe/transfer_reversals_operations_test.rb +0 -55
  209. data/test/stripe/transfer_test.rb +0 -41
  210. data/test/stripe/util_test.rb +0 -432
  211. data/test/stripe/webhook_test.rb +0 -94
  212. data/test/stripe_test.rb +0 -59
  213. data/test/test_data.rb +0 -59
  214. data/test/test_helper.rb +0 -60
data/lib/stripe/source.rb DELETED
@@ -1,36 +0,0 @@
1
- module Stripe
2
- class Source < APIResource
3
- extend Stripe::APIOperations::Create
4
- include Stripe::APIOperations::Save
5
-
6
- OBJECT_NAME = "source".freeze
7
-
8
- def detach(params = {}, opts = {})
9
- if !respond_to?(:customer) || customer.nil? || customer.empty?
10
- raise NotImplementedError,
11
- "This source object does not appear to be currently attached " \
12
- "to a customer object."
13
- end
14
-
15
- url = "#{Customer.resource_url}/#{CGI.escape(customer)}/sources/#{CGI.escape(id)}"
16
- resp, opts = request(:delete, url, params, Util.normalize_opts(opts))
17
- initialize_from(resp.data, opts)
18
- end
19
-
20
- def delete(params = {}, opts = {})
21
- detach(params, opts)
22
- end
23
- extend Gem::Deprecate
24
- deprecate :delete, "#detach", 2017, 10
25
-
26
- def source_transactions(params = {}, opts = {})
27
- resp, opts = request(:get, resource_url + "/source_transactions", params, Util.normalize_opts(opts))
28
- Util.convert_to_stripe_object(resp.data, opts)
29
- end
30
-
31
- def verify(params = {}, opts = {})
32
- resp, opts = request(:post, resource_url + "/verify", params, Util.normalize_opts(opts))
33
- initialize_from(resp.data, opts)
34
- end
35
- end
36
- end
@@ -1,5 +0,0 @@
1
- module Stripe
2
- class SourceTransaction < StripeObject
3
- OBJECT_NAME = "source_transaction".freeze
4
- end
5
- end
@@ -1,43 +0,0 @@
1
- module Stripe
2
- class Subscription < APIResource
3
- extend Stripe::APIOperations::List
4
- extend Stripe::APIOperations::Create
5
- include Stripe::APIOperations::Save
6
- include Stripe::APIOperations::Delete
7
-
8
- OBJECT_NAME = "subscription".freeze
9
-
10
- save_nested_resource :source
11
-
12
- def delete_discount
13
- _, opts = request(:delete, discount_url)
14
- initialize_from({ discount: nil }, opts, true)
15
- end
16
-
17
- def self.update(id, params = {}, opts = {})
18
- params[:items] = Util.array_to_hash(params[:items]) if params[:items]
19
- super(id, params, opts)
20
- end
21
-
22
- def self.create(params = {}, opts = {})
23
- params[:items] = Util.array_to_hash(params[:items]) if params[:items]
24
- super(params, opts)
25
- end
26
-
27
- def serialize_params(options = {})
28
- update_hash = super
29
- if @unsaved_values.include?(:items)
30
- value = Util.array_to_hash(@values[:items])
31
- update_hash[:items] =
32
- serialize_params_value(value, nil, true, options[:force], key: :items)
33
- end
34
- update_hash
35
- end
36
-
37
- private
38
-
39
- def discount_url
40
- resource_url + "/discount"
41
- end
42
- end
43
- end
@@ -1,14 +0,0 @@
1
- module Stripe
2
- class SubscriptionItem < APIResource
3
- extend Stripe::APIOperations::Create
4
- include Stripe::APIOperations::Delete
5
- extend Stripe::APIOperations::List
6
- include Stripe::APIOperations::Save
7
-
8
- OBJECT_NAME = "subscription_item".freeze
9
-
10
- def self.resource_url
11
- "/v1/subscription_items"
12
- end
13
- end
14
- end
data/lib/stripe/token.rb DELETED
@@ -1,7 +0,0 @@
1
- module Stripe
2
- class Token < APIResource
3
- extend Stripe::APIOperations::Create
4
-
5
- OBJECT_NAME = "token".freeze
6
- end
7
- end
@@ -1,21 +0,0 @@
1
- module Stripe
2
- class Transfer < APIResource
3
- extend Stripe::APIOperations::List
4
- extend Stripe::APIOperations::Create
5
- include Stripe::APIOperations::Save
6
- extend Stripe::APIOperations::NestedResource
7
-
8
- OBJECT_NAME = "transfer".freeze
9
-
10
- nested_resource_class_methods :reversal, operations: %i[create retrieve update list]
11
-
12
- def cancel
13
- resp, api_key = request(:post, cancel_url)
14
- initialize_from(resp.data, api_key)
15
- end
16
-
17
- def cancel_url
18
- resource_url + "/cancel"
19
- end
20
- end
21
- end
File without changes
@@ -1,66 +0,0 @@
1
- require File.expand_path("../../test_helper", __FILE__)
2
-
3
- module Stripe
4
- class AccountExternalAccountsOperationsTest < Test::Unit::TestCase
5
- setup do
6
- @account_id = "acct_123"
7
- @external_account_id = "ba_123"
8
- end
9
-
10
- context "#create_external_account" do
11
- should "create an external account" do
12
- external_account = Stripe::Account.create_external_account(
13
- @account_id,
14
- external_account: "btok_123"
15
- )
16
- assert_requested :post, "#{Stripe.api_base}/v1/accounts/#{@account_id}/external_accounts"
17
- assert external_account.is_a?(Stripe::BankAccount)
18
- end
19
- end
20
-
21
- context "#retrieve_external_account" do
22
- should "retrieve an external account" do
23
- external_account = Stripe::Account.retrieve_external_account(
24
- @account_id,
25
- @external_account_id
26
- )
27
- assert_requested :get, "#{Stripe.api_base}/v1/accounts/#{@account_id}/external_accounts/#{@external_account_id}"
28
- assert external_account.is_a?(Stripe::BankAccount)
29
- end
30
- end
31
-
32
- context "#update_external_account" do
33
- should "update an external account" do
34
- external_account = Stripe::Account.update_external_account(
35
- @account_id,
36
- @external_account_id,
37
- metadata: { foo: "bar" }
38
- )
39
- assert_requested :post, "#{Stripe.api_base}/v1/accounts/#{@account_id}/external_accounts/#{@external_account_id}"
40
- assert external_account.is_a?(Stripe::BankAccount)
41
- end
42
- end
43
-
44
- context "#delete_external_account" do
45
- should "delete an external_account" do
46
- external_account = Stripe::Account.delete_external_account(
47
- @account_id,
48
- @external_account_id
49
- )
50
- assert_requested :delete, "#{Stripe.api_base}/v1/accounts/#{@account_id}/external_accounts/#{@external_account_id}"
51
- assert external_account.is_a?(Stripe::BankAccount)
52
- end
53
- end
54
-
55
- context "#list_external_accounts" do
56
- should "list the account's external accounts" do
57
- external_accounts = Stripe::Account.list_external_accounts(
58
- @account_id
59
- )
60
- assert_requested :get, "#{Stripe.api_base}/v1/accounts/#{@account_id}/external_accounts"
61
- assert external_accounts.is_a?(Stripe::ListObject)
62
- assert external_accounts.data.is_a?(Array)
63
- end
64
- end
65
- end
66
- end
@@ -1,19 +0,0 @@
1
- require File.expand_path("../../test_helper", __FILE__)
2
-
3
- module Stripe
4
- class AccountLoginLinksOperationsTest < Test::Unit::TestCase
5
- setup do
6
- @account_id = "acct_123"
7
- end
8
-
9
- context "#create_login_link" do
10
- should "create a login link" do
11
- login_link = Stripe::Account.create_login_link(
12
- @account_id
13
- )
14
- assert_requested :post, "#{Stripe.api_base}/v1/accounts/#{@account_id}/login_links"
15
- assert login_link.is_a?(Stripe::LoginLink)
16
- end
17
- end
18
- end
19
- end
@@ -1,190 +0,0 @@
1
- require File.expand_path("../../test_helper", __FILE__)
2
-
3
- module Stripe
4
- class AccountTest < Test::Unit::TestCase
5
- should "be listable" do
6
- accounts = Stripe::Account.list
7
- assert_requested :get, "#{Stripe.api_base}/v1/accounts"
8
- assert accounts.data.is_a?(Array)
9
- assert accounts.data[0].is_a?(Stripe::Account)
10
- end
11
-
12
- should "be retrievable using singular endpoint" do
13
- account = Stripe::Account.retrieve
14
- assert_requested :get, "#{Stripe.api_base}/v1/account"
15
- assert account.is_a?(Stripe::Account)
16
- end
17
-
18
- should "be retrievable using plural endpoint" do
19
- account = Stripe::Account.retrieve("acct_123")
20
- assert_requested :get, "#{Stripe.api_base}/v1/accounts/acct_123"
21
- assert account.is_a?(Stripe::Account)
22
- end
23
-
24
- should "be rejectable" do
25
- account_data = { id: "acct_foo" }
26
- stub_request(:get, "#{Stripe.api_base}/v1/accounts/acct_foo")
27
- .to_return(body: JSON.generate(account_data))
28
-
29
- stub_request(:post, "#{Stripe.api_base}/v1/accounts/acct_foo/reject")
30
- .to_return(body: JSON.generate(account_data))
31
-
32
- account = Stripe::Account.retrieve("acct_foo")
33
- account.reject(reason: "fraud")
34
- end
35
-
36
- should "be creatable" do
37
- account = Stripe::Account.create(metadata: {}, type: "standard")
38
- assert_requested :post, "#{Stripe.api_base}/v1/accounts"
39
- assert account.is_a?(Stripe::Account)
40
- end
41
-
42
- should "be saveable" do
43
- account = Stripe::Account.retrieve("acct_123")
44
- account.metadata["key"] = "value"
45
- account.save
46
- assert_requested :post, "#{Stripe.api_base}/v1/accounts/#{account.id}"
47
- end
48
-
49
- should "be updateable" do
50
- account = Stripe::Account.update("acct_123", metadata: { foo: "bar" })
51
- assert_requested :post, "#{Stripe.api_base}/v1/accounts/acct_123"
52
- assert account.is_a?(Stripe::Account)
53
- end
54
-
55
- should "be deletable" do
56
- account = Stripe::Account.retrieve("acct_123")
57
- account = account.delete
58
- assert_requested :delete, "#{Stripe.api_base}/v1/accounts/#{account.id}"
59
- assert account.is_a?(Stripe::Account)
60
- end
61
-
62
- context "#bank_account=" do
63
- should "warn that #bank_account= is deprecated" do
64
- old_stderr = $stderr
65
- $stderr = StringIO.new
66
- begin
67
- account = Stripe::Account.retrieve("acct_123")
68
- account.bank_account = "tok_123"
69
- message = "NOTE: Stripe::Account#bank_account= is " \
70
- "deprecated; use #external_account= instead"
71
- assert_match Regexp.new(message), $stderr.string
72
- ensure
73
- $stderr = old_stderr
74
- end
75
- end
76
- end
77
-
78
- context "#deauthorize" do
79
- should "deauthorize an account" do
80
- account = Stripe::Account.retrieve("acct_123")
81
-
82
- # Unfortunately, the OpenAPI spec doesn't yet cover anything under the
83
- # Connect endpoints, so for just stub this out with Webmock.
84
- stub_request(:post, "#{Stripe.connect_base}/oauth/deauthorize")
85
- .with(body: { "client_id" => "ca_1234", "stripe_user_id" => account.id })
86
- .to_return(body: JSON.generate("stripe_user_id" => account.id))
87
- account.deauthorize("ca_1234", "sk_test_1234")
88
- end
89
- end
90
-
91
- context "#legal_entity=" do
92
- should "disallow direct overrides" do
93
- account = Stripe::Account.retrieve("acct_123")
94
-
95
- assert_raise NoMethodError do
96
- account.legal_entity = { first_name: "Blah" }
97
- end
98
-
99
- account.legal_entity.first_name = "Blah"
100
- end
101
- end
102
-
103
- context "#serialize_params" do
104
- should "serialize an a new additional_owners" do
105
- obj = Stripe::Util.convert_to_stripe_object({
106
- object: "account",
107
- legal_entity: Stripe::StripeObject.construct_from({
108
- }),
109
- }, {})
110
- obj.legal_entity.additional_owners = [
111
- { first_name: "Joe" },
112
- { first_name: "Jane" },
113
- ]
114
-
115
- expected = {
116
- legal_entity: {
117
- additional_owners: {
118
- "0" => { first_name: "Joe" },
119
- "1" => { first_name: "Jane" },
120
- },
121
- },
122
- }
123
- assert_equal(expected, obj.serialize_params)
124
- end
125
-
126
- should "serialize on an partially changed additional_owners" do
127
- obj = Stripe::Util.convert_to_stripe_object({
128
- object: "account",
129
- legal_entity: {
130
- additional_owners: [
131
- Stripe::StripeObject.construct_from(first_name: "Joe"),
132
- Stripe::StripeObject.construct_from(first_name: "Jane"),
133
- ],
134
- },
135
- }, {})
136
- obj.legal_entity.additional_owners[1].first_name = "Stripe"
137
-
138
- expected = {
139
- legal_entity: {
140
- additional_owners: {
141
- "1" => { first_name: "Stripe" },
142
- },
143
- },
144
- }
145
- assert_equal(expected, obj.serialize_params)
146
- end
147
-
148
- should "serialize on an unchanged additional_owners" do
149
- obj = Stripe::Util.convert_to_stripe_object({
150
- object: "account",
151
- legal_entity: {
152
- additional_owners: [
153
- Stripe::StripeObject.construct_from(first_name: "Joe"),
154
- Stripe::StripeObject.construct_from(first_name: "Jane"),
155
- ],
156
- },
157
- }, {})
158
-
159
- expected = {
160
- legal_entity: {
161
- additional_owners: {},
162
- },
163
- }
164
- assert_equal(expected, obj.serialize_params)
165
- end
166
-
167
- # Note that the empty string that we send for this one has a special
168
- # meaning for the server, which interprets it as an array unset.
169
- should "serialize on an unset additional_owners" do
170
- obj = Stripe::Util.convert_to_stripe_object({
171
- object: "account",
172
- legal_entity: {
173
- additional_owners: [
174
- Stripe::StripeObject.construct_from(first_name: "Joe"),
175
- Stripe::StripeObject.construct_from(first_name: "Jane"),
176
- ],
177
- },
178
- }, {})
179
- obj.legal_entity.additional_owners = nil
180
-
181
- expected = {
182
- legal_entity: {
183
- additional_owners: "",
184
- },
185
- }
186
- assert_equal(expected, obj.serialize_params)
187
- end
188
- end
189
- end
190
- end
@@ -1,35 +0,0 @@
1
- require File.expand_path("../../test_helper", __FILE__)
2
-
3
- module Stripe
4
- class AlipayAccountTest < Test::Unit::TestCase
5
- context "#resource_url" do
6
- should "return a resource URL" do
7
- alipay_account = Stripe::AlipayAccount.construct_from(
8
- id: "aliacc_123",
9
- customer: "cus_123"
10
- )
11
- assert_equal "/v1/customers/cus_123/sources/aliacc_123",
12
- alipay_account.resource_url
13
- end
14
-
15
- should "raise without a customer" do
16
- alipay_account = Stripe::AlipayAccount.construct_from(id: "aliacc_123")
17
- assert_raises NotImplementedError do
18
- alipay_account.resource_url
19
- end
20
- end
21
- end
22
-
23
- should "raise on #retrieve" do
24
- assert_raises NotImplementedError do
25
- Stripe::AlipayAccount.retrieve("aliacc_123")
26
- end
27
- end
28
-
29
- should "raise on #update" do
30
- assert_raises NotImplementedError do
31
- Stripe::AlipayAccount.update("aliacc_123", {})
32
- end
33
- end
34
- end
35
- end
@@ -1,76 +0,0 @@
1
- # -*- coding: utf-8 -*-
2
- require File.expand_path("../../test_helper", __FILE__)
3
-
4
- module Stripe
5
- class ApiOperationsTest < Test::Unit::TestCase
6
- class UpdateableResource < APIResource
7
- include Stripe::APIOperations::Save
8
-
9
- def self.protected_fields
10
- [:protected]
11
- end
12
- end
13
-
14
- context ".update" do
15
- should "post the correct parameters to the resource URL" do
16
- stub_request(:post, "#{Stripe.api_base}/v1/updateableresources/id")
17
- .with(body: { foo: "bar" })
18
- .to_return(body: JSON.generate(foo: "bar"))
19
- resource = UpdateableResource.update("id", foo: "bar")
20
- assert_equal("bar", resource.foo)
21
- end
22
-
23
- should "error on protected fields" do
24
- e = assert_raises do
25
- UpdateableResource.update("id", protected: "bar")
26
- end
27
- assert_equal "Cannot update protected field: protected", e.message
28
- end
29
- end
30
-
31
- context ".nested_resource_class_methods" do
32
- class MainResource < APIResource
33
- extend Stripe::APIOperations::NestedResource
34
- nested_resource_class_methods :nested,
35
- operations: %i[create retrieve update delete list]
36
- end
37
-
38
- should "define a create method" do
39
- stub_request(:post, "#{Stripe.api_base}/v1/mainresources/id/nesteds")
40
- .with(body: { foo: "bar" })
41
- .to_return(body: JSON.generate(id: "nested_id", object: "nested", foo: "bar"))
42
- nested_resource = MainResource.create_nested("id", foo: "bar")
43
- assert_equal "bar", nested_resource.foo
44
- end
45
-
46
- should "define a retrieve method" do
47
- stub_request(:get, "#{Stripe.api_base}/v1/mainresources/id/nesteds/nested_id")
48
- .to_return(body: JSON.generate(id: "nested_id", object: "nested", foo: "bar"))
49
- nested_resource = MainResource.retrieve_nested("id", "nested_id")
50
- assert_equal "bar", nested_resource.foo
51
- end
52
-
53
- should "define an update method" do
54
- stub_request(:post, "#{Stripe.api_base}/v1/mainresources/id/nesteds/nested_id")
55
- .with(body: { foo: "baz" })
56
- .to_return(body: JSON.generate(id: "nested_id", object: "nested", foo: "baz"))
57
- nested_resource = MainResource.update_nested("id", "nested_id", foo: "baz")
58
- assert_equal "baz", nested_resource.foo
59
- end
60
-
61
- should "define a delete method" do
62
- stub_request(:delete, "#{Stripe.api_base}/v1/mainresources/id/nesteds/nested_id")
63
- .to_return(body: JSON.generate(id: "nested_id", object: "nested", deleted: true))
64
- nested_resource = MainResource.delete_nested("id", "nested_id")
65
- assert_equal true, nested_resource.deleted
66
- end
67
-
68
- should "define a list method" do
69
- stub_request(:get, "#{Stripe.api_base}/v1/mainresources/id/nesteds")
70
- .to_return(body: JSON.generate(object: "list", data: []))
71
- nested_resources = MainResource.list_nesteds("id")
72
- assert nested_resources.data.is_a?(Array)
73
- end
74
- end
75
- end
76
- end