stripe 4.21.3 → 5.52.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (226) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +254 -1
  3. data/CODE_OF_CONDUCT.md +77 -0
  4. data/Gemfile +10 -16
  5. data/Makefile +7 -0
  6. data/README.md +115 -47
  7. data/Rakefile +8 -7
  8. data/VERSION +1 -1
  9. data/lib/stripe/api_operations/create.rb +1 -1
  10. data/lib/stripe/api_operations/delete.rb +7 -3
  11. data/lib/stripe/api_operations/list.rb +1 -12
  12. data/lib/stripe/api_operations/nested_resource.rb +29 -26
  13. data/lib/stripe/api_operations/request.rb +82 -6
  14. data/lib/stripe/api_operations/save.rb +7 -4
  15. data/lib/stripe/api_operations/search.rb +19 -0
  16. data/lib/stripe/api_resource.rb +22 -17
  17. data/lib/stripe/api_resource_test_helpers.rb +47 -0
  18. data/lib/stripe/connection_manager.rb +200 -0
  19. data/lib/stripe/error_object.rb +93 -0
  20. data/lib/stripe/errors.rb +24 -3
  21. data/lib/stripe/instrumentation.rb +84 -0
  22. data/lib/stripe/list_object.rb +34 -5
  23. data/lib/stripe/multipart_encoder.rb +131 -0
  24. data/lib/stripe/oauth.rb +8 -6
  25. data/lib/stripe/object_types.rb +20 -5
  26. data/lib/stripe/resources/account.rb +12 -16
  27. data/lib/stripe/resources/account_link.rb +2 -1
  28. data/lib/stripe/resources/alipay_account.rb +1 -1
  29. data/lib/stripe/resources/apple_pay_domain.rb +2 -1
  30. data/lib/stripe/resources/application_fee.rb +2 -12
  31. data/lib/stripe/resources/application_fee_refund.rb +3 -2
  32. data/lib/stripe/resources/balance.rb +2 -1
  33. data/lib/stripe/resources/balance_transaction.rb +2 -5
  34. data/lib/stripe/resources/bank_account.rb +3 -2
  35. data/lib/stripe/resources/billing_portal/configuration.rb +14 -0
  36. data/lib/stripe/resources/billing_portal/session.rb +12 -0
  37. data/lib/stripe/resources/bitcoin_receiver.rb +2 -1
  38. data/lib/stripe/resources/bitcoin_transaction.rb +4 -3
  39. data/lib/stripe/resources/capability.rb +3 -2
  40. data/lib/stripe/resources/card.rb +2 -1
  41. data/lib/stripe/resources/charge.rb +13 -65
  42. data/lib/stripe/resources/checkout/session.rb +17 -1
  43. data/lib/stripe/resources/country_spec.rb +2 -1
  44. data/lib/stripe/resources/coupon.rb +2 -1
  45. data/lib/stripe/resources/credit_note.rb +18 -3
  46. data/lib/stripe/resources/credit_note_line_item.rb +8 -0
  47. data/lib/stripe/resources/customer.rb +35 -59
  48. data/lib/stripe/resources/customer_balance_transaction.rb +4 -3
  49. data/lib/stripe/resources/discount.rb +2 -1
  50. data/lib/stripe/resources/dispute.rb +8 -9
  51. data/lib/stripe/resources/ephemeral_key.rb +2 -1
  52. data/lib/stripe/resources/event.rb +2 -1
  53. data/lib/stripe/resources/exchange_rate.rb +2 -1
  54. data/lib/stripe/resources/file.rb +6 -14
  55. data/lib/stripe/resources/file_link.rb +2 -1
  56. data/lib/stripe/resources/funding_instructions.rb +16 -0
  57. data/lib/stripe/resources/identity/verification_report.rb +12 -0
  58. data/lib/stripe/resources/identity/verification_session.rb +35 -0
  59. data/lib/stripe/resources/invoice.rb +47 -12
  60. data/lib/stripe/resources/invoice_item.rb +2 -1
  61. data/lib/stripe/resources/invoice_line_item.rb +2 -1
  62. data/lib/stripe/resources/issuing/authorization.rb +14 -5
  63. data/lib/stripe/resources/issuing/card.rb +8 -3
  64. data/lib/stripe/resources/issuing/card_details.rb +3 -2
  65. data/lib/stripe/resources/issuing/cardholder.rb +2 -1
  66. data/lib/stripe/resources/issuing/dispute.rb +13 -1
  67. data/lib/stripe/resources/issuing/transaction.rb +2 -1
  68. data/lib/stripe/resources/line_item.rb +8 -0
  69. data/lib/stripe/resources/login_link.rb +2 -1
  70. data/lib/stripe/resources/mandate.rb +8 -0
  71. data/lib/stripe/resources/order.rb +14 -13
  72. data/lib/stripe/resources/order_return.rb +2 -1
  73. data/lib/stripe/resources/payment_intent.rb +59 -7
  74. data/lib/stripe/resources/payment_link.rb +23 -0
  75. data/lib/stripe/resources/payment_method.rb +14 -5
  76. data/lib/stripe/resources/payout.rb +16 -7
  77. data/lib/stripe/resources/person.rb +2 -1
  78. data/lib/stripe/resources/plan.rb +2 -1
  79. data/lib/stripe/resources/price.rb +21 -0
  80. data/lib/stripe/resources/product.rb +11 -1
  81. data/lib/stripe/resources/promotion_code.rb +12 -0
  82. data/lib/stripe/resources/quote.rb +105 -0
  83. data/lib/stripe/resources/radar/early_fraud_warning.rb +2 -1
  84. data/lib/stripe/resources/radar/value_list.rb +2 -1
  85. data/lib/stripe/resources/radar/value_list_item.rb +2 -1
  86. data/lib/stripe/resources/recipient.rb +2 -5
  87. data/lib/stripe/resources/recipient_transfer.rb +1 -1
  88. data/lib/stripe/resources/refund.rb +13 -1
  89. data/lib/stripe/resources/reporting/report_run.rb +2 -1
  90. data/lib/stripe/resources/reporting/report_type.rb +2 -1
  91. data/lib/stripe/resources/reversal.rb +4 -3
  92. data/lib/stripe/resources/review.rb +8 -3
  93. data/lib/stripe/resources/setup_attempt.rb +10 -0
  94. data/lib/stripe/resources/setup_intent.rb +24 -5
  95. data/lib/stripe/resources/shipping_rate.rb +12 -0
  96. data/lib/stripe/resources/sigma/scheduled_query_run.rb +2 -1
  97. data/lib/stripe/resources/sku.rb +2 -1
  98. data/lib/stripe/resources/source.rb +17 -12
  99. data/lib/stripe/resources/source_transaction.rb +2 -1
  100. data/lib/stripe/resources/subscription.rb +16 -6
  101. data/lib/stripe/resources/subscription_item.rb +11 -2
  102. data/lib/stripe/resources/subscription_schedule.rb +14 -13
  103. data/lib/stripe/resources/tax_code.rb +10 -0
  104. data/lib/stripe/resources/tax_id.rb +2 -1
  105. data/lib/stripe/resources/tax_rate.rb +2 -1
  106. data/lib/stripe/resources/terminal/configuration.rb +15 -0
  107. data/lib/stripe/resources/terminal/connection_token.rb +2 -1
  108. data/lib/stripe/resources/terminal/location.rb +2 -1
  109. data/lib/stripe/resources/terminal/reader.rb +62 -1
  110. data/lib/stripe/resources/test_helpers/test_clock.rb +25 -0
  111. data/lib/stripe/resources/three_d_secure.rb +2 -1
  112. data/lib/stripe/resources/token.rb +2 -1
  113. data/lib/stripe/resources/topup.rb +8 -3
  114. data/lib/stripe/resources/transfer.rb +8 -8
  115. data/lib/stripe/resources/usage_record.rb +2 -17
  116. data/lib/stripe/resources/usage_record_summary.rb +2 -1
  117. data/lib/stripe/resources/webhook_endpoint.rb +2 -1
  118. data/lib/stripe/resources.rb +18 -2
  119. data/lib/stripe/search_result_object.rb +86 -0
  120. data/lib/stripe/stripe_client.rb +617 -243
  121. data/lib/stripe/stripe_configuration.rb +194 -0
  122. data/lib/stripe/stripe_object.rb +30 -25
  123. data/lib/stripe/stripe_response.rb +87 -27
  124. data/lib/stripe/util.rb +88 -18
  125. data/lib/stripe/version.rb +1 -1
  126. data/lib/stripe/webhook.rb +39 -8
  127. data/lib/stripe.rb +43 -131
  128. data/stripe.gemspec +17 -13
  129. metadata +36 -220
  130. data/.editorconfig +0 -10
  131. data/.gitattributes +0 -4
  132. data/.github/ISSUE_TEMPLATE.md +0 -5
  133. data/.gitignore +0 -8
  134. data/.rubocop.yml +0 -43
  135. data/.rubocop_todo.yml +0 -38
  136. data/.travis.yml +0 -43
  137. data/.vscode/extensions.json +0 -7
  138. data/.vscode/settings.json +0 -8
  139. data/lib/stripe/resources/issuer_fraud_record.rb +0 -9
  140. data/lib/stripe/resources/subscription_schedule_revision.rb +0 -34
  141. data/test/api_stub_helpers.rb +0 -1
  142. data/test/openapi/README.md +0 -9
  143. data/test/stripe/account_link_test.rb +0 -18
  144. data/test/stripe/account_test.rb +0 -428
  145. data/test/stripe/alipay_account_test.rb +0 -37
  146. data/test/stripe/api_operations_test.rb +0 -80
  147. data/test/stripe/api_resource_test.rb +0 -544
  148. data/test/stripe/apple_pay_domain_test.rb +0 -46
  149. data/test/stripe/application_fee_refund_test.rb +0 -37
  150. data/test/stripe/application_fee_test.rb +0 -58
  151. data/test/stripe/balance_test.rb +0 -13
  152. data/test/stripe/bank_account_test.rb +0 -36
  153. data/test/stripe/capability_test.rb +0 -45
  154. data/test/stripe/charge_test.rb +0 -80
  155. data/test/stripe/checkout/session_test.rb +0 -41
  156. data/test/stripe/country_spec_test.rb +0 -20
  157. data/test/stripe/coupon_test.rb +0 -61
  158. data/test/stripe/credit_note_test.rb +0 -61
  159. data/test/stripe/customer_balance_transaction_test.rb +0 -37
  160. data/test/stripe/customer_card_test.rb +0 -42
  161. data/test/stripe/customer_test.rb +0 -269
  162. data/test/stripe/dispute_test.rb +0 -51
  163. data/test/stripe/ephemeral_key_test.rb +0 -93
  164. data/test/stripe/errors_test.rb +0 -20
  165. data/test/stripe/exchange_rate_test.rb +0 -20
  166. data/test/stripe/file_link_test.rb +0 -41
  167. data/test/stripe/file_test.rb +0 -97
  168. data/test/stripe/file_upload_test.rb +0 -79
  169. data/test/stripe/invoice_item_test.rb +0 -66
  170. data/test/stripe/invoice_line_item_test.rb +0 -8
  171. data/test/stripe/invoice_test.rb +0 -213
  172. data/test/stripe/issuer_fraud_record_test.rb +0 -20
  173. data/test/stripe/issuing/authorization_test.rb +0 -72
  174. data/test/stripe/issuing/card_test.rb +0 -62
  175. data/test/stripe/issuing/cardholder_test.rb +0 -53
  176. data/test/stripe/issuing/dispute_test.rb +0 -45
  177. data/test/stripe/issuing/transaction_test.rb +0 -48
  178. data/test/stripe/list_object_test.rb +0 -156
  179. data/test/stripe/login_link_test.rb +0 -37
  180. data/test/stripe/oauth_test.rb +0 -88
  181. data/test/stripe/order_return_test.rb +0 -21
  182. data/test/stripe/order_test.rb +0 -82
  183. data/test/stripe/payment_intent_test.rb +0 -107
  184. data/test/stripe/payment_method_test.rb +0 -84
  185. data/test/stripe/payout_test.rb +0 -57
  186. data/test/stripe/person_test.rb +0 -46
  187. data/test/stripe/plan_test.rb +0 -98
  188. data/test/stripe/product_test.rb +0 -59
  189. data/test/stripe/radar/early_fraud_warning_test.rb +0 -22
  190. data/test/stripe/radar/value_list_item_test.rb +0 -48
  191. data/test/stripe/radar/value_list_test.rb +0 -61
  192. data/test/stripe/recipient_test.rb +0 -62
  193. data/test/stripe/refund_test.rb +0 -39
  194. data/test/stripe/reporting/report_run_test.rb +0 -33
  195. data/test/stripe/reporting/report_type_test.rb +0 -22
  196. data/test/stripe/reversal_test.rb +0 -43
  197. data/test/stripe/review_test.rb +0 -27
  198. data/test/stripe/setup_intent_test.rb +0 -84
  199. data/test/stripe/sigma/scheduled_query_run_test.rb +0 -22
  200. data/test/stripe/sku_test.rb +0 -60
  201. data/test/stripe/source_test.rb +0 -99
  202. data/test/stripe/source_transaction_test.rb +0 -19
  203. data/test/stripe/stripe_client_test.rb +0 -842
  204. data/test/stripe/stripe_object_test.rb +0 -525
  205. data/test/stripe/stripe_response_test.rb +0 -49
  206. data/test/stripe/subscription_item_test.rb +0 -63
  207. data/test/stripe/subscription_schedule_revision_test.rb +0 -37
  208. data/test/stripe/subscription_schedule_test.rb +0 -116
  209. data/test/stripe/subscription_test.rb +0 -80
  210. data/test/stripe/tax_id_test.rb +0 -31
  211. data/test/stripe/tax_rate_test.rb +0 -43
  212. data/test/stripe/terminal/connection_token_test.rb +0 -16
  213. data/test/stripe/terminal/location_test.rb +0 -68
  214. data/test/stripe/terminal/reader_test.rb +0 -62
  215. data/test/stripe/three_d_secure_test.rb +0 -23
  216. data/test/stripe/topup_test.rb +0 -62
  217. data/test/stripe/transfer_test.rb +0 -88
  218. data/test/stripe/usage_record_summary_test.rb +0 -19
  219. data/test/stripe/usage_record_test.rb +0 -28
  220. data/test/stripe/util_test.rb +0 -402
  221. data/test/stripe/webhook_endpoint_test.rb +0 -59
  222. data/test/stripe/webhook_test.rb +0 -96
  223. data/test/stripe_mock.rb +0 -77
  224. data/test/stripe_test.rb +0 -63
  225. data/test/test_data.rb +0 -61
  226. data/test/test_helper.rb +0 -71
@@ -1,269 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require ::File.expand_path("../test_helper", __dir__)
4
-
5
- module Stripe
6
- class CustomerTest < Test::Unit::TestCase
7
- should "be listable" do
8
- customers = Stripe::Customer.list
9
- assert_requested :get, "#{Stripe.api_base}/v1/customers"
10
- assert customers.data.is_a?(Array)
11
- assert customers.first.is_a?(Stripe::Customer)
12
- end
13
-
14
- should "be retrievable" do
15
- customer = Stripe::Customer.retrieve("cus_123")
16
- assert_requested :get, "#{Stripe.api_base}/v1/customers/cus_123"
17
- assert customer.is_a?(Stripe::Customer)
18
- end
19
-
20
- should "be creatable" do
21
- customer = Stripe::Customer.create
22
- assert_requested :post, "#{Stripe.api_base}/v1/customers"
23
- assert customer.is_a?(Stripe::Customer)
24
- end
25
-
26
- should "be saveable" do
27
- customer = Stripe::Customer.retrieve("cus_123")
28
- customer.metadata["key"] = "value"
29
- customer.save
30
- assert_requested :post, "#{Stripe.api_base}/v1/customers/#{customer.id}"
31
- end
32
-
33
- should "be updateable" do
34
- customer = Stripe::Customer.update("cus_123", metadata: { key: "value" })
35
- assert_requested :post, "#{Stripe.api_base}/v1/customers/cus_123"
36
- assert customer.is_a?(Stripe::Customer)
37
- end
38
-
39
- context "#delete" do
40
- should "be deletable" do
41
- customer = Stripe::Customer.retrieve("cus_123")
42
- customer = customer.delete
43
- assert_requested :delete, "#{Stripe.api_base}/v1/customers/#{customer.id}"
44
- assert customer.is_a?(Stripe::Customer)
45
- end
46
- end
47
-
48
- context ".delete" do
49
- should "be deletable" do
50
- customer = Stripe::Customer.delete("cus_123")
51
- assert_requested :delete, "#{Stripe.api_base}/v1/customers/cus_123"
52
- assert customer.is_a?(Stripe::Customer)
53
- end
54
- end
55
-
56
- context "#create_subscription" do
57
- should "create a new subscription" do
58
- customer = Stripe::Customer.retrieve("cus_123")
59
- subscription = customer.create_subscription(items: [{ plan: "silver" }])
60
- assert_requested :post, "#{Stripe.api_base}/v1/customers/#{customer.id}/subscriptions"
61
- assert subscription.is_a?(Stripe::Subscription)
62
- end
63
- end
64
-
65
- context "#create_upcoming_invoice" do
66
- should "create a new invoice" do
67
- customer = Stripe::Customer.retrieve("cus_123")
68
- invoice = customer.create_upcoming_invoice
69
- assert_requested :post, "#{Stripe.api_base}/v1/invoices"
70
- assert invoice.is_a?(Stripe::Invoice)
71
- end
72
- end
73
-
74
- context "#update_subscription" do
75
- should "update a subscription" do
76
- customer = Stripe::Customer.retrieve("cus_123")
77
-
78
- # deprecated API and not in schema
79
- stub_request(:post, "#{Stripe.api_base}/v1/customers/#{customer.id}/subscription")
80
- .with(body: { plan: "silver" })
81
- .to_return(body: JSON.generate(object: "subscription"))
82
- subscription = customer.update_subscription(plan: "silver")
83
- assert subscription.is_a?(Stripe::Subscription)
84
- end
85
- end
86
-
87
- context "#cancel_subscription" do
88
- should "cancel a subscription" do
89
- customer = Stripe::Customer.retrieve("cus_123")
90
-
91
- # deprecated API and not in schema
92
- stub_request(:delete, "#{Stripe.api_base}/v1/customers/#{customer.id}/subscription")
93
- .with(query: { at_period_end: "true" })
94
- .to_return(body: JSON.generate(object: "subscription"))
95
- subscription = customer.cancel_subscription(at_period_end: "true")
96
- assert subscription.is_a?(Stripe::Subscription)
97
- end
98
- end
99
-
100
- context "#delete_discount" do
101
- should "delete a discount" do
102
- customer = Stripe::Customer.retrieve("cus_123")
103
- customer = customer.delete_discount
104
- assert_requested :delete, "#{Stripe.api_base}/v1/customers/#{customer.id}/discount"
105
- assert customer.is_a?(Stripe::Customer)
106
- end
107
- end
108
-
109
- context ".delete_discount" do
110
- should "delete a discount" do
111
- discount = Stripe::Customer.delete_discount("cus_123")
112
- assert_requested :delete, "#{Stripe.api_base}/v1/customers/cus_123/discount"
113
- assert discount.is_a?(Stripe::Discount)
114
- end
115
- end
116
- context "#create_source" do
117
- should "create a source" do
118
- Stripe::Customer.create_source(
119
- "cus_123",
120
- source: "tok_123"
121
- )
122
- assert_requested :post, "#{Stripe.api_base}/v1/customers/cus_123/sources"
123
- end
124
- end
125
-
126
- context "#retrieve_source" do
127
- should "retrieve a source" do
128
- Stripe::Customer.retrieve_source(
129
- "cus_123",
130
- "ba_123"
131
- )
132
- assert_requested :get, "#{Stripe.api_base}/v1/customers/cus_123/sources/ba_123"
133
- end
134
- end
135
-
136
- context "#update_source" do
137
- should "update a source" do
138
- Stripe::Customer.update_source(
139
- "cus_123",
140
- "ba_123",
141
- metadata: { foo: "bar" }
142
- )
143
- assert_requested :post, "#{Stripe.api_base}/v1/customers/cus_123/sources/ba_123"
144
- end
145
- end
146
-
147
- context "#delete_source" do
148
- should "delete a source" do
149
- Stripe::Customer.delete_source(
150
- "cus_123",
151
- "ba_123"
152
- )
153
- assert_requested :delete, "#{Stripe.api_base}/v1/customers/cus_123/sources/ba_123"
154
- end
155
- end
156
-
157
- context "#list_sources" do
158
- should "list the customer's sources" do
159
- sources = Stripe::Customer.list_sources(
160
- "cus_123"
161
- )
162
- assert_requested :get, "#{Stripe.api_base}/v1/customers/cus_123/sources"
163
- assert sources.is_a?(Stripe::ListObject)
164
- assert sources.data.is_a?(Array)
165
- end
166
- end
167
-
168
- context "source field" do
169
- should "allow setting source with token" do
170
- c = Stripe::Customer.new("test_customer")
171
- c.source = "tok_123"
172
- assert_equal "tok_123", c.source
173
- end
174
-
175
- should "allow setting source with hash and set flag" do
176
- c = Stripe::Customer.new("test_customer")
177
- c.source = {
178
- object: "card",
179
- }
180
- assert_equal true, c.source.save_with_parent
181
- end
182
- end
183
-
184
- context "#create_tax_id" do
185
- should "create a tax id" do
186
- Stripe::Customer.create_tax_id(
187
- "cus_123",
188
- type: "eu_vat",
189
- value: "11111"
190
- )
191
- assert_requested :post, "#{Stripe.api_base}/v1/customers/cus_123/tax_ids"
192
- end
193
- end
194
-
195
- context "#retrieve_tax_id" do
196
- should "retrieve a tax id" do
197
- Stripe::Customer.retrieve_tax_id(
198
- "cus_123",
199
- "txi_123"
200
- )
201
- assert_requested :get, "#{Stripe.api_base}/v1/customers/cus_123/tax_ids/txi_123"
202
- end
203
- end
204
-
205
- context "#delete_tax_id" do
206
- should "delete a tax id" do
207
- Stripe::Customer.delete_tax_id(
208
- "cus_123",
209
- "txi_123"
210
- )
211
- assert_requested :delete, "#{Stripe.api_base}/v1/customers/cus_123/tax_ids/txi_123"
212
- end
213
- end
214
-
215
- context "#list_tax_ids" do
216
- should "list the customer's tax ids" do
217
- sources = Stripe::Customer.list_tax_ids(
218
- "cus_123"
219
- )
220
- assert_requested :get, "#{Stripe.api_base}/v1/customers/cus_123/tax_ids"
221
- assert sources.is_a?(Stripe::ListObject)
222
- assert sources.data.is_a?(Array)
223
- end
224
- end
225
-
226
- context "#create_balance_transaction" do
227
- should "create a customer balance transaction" do
228
- Stripe::Customer.create_balance_transaction(
229
- "cus_123",
230
- amount: 1234,
231
- currency: "usd"
232
- )
233
- assert_requested :post, "#{Stripe.api_base}/v1/customers/cus_123/balance_transactions"
234
- end
235
- end
236
-
237
- context "#retrieve_balance_transaction" do
238
- should "retrieve a customer balance transaction" do
239
- Stripe::Customer.retrieve_balance_transaction(
240
- "cus_123",
241
- "cbtxn_123"
242
- )
243
- assert_requested :get, "#{Stripe.api_base}/v1/customers/cus_123/balance_transactions/cbtxn_123"
244
- end
245
- end
246
-
247
- context "#update_balance_transaction" do
248
- should "update a customer balance transaction" do
249
- Stripe::Customer.update_balance_transaction(
250
- "cus_123",
251
- "cbtxn_123",
252
- description: "new"
253
- )
254
- assert_requested :post, "#{Stripe.api_base}/v1/customers/cus_123/balance_transactions/cbtxn_123"
255
- end
256
- end
257
-
258
- context "#list_balance_transactions" do
259
- should "list the customer balance transactions" do
260
- sources = Stripe::Customer.list_balance_transactions(
261
- "cus_123"
262
- )
263
- assert_requested :get, "#{Stripe.api_base}/v1/customers/cus_123/balance_transactions"
264
- assert sources.is_a?(Stripe::ListObject)
265
- assert sources.data.is_a?(Array)
266
- end
267
- end
268
- end
269
- end
@@ -1,51 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require ::File.expand_path("../test_helper", __dir__)
4
-
5
- module Stripe
6
- class DisputeTest < Test::Unit::TestCase
7
- should "be listable" do
8
- disputes = Stripe::Dispute.list
9
- assert_requested :get, "#{Stripe.api_base}/v1/disputes"
10
- assert disputes.data.is_a?(Array)
11
- assert disputes.first.is_a?(Stripe::Dispute)
12
- end
13
-
14
- should "be retrievable" do
15
- dispute = Stripe::Dispute.retrieve("dp_123")
16
- assert_requested :get, "#{Stripe.api_base}/v1/disputes/dp_123"
17
- assert dispute.is_a?(Stripe::Dispute)
18
- end
19
-
20
- should "be saveable" do
21
- dispute = Stripe::Dispute.retrieve("dp_123")
22
- dispute.metadata["key"] = "value"
23
- dispute.save
24
- assert_requested :post, "#{Stripe.api_base}/v1/disputes/#{dispute.id}"
25
- end
26
-
27
- should "be updateable" do
28
- dispute = Stripe::Dispute.update("dp_123", metadata: { key: "value" })
29
- assert_requested :post, "#{Stripe.api_base}/v1/disputes/dp_123"
30
- assert dispute.is_a?(Stripe::Dispute)
31
- end
32
-
33
- context "#close" do
34
- should "be closeable" do
35
- dispute = Stripe::Dispute.retrieve("dp_123")
36
- dispute.close
37
- assert_requested :post,
38
- "#{Stripe.api_base}/v1/disputes/#{dispute.id}/close"
39
- assert dispute.is_a?(Stripe::Dispute)
40
- end
41
- end
42
-
43
- context ".close" do
44
- should "close a dispute" do
45
- dispute = Stripe::Dispute.close("dp_123")
46
- assert_requested :post, "#{Stripe.api_base}/v1/disputes/dp_123/close"
47
- assert dispute.is_a?(Stripe::Dispute)
48
- end
49
- end
50
- end
51
- end
@@ -1,93 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require ::File.expand_path("../test_helper", __dir__)
4
-
5
- module Stripe
6
- class EphemeralKeyTest < Test::Unit::TestCase
7
- context "#create" do
8
- should "succeed" do
9
- key = Stripe::EphemeralKey.create(
10
- { customer: "cus_123" },
11
- stripe_version: "2017-05-25"
12
- )
13
-
14
- assert_requested(
15
- :post,
16
- "#{Stripe.api_base}/v1/ephemeral_keys",
17
- headers: { "Stripe-Version" => "2017-05-25" }
18
- )
19
-
20
- assert key.is_a?(Stripe::EphemeralKey)
21
- end
22
-
23
- context "#no global version" do
24
- should "use the correct api version" do
25
- key = Stripe::EphemeralKey.create(
26
- { customer: "cus_123" },
27
- stripe_version: "2017-06-05"
28
- )
29
-
30
- assert_requested(
31
- :post,
32
- "#{Stripe.api_base}/v1/ephemeral_keys",
33
- headers: { "Stripe-Version" => "2017-06-05" }
34
- )
35
-
36
- assert key.is_a?(Stripe::EphemeralKey)
37
- end
38
-
39
- should "error without an explicit api version" do
40
- e = assert_raises(ArgumentError) do
41
- Stripe::EphemeralKey.create(customer: "cus_123")
42
- end
43
- assert_match("stripe_version must be specified", e.message)
44
- end
45
- end
46
-
47
- context "#with global version" do
48
- setup do
49
- Stripe.api_version = "2017-05-25"
50
- end
51
-
52
- teardown do
53
- Stripe.api_version = nil
54
- end
55
-
56
- should "use the correct api version" do
57
- key = Stripe::EphemeralKey.create(
58
- { customer: "cus_123" },
59
- stripe_version: "2017-05-25"
60
- )
61
-
62
- assert key.is_a?(Stripe::EphemeralKey)
63
- end
64
-
65
- should "error without an explicit api version" do
66
- e = assert_raises(ArgumentError) do
67
- Stripe::EphemeralKey.create(customer: "cus_123")
68
- end
69
- assert_match("stripe_version must be specified", e.message)
70
- end
71
- end
72
- end
73
-
74
- context "#delete" do
75
- should "succeed" do
76
- key = Stripe::EphemeralKey.create(
77
- { customer: "cus_123" },
78
- stripe_version: "2017-05-25"
79
- )
80
-
81
- key.delete
82
- assert_requested :delete, "#{Stripe.api_base}/v1/ephemeral_keys/#{key.id}"
83
- end
84
- end
85
-
86
- context ".delete" do
87
- should "succeed" do
88
- Stripe::EphemeralKey.delete("ephkey_123")
89
- assert_requested :delete, "#{Stripe.api_base}/v1/ephemeral_keys/ephkey_123"
90
- end
91
- end
92
- end
93
- end
@@ -1,20 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require ::File.expand_path("../test_helper", __dir__)
4
-
5
- module Stripe
6
- class StripeErrorTest < Test::Unit::TestCase
7
- context "#to_s" do
8
- should "convert to string" do
9
- e = StripeError.new("message")
10
- assert_equal "message", e.to_s
11
-
12
- e = StripeError.new("message", http_status: 200)
13
- assert_equal "(Status 200) message", e.to_s
14
-
15
- e = StripeError.new("message", http_status: nil, http_body: nil, json_body: nil, http_headers: { request_id: "request-id" })
16
- assert_equal "(Request request-id) message", e.to_s
17
- end
18
- end
19
- end
20
- end
@@ -1,20 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require ::File.expand_path("../test_helper", __dir__)
4
-
5
- module Stripe
6
- class ExchangeRateTest < Test::Unit::TestCase
7
- should "be listable" do
8
- list_rates = Stripe::ExchangeRate.list
9
- assert_requested :get, "#{Stripe.api_base}/v1/exchange_rates"
10
- assert list_rates.data.is_a?(Array)
11
- assert list_rates.data.first.is_a?(Stripe::ExchangeRate)
12
- end
13
-
14
- should "be retrievable" do
15
- rates = Stripe::ExchangeRate.retrieve("usd")
16
- assert_requested :get, "#{Stripe.api_base}/v1/exchange_rates/usd"
17
- assert rates.is_a?(Stripe::ExchangeRate)
18
- end
19
- end
20
- end
@@ -1,41 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require ::File.expand_path("../test_helper", __dir__)
4
-
5
- module Stripe
6
- class FileLinkTest < Test::Unit::TestCase
7
- should "be listable" do
8
- file_links = Stripe::FileLink.list
9
- assert_requested :get, "#{Stripe.api_base}/v1/file_links"
10
- assert file_links.data.is_a?(Array)
11
- assert file_links.first.is_a?(Stripe::FileLink)
12
- end
13
-
14
- should "be retrievable" do
15
- file_link = Stripe::FileLink.retrieve("link_123")
16
- assert_requested :get, "#{Stripe.api_base}/v1/file_links/link_123"
17
- assert file_link.is_a?(Stripe::FileLink)
18
- end
19
-
20
- should "be creatable" do
21
- file_link = Stripe::FileLink.create(
22
- file: "file_123"
23
- )
24
- assert_requested :post, "#{Stripe.api_base}/v1/file_links"
25
- assert file_link.is_a?(Stripe::FileLink)
26
- end
27
-
28
- should "be saveable" do
29
- file_link = Stripe::FileLink.retrieve("link_123")
30
- file_link.metadata["key"] = "value"
31
- file_link.save
32
- assert_requested :post, "#{Stripe.api_base}/v1/file_links/#{file_link.id}"
33
- end
34
-
35
- should "be updateable" do
36
- file_link = Stripe::FileLink.update("link_123", metadata: { key: "value" })
37
- assert_requested :post, "#{Stripe.api_base}/v1/file_links/link_123"
38
- assert file_link.is_a?(Stripe::FileLink)
39
- end
40
- end
41
- end
@@ -1,97 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require ::File.expand_path("../test_helper", __dir__)
4
-
5
- module Stripe
6
- class FileTest < Test::Unit::TestCase
7
- should "be listable" do
8
- files = Stripe::File.list
9
- assert_requested :get, "#{Stripe.api_base}/v1/files"
10
- assert files.data.is_a?(Array)
11
- assert files.data[0].is_a?(Stripe::File)
12
- end
13
-
14
- should "be retrievable" do
15
- file = Stripe::File.retrieve("file_123")
16
- assert_requested :get, "#{Stripe.api_base}/v1/files/file_123"
17
- assert file.is_a?(Stripe::File)
18
- end
19
-
20
- context ".create" do
21
- setup do
22
- # We don't point to the same host for the API and uploads in
23
- # production, but `stripe-mock` supports both APIs.
24
- Stripe.uploads_base = Stripe.api_base
25
-
26
- # Set `api_base` to `nil` to ensure that these requests are _not_ sent
27
- # to the default API hostname.
28
- Stripe.api_base = nil
29
- end
30
-
31
- should "be creatable with a File" do
32
- file = Stripe::File.create(
33
- purpose: "dispute_evidence",
34
- file: ::File.new(__FILE__),
35
- file_link_data: { create: true }
36
- )
37
- assert_requested :post, "#{Stripe.uploads_base}/v1/files"
38
- assert file.is_a?(Stripe::File)
39
- end
40
-
41
- should "be creatable with a Tempfile" do
42
- tempfile = Tempfile.new("foo")
43
- tempfile.write("Hello world")
44
- tempfile.rewind
45
-
46
- file = Stripe::File.create(
47
- purpose: "dispute_evidence",
48
- file: tempfile,
49
- file_link_data: { create: true }
50
- )
51
- assert_requested :post, "#{Stripe.uploads_base}/v1/files"
52
- assert file.is_a?(Stripe::File)
53
- end
54
-
55
- should "be creatable with Faraday::UploadIO" do
56
- file = Stripe::File.create(
57
- purpose: "dispute_evidence",
58
- file: Faraday::UploadIO.new(::File.new(__FILE__), nil),
59
- file_link_data: { create: true }
60
- )
61
- assert_requested :post, "#{Stripe.uploads_base}/v1/files"
62
- assert file.is_a?(Stripe::File)
63
- end
64
-
65
- should "be creatable with a string" do
66
- file = Stripe::File.create(
67
- purpose: "dispute_evidence",
68
- file: "my-file-contents",
69
- file_link_data: { create: true }
70
- )
71
- assert_requested :post, "#{Stripe.uploads_base}/v1/files"
72
- assert file.is_a?(Stripe::File)
73
- end
74
-
75
- should "raise given a file object that doesn't respond to #read" do
76
- e = assert_raises(ArgumentError) do
77
- Stripe::File.create(
78
- purpose: "dispute_evidence",
79
- file: Object.new,
80
- file_link_data: { create: true }
81
- )
82
- end
83
- assert_equal "file must respond to `#read`", e.message
84
- end
85
- end
86
-
87
- should "be deserializable when `object=file`" do
88
- file = Stripe::Util.convert_to_stripe_object({ object: "file" }, {})
89
- assert file.is_a?(Stripe::File)
90
- end
91
-
92
- should "be deserializable when `object=file_upload`" do
93
- file = Stripe::Util.convert_to_stripe_object({ object: "file_upload" }, {})
94
- assert file.is_a?(Stripe::File)
95
- end
96
- end
97
- end
@@ -1,79 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require ::File.expand_path("../test_helper", __dir__)
4
-
5
- module Stripe
6
- # This is a strict copy of `FileTest`, except that it uses
7
- # `Stripe::FileUpload` instead of `Stripe::File`.
8
- class FileUploadTest < Test::Unit::TestCase
9
- should "be listable" do
10
- files = Stripe::FileUpload.list
11
- assert_requested :get, "#{Stripe.api_base}/v1/files"
12
- assert files.data.is_a?(Array)
13
- assert files.data[0].is_a?(Stripe::FileUpload)
14
- end
15
-
16
- should "be retrievable" do
17
- file = Stripe::FileUpload.retrieve("file_123")
18
- assert_requested :get, "#{Stripe.api_base}/v1/files/file_123"
19
- assert file.is_a?(Stripe::FileUpload)
20
- end
21
-
22
- context ".create" do
23
- setup do
24
- # We don't point to the same host for the API and uploads in
25
- # production, but `stripe-mock` supports both APIs.
26
- Stripe.uploads_base = Stripe.api_base
27
-
28
- # Set `api_base` to `nil` to ensure that these requests are _not_ sent
29
- # to the default API hostname. `api_base` is reset when each test
30
- # starts so this won't affect the global state.
31
- Stripe.api_base = nil
32
- end
33
-
34
- should "be creatable with a File" do
35
- file = Stripe::FileUpload.create(
36
- purpose: "dispute_evidence",
37
- file: ::File.new(__FILE__),
38
- file_link_data: { create: true }
39
- )
40
- assert_requested :post, "#{Stripe.uploads_base}/v1/files"
41
- assert file.is_a?(Stripe::FileUpload)
42
- end
43
-
44
- should "be creatable with a Tempfile" do
45
- tempfile = Tempfile.new("foo")
46
- tempfile.write("Hello world")
47
- tempfile.rewind
48
-
49
- file = Stripe::FileUpload.create(
50
- purpose: "dispute_evidence",
51
- file: tempfile,
52
- file_link_data: { create: true }
53
- )
54
- assert_requested :post, "#{Stripe.uploads_base}/v1/files"
55
- assert file.is_a?(Stripe::FileUpload)
56
- end
57
-
58
- should "be creatable with Faraday::UploadIO" do
59
- file = Stripe::FileUpload.create(
60
- purpose: "dispute_evidence",
61
- file: Faraday::UploadIO.new(::File.new(__FILE__), nil),
62
- file_link_data: { create: true }
63
- )
64
- assert_requested :post, "#{Stripe.uploads_base}/v1/files"
65
- assert file.is_a?(Stripe::FileUpload)
66
- end
67
- end
68
-
69
- should "be deserializable when `object=file`" do
70
- file = Stripe::Util.convert_to_stripe_object({ object: "file" }, {})
71
- assert file.is_a?(Stripe::FileUpload)
72
- end
73
-
74
- should "be deserializable when `object=file_upload`" do
75
- file = Stripe::Util.convert_to_stripe_object({ object: "file_upload" }, {})
76
- assert file.is_a?(Stripe::FileUpload)
77
- end
78
- end
79
- end