stripe 3.2.0 → 5.16.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (230) hide show
  1. checksums.yaml +5 -5
  2. data/.editorconfig +10 -0
  3. data/.gitignore +3 -0
  4. data/.rubocop.yml +80 -0
  5. data/.rubocop_todo.yml +33 -0
  6. data/.travis.yml +9 -7
  7. data/.vscode/extensions.json +7 -0
  8. data/.vscode/settings.json +8 -0
  9. data/CHANGELOG.md +876 -0
  10. data/CODE_OF_CONDUCT.md +77 -0
  11. data/Gemfile +21 -21
  12. data/History.txt +1 -678
  13. data/README.md +195 -53
  14. data/Rakefile +18 -12
  15. data/VERSION +1 -1
  16. data/bin/stripe-console +5 -3
  17. data/lib/stripe/api_operations/create.rb +3 -1
  18. data/lib/stripe/api_operations/delete.rb +26 -2
  19. data/lib/stripe/api_operations/list.rb +3 -12
  20. data/lib/stripe/api_operations/nested_resource.rb +72 -0
  21. data/lib/stripe/api_operations/request.rb +33 -15
  22. data/lib/stripe/api_operations/save.rb +18 -9
  23. data/lib/stripe/api_resource.rb +60 -10
  24. data/lib/stripe/connection_manager.rb +159 -0
  25. data/lib/stripe/error_object.rb +94 -0
  26. data/lib/stripe/errors.rb +39 -19
  27. data/lib/stripe/instrumentation.rb +82 -0
  28. data/lib/stripe/list_object.rb +54 -22
  29. data/lib/stripe/multipart_encoder.rb +131 -0
  30. data/lib/stripe/oauth.rb +22 -14
  31. data/lib/stripe/object_types.rb +96 -0
  32. data/lib/stripe/{account.rb → resources/account.rb} +72 -34
  33. data/lib/stripe/resources/account_link.rb +9 -0
  34. data/lib/stripe/resources/alipay_account.rb +34 -0
  35. data/lib/stripe/{apple_pay_domain.rb → resources/apple_pay_domain.rb} +4 -2
  36. data/lib/stripe/resources/application_fee.rb +13 -0
  37. data/lib/stripe/resources/application_fee_refund.rb +30 -0
  38. data/lib/stripe/{balance.rb → resources/balance.rb} +3 -1
  39. data/lib/stripe/{balance_transaction.rb → resources/balance_transaction.rb} +3 -5
  40. data/lib/stripe/resources/bank_account.rb +42 -0
  41. data/lib/stripe/{bitcoin_receiver.rb → resources/bitcoin_receiver.rb} +6 -5
  42. data/lib/stripe/resources/bitcoin_transaction.rb +15 -0
  43. data/lib/stripe/resources/capability.rb +33 -0
  44. data/lib/stripe/resources/card.rb +37 -0
  45. data/lib/stripe/resources/charge.rb +22 -0
  46. data/lib/stripe/resources/checkout/session.rb +12 -0
  47. data/lib/stripe/{country_spec.rb → resources/country_spec.rb} +3 -5
  48. data/lib/stripe/{coupon.rb → resources/coupon.rb} +4 -2
  49. data/lib/stripe/resources/credit_note.rb +32 -0
  50. data/lib/stripe/resources/credit_note_line_item.rb +7 -0
  51. data/lib/stripe/resources/customer.rb +35 -0
  52. data/lib/stripe/resources/customer_balance_transaction.rb +30 -0
  53. data/lib/stripe/resources/discount.rb +7 -0
  54. data/lib/stripe/resources/dispute.rb +21 -0
  55. data/lib/stripe/resources/ephemeral_key.rb +19 -0
  56. data/lib/stripe/{event.rb → resources/event.rb} +3 -1
  57. data/lib/stripe/resources/exchange_rate.rb +9 -0
  58. data/lib/stripe/resources/file.rb +34 -0
  59. data/lib/stripe/resources/file_link.rb +11 -0
  60. data/lib/stripe/resources/invoice.rb +73 -0
  61. data/lib/stripe/{invoice_item.rb → resources/invoice_item.rb} +4 -2
  62. data/lib/stripe/{invoice_line_item.rb → resources/invoice_line_item.rb} +3 -1
  63. data/lib/stripe/resources/issuing/authorization.rb +33 -0
  64. data/lib/stripe/resources/issuing/card.rb +24 -0
  65. data/lib/stripe/resources/issuing/card_details.rb +9 -0
  66. data/lib/stripe/resources/issuing/cardholder.rb +13 -0
  67. data/lib/stripe/resources/issuing/dispute.rb +13 -0
  68. data/lib/stripe/resources/issuing/transaction.rb +12 -0
  69. data/lib/stripe/resources/login_link.rb +14 -0
  70. data/lib/stripe/resources/mandate.rb +7 -0
  71. data/lib/stripe/resources/order.rb +32 -0
  72. data/lib/stripe/{order_return.rb → resources/order_return.rb} +3 -5
  73. data/lib/stripe/resources/payment_intent.rb +42 -0
  74. data/lib/stripe/resources/payment_method.rb +32 -0
  75. data/lib/stripe/resources/payout.rb +22 -0
  76. data/lib/stripe/resources/person.rb +31 -0
  77. data/lib/stripe/{plan.rb → resources/plan.rb} +3 -1
  78. data/lib/stripe/{product.rb → resources/product.rb} +5 -3
  79. data/lib/stripe/resources/radar/early_fraud_warning.rb +11 -0
  80. data/lib/stripe/resources/radar/value_list.rb +14 -0
  81. data/lib/stripe/resources/radar/value_list_item.rb +13 -0
  82. data/lib/stripe/{recipient.rb → resources/recipient.rb} +5 -6
  83. data/lib/stripe/resources/recipient_transfer.rb +7 -0
  84. data/lib/stripe/{refund.rb → resources/refund.rb} +3 -1
  85. data/lib/stripe/resources/reporting/report_run.rb +12 -0
  86. data/lib/stripe/resources/reporting/report_type.rb +12 -0
  87. data/lib/stripe/resources/reversal.rb +29 -0
  88. data/lib/stripe/resources/review.rb +20 -0
  89. data/lib/stripe/resources/setup_intent.rb +32 -0
  90. data/lib/stripe/resources/sigma/scheduled_query_run.rb +15 -0
  91. data/lib/stripe/{sku.rb → resources/sku.rb} +5 -3
  92. data/lib/stripe/resources/source.rb +46 -0
  93. data/lib/stripe/resources/source_transaction.rb +7 -0
  94. data/lib/stripe/resources/subscription.rb +25 -0
  95. data/lib/stripe/resources/subscription_item.rb +25 -0
  96. data/lib/stripe/resources/subscription_schedule.rb +32 -0
  97. data/lib/stripe/resources/tax_id.rb +26 -0
  98. data/lib/stripe/resources/tax_rate.rb +11 -0
  99. data/lib/stripe/resources/terminal/connection_token.rb +11 -0
  100. data/lib/stripe/resources/terminal/location.rb +14 -0
  101. data/lib/stripe/resources/terminal/reader.rb +14 -0
  102. data/lib/stripe/{three_d_secure.rb → resources/three_d_secure.rb} +3 -1
  103. data/lib/stripe/{token.rb → resources/token.rb} +3 -1
  104. data/lib/stripe/resources/topup.rb +22 -0
  105. data/lib/stripe/resources/transfer.rb +26 -0
  106. data/lib/stripe/resources/usage_record.rb +7 -0
  107. data/lib/stripe/resources/usage_record_summary.rb +7 -0
  108. data/lib/stripe/resources/webhook_endpoint.rb +12 -0
  109. data/lib/stripe/resources.rb +79 -0
  110. data/lib/stripe/singleton_api_resource.rb +10 -4
  111. data/lib/stripe/stripe_client.rb +658 -337
  112. data/lib/stripe/stripe_object.rb +248 -126
  113. data/lib/stripe/stripe_response.rb +55 -21
  114. data/lib/stripe/util.rb +145 -187
  115. data/lib/stripe/version.rb +3 -1
  116. data/lib/stripe/webhook.rb +27 -16
  117. data/lib/stripe.rb +139 -90
  118. data/stripe.gemspec +26 -14
  119. data/test/openapi/README.md +9 -0
  120. data/test/stripe/account_link_test.rb +18 -0
  121. data/test/stripe/account_test.rb +311 -101
  122. data/test/stripe/alipay_account_test.rb +21 -1
  123. data/test/stripe/api_operations_test.rb +57 -8
  124. data/test/stripe/api_resource_test.rb +359 -271
  125. data/test/stripe/apple_pay_domain_test.rb +26 -11
  126. data/test/stripe/application_fee_refund_test.rb +10 -8
  127. data/test/stripe/application_fee_test.rb +49 -3
  128. data/test/stripe/balance_test.rb +4 -2
  129. data/test/stripe/balance_transaction_test.rb +20 -0
  130. data/test/stripe/bank_account_test.rb +11 -11
  131. data/test/stripe/capability_test.rb +45 -0
  132. data/test/stripe/charge_test.rb +25 -18
  133. data/test/stripe/checkout/session_test.rb +41 -0
  134. data/test/stripe/connection_manager_test.rb +163 -0
  135. data/test/stripe/country_spec_test.rb +6 -4
  136. data/test/stripe/coupon_test.rb +29 -10
  137. data/test/stripe/credit_note_test.rb +90 -0
  138. data/test/stripe/customer_balance_transaction_test.rb +37 -0
  139. data/test/stripe/customer_card_test.rb +13 -17
  140. data/test/stripe/customer_test.rb +161 -49
  141. data/test/stripe/dispute_test.rb +19 -8
  142. data/test/stripe/ephemeral_key_test.rb +23 -14
  143. data/test/stripe/errors_test.rb +32 -9
  144. data/test/stripe/exchange_rate_test.rb +20 -0
  145. data/test/stripe/file_link_test.rb +41 -0
  146. data/test/stripe/file_test.rb +87 -0
  147. data/test/stripe/instrumentation_test.rb +74 -0
  148. data/test/stripe/invoice_item_test.rb +31 -18
  149. data/test/stripe/invoice_line_item_test.rb +3 -1
  150. data/test/stripe/invoice_test.rb +158 -39
  151. data/test/stripe/issuing/authorization_test.rb +72 -0
  152. data/test/stripe/issuing/card_test.rb +62 -0
  153. data/test/stripe/issuing/cardholder_test.rb +53 -0
  154. data/test/stripe/issuing/dispute_test.rb +45 -0
  155. data/test/stripe/issuing/transaction_test.rb +48 -0
  156. data/test/stripe/list_object_test.rb +120 -88
  157. data/test/stripe/login_link_test.rb +16 -14
  158. data/test/stripe/mandate_test.rb +14 -0
  159. data/test/stripe/multipart_encoder_test.rb +130 -0
  160. data/test/stripe/oauth_test.rb +69 -50
  161. data/test/stripe/order_return_test.rb +7 -5
  162. data/test/stripe/order_test.rb +39 -14
  163. data/test/stripe/payment_intent_test.rb +107 -0
  164. data/test/stripe/payment_method_test.rb +84 -0
  165. data/test/stripe/payout_test.rb +18 -9
  166. data/test/stripe/person_test.rb +46 -0
  167. data/test/stripe/plan_test.rb +67 -19
  168. data/test/stripe/product_test.rb +28 -14
  169. data/test/stripe/radar/early_fraud_warning_test.rb +22 -0
  170. data/test/stripe/radar/value_list_item_test.rb +48 -0
  171. data/test/stripe/radar/value_list_test.rb +61 -0
  172. data/test/stripe/recipient_test.rb +27 -13
  173. data/test/stripe/refund_test.rb +11 -9
  174. data/test/stripe/reporting/report_run_test.rb +33 -0
  175. data/test/stripe/reporting/report_type_test.rb +22 -0
  176. data/test/stripe/reversal_test.rb +12 -10
  177. data/test/stripe/review_test.rb +27 -0
  178. data/test/stripe/setup_intent_test.rb +84 -0
  179. data/test/stripe/sigma/scheduled_query_run_test.rb +22 -0
  180. data/test/stripe/sku_test.rb +24 -12
  181. data/test/stripe/source_test.rb +70 -19
  182. data/test/stripe/stripe_client_test.rb +867 -326
  183. data/test/stripe/stripe_object_test.rb +284 -182
  184. data/test/stripe/stripe_response_test.rb +73 -24
  185. data/test/stripe/subscription_item_test.rb +47 -15
  186. data/test/stripe/subscription_schedule_test.rb +82 -0
  187. data/test/stripe/subscription_test.rb +41 -19
  188. data/test/stripe/tax_id_test.rb +31 -0
  189. data/test/stripe/tax_rate_test.rb +43 -0
  190. data/test/stripe/terminal/connection_token_test.rb +16 -0
  191. data/test/stripe/terminal/location_test.rb +68 -0
  192. data/test/stripe/terminal/reader_test.rb +62 -0
  193. data/test/stripe/three_d_secure_test.rb +4 -2
  194. data/test/stripe/topup_test.rb +62 -0
  195. data/test/stripe/transfer_test.rb +55 -8
  196. data/test/stripe/usage_record_summary_test.rb +29 -0
  197. data/test/stripe/util_test.rb +173 -84
  198. data/test/stripe/webhook_endpoint_test.rb +59 -0
  199. data/test/stripe/webhook_test.rb +21 -17
  200. data/test/stripe_mock.rb +78 -0
  201. data/test/stripe_test.rb +6 -15
  202. data/test/test_data.rb +28 -26
  203. data/test/test_helper.rb +48 -29
  204. metadata +183 -70
  205. data/lib/stripe/alipay_account.rb +0 -22
  206. data/lib/stripe/application_fee.rb +0 -22
  207. data/lib/stripe/application_fee_refund.rb +0 -20
  208. data/lib/stripe/bank_account.rb +0 -30
  209. data/lib/stripe/bitcoin_transaction.rb +0 -11
  210. data/lib/stripe/card.rb +0 -27
  211. data/lib/stripe/charge.rb +0 -82
  212. data/lib/stripe/customer.rb +0 -79
  213. data/lib/stripe/dispute.rb +0 -17
  214. data/lib/stripe/ephemeral_key.rb +0 -18
  215. data/lib/stripe/file_upload.rb +0 -33
  216. data/lib/stripe/invoice.rb +0 -29
  217. data/lib/stripe/login_link.rb +0 -9
  218. data/lib/stripe/order.rb +0 -29
  219. data/lib/stripe/payout.rb +0 -18
  220. data/lib/stripe/recipient_transfer.rb +0 -6
  221. data/lib/stripe/reversal.rb +0 -20
  222. data/lib/stripe/source.rb +0 -23
  223. data/lib/stripe/subscription.rb +0 -33
  224. data/lib/stripe/subscription_item.rb +0 -14
  225. data/lib/stripe/transfer.rb +0 -18
  226. data/test/api_stub_helpers.rb +0 -0
  227. data/test/stripe/bitcoin_receiver_test.rb +0 -67
  228. data/test/stripe/bitcoin_transaction_test.rb +0 -19
  229. data/test/stripe/file_upload_test.rb +0 -66
  230. data/test/stripe/recipient_card_test.rb +0 -44
@@ -0,0 +1,62 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ class TopupTest < Test::Unit::TestCase
7
+ should "be listable" do
8
+ topups = Stripe::Topup.list
9
+ assert_requested :get, "#{Stripe.api_base}/v1/topups"
10
+ assert topups.data.is_a?(Array)
11
+ assert topups.data[0].is_a?(Stripe::Topup)
12
+ end
13
+
14
+ should "be retrievable" do
15
+ topup = Stripe::Topup.retrieve("tu_123")
16
+ assert_requested :get, "#{Stripe.api_base}/v1/topups/tu_123"
17
+ assert topup.is_a?(Stripe::Topup)
18
+ end
19
+
20
+ should "be creatable" do
21
+ topup = Stripe::Topup.create(
22
+ amount: 100,
23
+ currency: "USD",
24
+ source: "src_123",
25
+ description: "description",
26
+ statement_descriptor: "statement descriptor"
27
+ )
28
+ assert_requested :post, "#{Stripe.api_base}/v1/topups"
29
+ assert topup.is_a?(Stripe::Topup)
30
+ end
31
+
32
+ should "be saveable" do
33
+ topup = Stripe::Topup.retrieve("tu_123")
34
+ topup.metadata["key"] = "value"
35
+ topup.save
36
+ assert_requested :post, "#{Stripe.api_base}/v1/topups/#{topup.id}"
37
+ end
38
+
39
+ should "be updateable" do
40
+ topup = Stripe::Topup.update("tu_123", metadata: { foo: "bar" })
41
+ assert_requested :post, "#{Stripe.api_base}/v1/topups/tu_123"
42
+ assert topup.is_a?(Stripe::Topup)
43
+ end
44
+
45
+ context "#cancel" do
46
+ should "cancel the topup" do
47
+ topup = Stripe::Topup.retrieve("tu_123")
48
+ topup = topup.cancel
49
+ assert_requested :post, "#{Stripe.api_base}/v1/topups/#{topup.id}/cancel"
50
+ assert topup.is_a?(Stripe::Topup)
51
+ end
52
+ end
53
+
54
+ context ".cancel" do
55
+ should "cancel the topup" do
56
+ topup = Stripe::Topup.cancel("tu_123")
57
+ assert_requested :post, "#{Stripe.api_base}/v1/topups/tu_123/cancel"
58
+ assert topup.is_a?(Stripe::Topup)
59
+ end
60
+ end
61
+ end
62
+ end
@@ -1,18 +1,20 @@
1
- require File.expand_path('../../test_helper', __FILE__)
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../test_helper", __dir__)
2
4
 
3
5
  module Stripe
4
6
  class TransferTest < Test::Unit::TestCase
5
7
  should "be listable" do
6
8
  transfers = Stripe::Transfer.list
7
9
  assert_requested :get, "#{Stripe.api_base}/v1/transfers"
8
- assert transfers.data.kind_of?(Array)
9
- assert transfers.data[0].kind_of?(Stripe::Transfer)
10
+ assert transfers.data.is_a?(Array)
11
+ assert transfers.data[0].is_a?(Stripe::Transfer)
10
12
  end
11
13
 
12
14
  should "be retrievable" do
13
15
  transfer = Stripe::Transfer.retrieve("tr_123")
14
16
  assert_requested :get, "#{Stripe.api_base}/v1/transfers/tr_123"
15
- assert transfer.kind_of?(Stripe::Transfer)
17
+ assert transfer.is_a?(Stripe::Transfer)
16
18
  end
17
19
 
18
20
  should "be creatable" do
@@ -22,20 +24,65 @@ module Stripe
22
24
  destination: "acct_123"
23
25
  )
24
26
  assert_requested :post, "#{Stripe.api_base}/v1/transfers"
25
- assert transfer.kind_of?(Stripe::Transfer)
27
+ assert transfer.is_a?(Stripe::Transfer)
26
28
  end
27
29
 
28
30
  should "be saveable" do
29
31
  transfer = Stripe::Transfer.retrieve("tr_123")
30
- transfer.metadata['key'] = 'value'
32
+ transfer.metadata["key"] = "value"
31
33
  transfer.save
32
34
  assert_requested :post, "#{Stripe.api_base}/v1/transfers/#{transfer.id}"
33
35
  end
34
36
 
35
37
  should "be updateable" do
36
- transfer = Stripe::Transfer.update("tr_123", metadata: {foo: 'bar'})
38
+ transfer = Stripe::Transfer.update("tr_123", metadata: { foo: "bar" })
37
39
  assert_requested :post, "#{Stripe.api_base}/v1/transfers/tr_123"
38
- assert transfer.kind_of?(Stripe::Transfer)
40
+ assert transfer.is_a?(Stripe::Transfer)
41
+ end
42
+
43
+ context "#create_reversal" do
44
+ should "create a reversal" do
45
+ reversal = Stripe::Transfer.create_reversal(
46
+ "tr_123",
47
+ amount: 100
48
+ )
49
+ assert_requested :post, "#{Stripe.api_base}/v1/transfers/tr_123/reversals"
50
+ assert reversal.is_a?(Stripe::Reversal)
51
+ end
52
+ end
53
+
54
+ context "#retrieve_reversal" do
55
+ should "retrieve a reversal" do
56
+ reversal = Stripe::Transfer.retrieve_reversal(
57
+ "tr_123",
58
+ "trr_123"
59
+ )
60
+ assert_requested :get, "#{Stripe.api_base}/v1/transfers/tr_123/reversals/trr_123"
61
+ assert reversal.is_a?(Stripe::Reversal)
62
+ end
63
+ end
64
+
65
+ context "#update_reversal" do
66
+ should "update a reversal" do
67
+ reversal = Stripe::Transfer.update_reversal(
68
+ "tr_123",
69
+ "trr_123",
70
+ metadata: { foo: "bar" }
71
+ )
72
+ assert_requested :post, "#{Stripe.api_base}/v1/transfers/tr_123/reversals/trr_123"
73
+ assert reversal.is_a?(Stripe::Reversal)
74
+ end
75
+ end
76
+
77
+ context "#list_reversals" do
78
+ should "list the transfer's reversals" do
79
+ reversals = Stripe::Transfer.list_reversals(
80
+ "tr_123"
81
+ )
82
+ assert_requested :get, "#{Stripe.api_base}/v1/transfers/tr_123/reversals"
83
+ assert reversals.is_a?(Stripe::ListObject)
84
+ assert reversals.data.is_a?(Array)
85
+ end
39
86
  end
40
87
  end
41
88
  end
@@ -0,0 +1,29 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ class UsageRecordSummaryTest < Test::Unit::TestCase
7
+ setup do
8
+ @sub_item = Stripe::SubscriptionItem.retrieve("si_123")
9
+ end
10
+
11
+ should "be listable" do
12
+ old_stderr = $stderr
13
+ $stderr = StringIO.new
14
+
15
+ begin
16
+ transactions = @sub_item.usage_record_summaries
17
+
18
+ assert_requested :get, "#{Stripe.api_base}/v1/subscription_items/#{@sub_item.id}/usage_record_summaries"
19
+ assert transactions.data.is_a?(Array)
20
+ assert transactions.first.is_a?(Stripe::UsageRecordSummary)
21
+
22
+ assert_include $stderr.string,
23
+ "use SubscriptionItem.list_usage_record_summaries instead"
24
+ ensure
25
+ $stderr = old_stderr
26
+ end
27
+ end
28
+ end
29
+ end
@@ -1,53 +1,43 @@
1
- require File.expand_path('../../test_helper', __FILE__)
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../test_helper", __dir__)
2
4
 
3
5
  module Stripe
4
6
  class UtilTest < Test::Unit::TestCase
7
+ context "OPTS_COPYABLE" do
8
+ should "include :apibase" do
9
+ assert_include Stripe::Util::OPTS_COPYABLE, :api_base
10
+ end
11
+ end
12
+
13
+ context "OPTS_PERSISTABLE" do
14
+ should "include :client" do
15
+ assert_include Stripe::Util::OPTS_PERSISTABLE, :client
16
+ end
17
+
18
+ should "not include :idempotency_key" do
19
+ refute_includes Stripe::Util::OPTS_PERSISTABLE, :idempotency_key
20
+ end
21
+ end
22
+
5
23
  should "#encode_parameters should prepare parameters for an HTTP request" do
6
24
  params = {
7
- :a => 3,
8
- :b => "+foo?",
9
- :c => "bar&baz",
10
- :d => { :a => "a", :b => "b" },
11
- :e => [0, 1],
12
- :f => "",
25
+ a: 3,
26
+ b: "+foo?",
27
+ c: "bar&baz",
28
+ d: { a: "a", b: "b" },
29
+ e: [0, 1],
30
+ f: "",
13
31
 
14
32
  # note the empty hash won't even show up in the request
15
- :g => [],
33
+ g: [],
16
34
  }
17
35
  assert_equal(
18
- "a=3&b=%2Bfoo%3F&c=bar%26baz&d[a]=a&d[b]=b&e[]=0&e[]=1&f=",
36
+ "a=3&b=%2Bfoo%3F&c=bar%26baz&d[a]=a&d[b]=b&e[0]=0&e[1]=1&f=",
19
37
  Stripe::Util.encode_parameters(params)
20
38
  )
21
39
  end
22
40
 
23
- should "#encode_params should throw an error on an array of maps that cannot be encoded" do
24
- params = {
25
- :a => [
26
- { :a => 1, :b => 2 },
27
- { :c => 3, :a => 4 },
28
- ]
29
- }
30
- e = assert_raises(ArgumentError) do
31
- Stripe::Util.encode_parameters(params)
32
- end
33
- expected = "All maps nested in an array should start with the same key " +
34
- "(expected starting key 'a', got 'c')"
35
- assert_equal expected, e.message
36
-
37
- # Make sure the check is recursive by taking our original params and
38
- # nesting it into yet another map and array. Should throw exactly the
39
- # same error because it's still the in inner array of maps that's wrong.
40
- params = {
41
- :x => [
42
- params
43
- ]
44
- }
45
- e = assert_raises(ArgumentError) do
46
- Stripe::Util.encode_parameters(params)
47
- end
48
- assert_equal expected, e.message
49
- end
50
-
51
41
  should "#url_encode should prepare strings for HTTP" do
52
42
  assert_equal "foo", Stripe::Util.url_encode("foo")
53
43
  assert_equal "foo", Stripe::Util.url_encode(:foo)
@@ -61,50 +51,50 @@ module Stripe
61
51
  [:a, 3],
62
52
  [:b, "foo?"],
63
53
  [:c, "bar&baz"],
64
- [:d, { :a => "a", :b => "b" }],
54
+ [:d, { a: "a", b: "b" }],
65
55
  [:e, [0, 1]],
66
56
  [:f, [
67
- { :foo => "1", :ghi => "2" },
68
- { :foo => "3", :bar => "4" },
69
- ]],
57
+ { foo: "1", ghi: "2" },
58
+ { foo: "3", bar: "4" },
59
+ ],],
70
60
  ]
71
61
  assert_equal([
72
- ["a", 3],
62
+ ["a", 3],
73
63
  ["b", "foo?"],
74
64
  ["c", "bar&baz"],
75
65
  ["d[a]", "a"],
76
66
  ["d[b]", "b"],
77
- ["e[]", 0],
78
- ["e[]", 1],
67
+ ["e[0]", 0],
68
+ ["e[1]", 1],
79
69
 
80
70
  # *The key here is the order*. In order to be properly interpreted as
81
71
  # an array of hashes on the server, everything from a single hash must
82
72
  # come in at once. A duplicate key in an array triggers a new element.
83
- ["f[][foo]", "1"],
84
- ["f[][ghi]", "2"],
85
- ["f[][foo]", "3"],
86
- ["f[][bar]", "4"],
73
+ ["f[0][foo]", "1"],
74
+ ["f[0][ghi]", "2"],
75
+ ["f[1][foo]", "3"],
76
+ ["f[1][bar]", "4"],
87
77
  ], Stripe::Util.flatten_params(params))
88
78
  end
89
79
 
90
80
  should "#symbolize_names should convert names to symbols" do
91
81
  start = {
92
- 'foo' => 'bar',
93
- 'array' => [{ 'foo' => 'bar' }],
94
- 'nested' => {
82
+ "foo" => "bar",
83
+ "array" => [{ "foo" => "bar" }],
84
+ "nested" => {
95
85
  1 => 2,
96
86
  :symbol => 9,
97
- 'string' => nil
98
- }
87
+ "string" => nil,
88
+ },
99
89
  }
100
90
  finish = {
101
- :foo => 'bar',
102
- :array => [{ :foo => 'bar' }],
103
- :nested => {
91
+ foo: "bar",
92
+ array: [{ foo: "bar" }],
93
+ nested: {
104
94
  1 => 2,
105
95
  :symbol => 9,
106
- :string => nil
107
- }
96
+ :string => nil,
97
+ },
108
98
  }
109
99
 
110
100
  symbolized = Stripe::Util.symbolize_names(start)
@@ -113,7 +103,7 @@ module Stripe
113
103
 
114
104
  should "#normalize_opts should reject nil keys" do
115
105
  assert_raise { Stripe::Util.normalize_opts(nil) }
116
- assert_raise { Stripe::Util.normalize_opts(:api_key => nil) }
106
+ assert_raise { Stripe::Util.normalize_opts(api_key: nil) }
117
107
  end
118
108
 
119
109
  should "#convert_to_stripe_object should pass through unknown types" do
@@ -122,18 +112,18 @@ module Stripe
122
112
  end
123
113
 
124
114
  should "#convert_to_stripe_object should turn hashes into StripeObjects" do
125
- obj = Util.convert_to_stripe_object({ :foo => "bar" }, {})
115
+ obj = Util.convert_to_stripe_object({ foo: "bar" }, {})
126
116
  assert obj.is_a?(StripeObject)
127
117
  assert_equal "bar", obj.foo
128
118
  end
129
119
 
130
120
  should "#convert_to_stripe_object should turn lists into ListObjects" do
131
- obj = Util.convert_to_stripe_object({ :object => "list" }, {})
121
+ obj = Util.convert_to_stripe_object({ object: "list" }, {})
132
122
  assert obj.is_a?(ListObject)
133
123
  end
134
124
 
135
125
  should "#convert_to_stripe_object should marshal other classes" do
136
- obj = Util.convert_to_stripe_object({ :object => "account" }, {})
126
+ obj = Util.convert_to_stripe_object({ object: "account" }, {})
137
127
  assert obj.is_a?(Account)
138
128
  end
139
129
 
@@ -142,24 +132,20 @@ module Stripe
142
132
  assert_equal [1, 2, 3], obj
143
133
  end
144
134
 
145
- should "#array_to_hash should convert an array into a hash with integer keys" do
146
- assert_equal({"0" => 1, "1" => 2, "2" => 3}, Util.array_to_hash([1, 2, 3]))
147
- end
148
-
149
135
  context ".request_id_dashboard_url" do
150
136
  should "generate a livemode URL" do
151
137
  assert_equal "https://dashboard.stripe.com/live/logs/request-id",
152
- Util.request_id_dashboard_url("request-id", "sk_live_123")
138
+ Util.request_id_dashboard_url("request-id", "sk_live_123")
153
139
  end
154
140
 
155
141
  should "generate a testmode URL" do
156
142
  assert_equal "https://dashboard.stripe.com/test/logs/request-id",
157
- Util.request_id_dashboard_url("request-id", "sk_test_123")
143
+ Util.request_id_dashboard_url("request-id", "sk_test_123")
158
144
  end
159
145
 
160
146
  should "default to a testmode URL" do
161
147
  assert_equal "https://dashboard.stripe.com/test/logs/request-id",
162
- Util.request_id_dashboard_url("request-id", nil)
148
+ Util.request_id_dashboard_url("request-id", nil)
163
149
  end
164
150
  end
165
151
 
@@ -168,12 +154,16 @@ module Stripe
168
154
  @old_log_level = Stripe.log_level
169
155
  Stripe.log_level = nil
170
156
 
157
+ @old_stderr = $stderr
158
+ $stderr = StringIO.new
159
+
171
160
  @old_stdout = $stdout
172
161
  $stdout = StringIO.new
173
162
  end
174
163
 
175
164
  teardown do
176
165
  Stripe.log_level = @old_log_level
166
+ $stderr = @old_stderr
177
167
  $stdout = @old_stdout
178
168
  end
179
169
 
@@ -189,6 +179,12 @@ module Stripe
189
179
  assert_equal "message=foo level=debug \n", $stdout.string
190
180
  end
191
181
 
182
+ should "not log if level set to error" do
183
+ Stripe.log_level = Stripe::LEVEL_ERROR
184
+ Util.log_debug("foo")
185
+ assert_equal "", $stdout.string
186
+ end
187
+
192
188
  should "not log if level set to info" do
193
189
  Stripe.log_level = Stripe::LEVEL_INFO
194
190
  Util.log_debug("foo")
@@ -196,6 +192,31 @@ module Stripe
196
192
  end
197
193
  end
198
194
 
195
+ context ".log_error" do
196
+ should "not log if logging is disabled" do
197
+ Util.log_error("foo")
198
+ assert_equal "", $stdout.string
199
+ end
200
+
201
+ should "log if level set to debug" do
202
+ Stripe.log_level = Stripe::LEVEL_DEBUG
203
+ Util.log_error("foo")
204
+ assert_equal "message=foo level=error \n", $stderr.string
205
+ end
206
+
207
+ should "log if level set to error" do
208
+ Stripe.log_level = Stripe::LEVEL_ERROR
209
+ Util.log_error("foo")
210
+ assert_equal "message=foo level=error \n", $stderr.string
211
+ end
212
+
213
+ should "log if level set to info" do
214
+ Stripe.log_level = Stripe::LEVEL_INFO
215
+ Util.log_error("foo")
216
+ assert_equal "message=foo level=error \n", $stderr.string
217
+ end
218
+ end
219
+
199
220
  context ".log_info" do
200
221
  should "not log if logging is disabled" do
201
222
  Util.log_info("foo")
@@ -208,6 +229,12 @@ module Stripe
208
229
  assert_equal "message=foo level=info \n", $stdout.string
209
230
  end
210
231
 
232
+ should "not log if level set to error" do
233
+ Stripe.log_level = Stripe::LEVEL_ERROR
234
+ Util.log_debug("foo")
235
+ assert_equal "", $stdout.string
236
+ end
237
+
211
238
  should "log if level set to info" do
212
239
  Stripe.log_level = Stripe::LEVEL_INFO
213
240
  Util.log_info("foo")
@@ -216,23 +243,59 @@ module Stripe
216
243
  end
217
244
  end
218
245
 
246
+ context ".log_* with a logger" do
247
+ setup do
248
+ @out = StringIO.new
249
+ logger = ::Logger.new(@out)
250
+
251
+ # Set a really simple formatter to make matching output as easy as
252
+ # possible.
253
+ logger.formatter = proc { |_severity, _datetime, _progname, message|
254
+ message
255
+ }
256
+
257
+ Stripe.logger = logger
258
+ end
259
+
260
+ context ".log_debug" do
261
+ should "log to the logger" do
262
+ Util.log_debug("foo")
263
+ assert_equal "message=foo ", @out.string
264
+ end
265
+ end
266
+
267
+ context ".log_error" do
268
+ should "log to the logger" do
269
+ Util.log_error("foo")
270
+ assert_equal "message=foo ", @out.string
271
+ end
272
+ end
273
+
274
+ context ".log_info" do
275
+ should "log to the logger" do
276
+ Util.log_info("foo")
277
+ assert_equal "message=foo ", @out.string
278
+ end
279
+ end
280
+ end
281
+
219
282
  context ".normalize_headers" do
220
283
  should "normalize the format of a header key" do
221
284
  assert_equal({ "Request-Id" => nil },
222
- Util.normalize_headers({ "Request-Id" => nil }))
285
+ Util.normalize_headers("Request-Id" => nil))
223
286
  assert_equal({ "Request-Id" => nil },
224
- Util.normalize_headers({ "request-id" => nil }))
287
+ Util.normalize_headers("request-id" => nil))
225
288
  assert_equal({ "Request-Id" => nil },
226
- Util.normalize_headers({ "Request-ID" => nil }))
289
+ Util.normalize_headers("Request-ID" => nil))
227
290
  assert_equal({ "Request-Id" => nil },
228
- Util.normalize_headers({ :request_id => nil }))
291
+ Util.normalize_headers(request_id: nil))
229
292
  end
230
293
 
231
294
  should "tolerate bad formatting" do
232
295
  assert_equal({ "Request-Id" => nil },
233
- Util.normalize_headers({ "-Request--Id-" => nil }))
296
+ Util.normalize_headers("-Request--Id-" => nil))
234
297
  assert_equal({ "Request-Id" => nil },
235
- Util.normalize_headers({ :request__id => nil }))
298
+ Util.normalize_headers(request__id: nil))
236
299
  end
237
300
  end
238
301
 
@@ -247,7 +310,7 @@ module Stripe
247
310
  context ".colorize" do
248
311
  should "colorize for a TTY" do
249
312
  assert_equal "\033[0;32;49mfoo\033[0m",
250
- Util.send(:colorize, "foo", :green, true)
313
+ Util.send(:colorize, "foo", :green, true)
251
314
  end
252
315
 
253
316
  should "not colorize otherwise" do
@@ -255,6 +318,14 @@ module Stripe
255
318
  end
256
319
  end
257
320
 
321
+ context ".level_name" do
322
+ should "convert levels to names" do
323
+ assert_equal "debug", Util.send(:level_name, LEVEL_DEBUG)
324
+ assert_equal "error", Util.send(:level_name, LEVEL_ERROR)
325
+ assert_equal "info", Util.send(:level_name, LEVEL_INFO)
326
+ end
327
+ end
328
+
258
329
  context ".log_internal" do
259
330
  should "log in a terminal friendly way" do
260
331
  out = StringIO.new
@@ -263,21 +334,39 @@ module Stripe
263
334
  # Open this instance of StringIO, and add a method override so that it
264
335
  # looks like a TTY.
265
336
  out.instance_eval do
266
- def isatty; true; end
337
+ def isatty
338
+ true
339
+ end
267
340
  end
268
341
 
269
342
  Util.send(:log_internal, "message", { foo: "bar" },
270
- color: :green, level: Stripe::LEVEL_DEBUG, out: out)
343
+ color: :green, level: Stripe::LEVEL_DEBUG, logger: nil, out: out)
271
344
  assert_equal "\e[0;32;49mDEBU\e[0m message \e[0;32;49mfoo\e[0m=bar\n",
272
- out.string
345
+ out.string
273
346
  end
274
347
 
275
348
  should "log in a data friendly way" do
276
349
  out = StringIO.new
277
350
  Util.send(:log_internal, "message", { foo: "bar" },
278
- color: :green, level: Stripe::LEVEL_DEBUG, out: out)
351
+ color: :green, level: Stripe::LEVEL_DEBUG, logger: nil, out: out)
279
352
  assert_equal "message=message level=debug foo=bar\n",
280
- out.string
353
+ out.string
354
+ end
355
+
356
+ should "log to a logger if set" do
357
+ out = StringIO.new
358
+ logger = ::Logger.new(out)
359
+
360
+ # Set a really simple formatter to make matching output as easy as
361
+ # possible.
362
+ logger.formatter = proc { |_severity, _datetime, _progname, message|
363
+ message
364
+ }
365
+
366
+ Util.send(:log_internal, "message", { foo: "bar" },
367
+ color: :green, level: Stripe::LEVEL_DEBUG, logger: logger, out: $stdout)
368
+ assert_equal "message=message foo=bar",
369
+ out.string
281
370
  end
282
371
  end
283
372
 
@@ -294,15 +383,15 @@ module Stripe
294
383
  end
295
384
 
296
385
  should "wrap more complex values in double quotes" do
297
- assert_equal %{"abc=123"}, Util.send(:wrap_logfmt_value, %{abc=123})
386
+ assert_equal %("abc=123"), Util.send(:wrap_logfmt_value, %(abc=123))
298
387
  end
299
388
 
300
389
  should "escape double quotes already in the value" do
301
- assert_equal %{"abc=\\"123\\""}, Util.send(:wrap_logfmt_value, %{abc="123"})
390
+ assert_equal %("abc=\\"123\\""), Util.send(:wrap_logfmt_value, %(abc="123"))
302
391
  end
303
392
 
304
393
  should "remove newlines" do
305
- assert_equal %{"abc"}, Util.send(:wrap_logfmt_value, "a\nb\nc")
394
+ assert_equal %("abc"), Util.send(:wrap_logfmt_value, "a\nb\nc")
306
395
  end
307
396
 
308
397
  should "not error if given a non-string" do
@@ -0,0 +1,59 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ class WebhookEndpointTest < Test::Unit::TestCase
7
+ should "be listable" do
8
+ webhook_endpoints = Stripe::WebhookEndpoint.list
9
+ assert_requested :get, "#{Stripe.api_base}/v1/webhook_endpoints"
10
+ assert webhook_endpoints.data.is_a?(Array)
11
+ assert webhook_endpoints.first.is_a?(Stripe::WebhookEndpoint)
12
+ end
13
+
14
+ should "be retrievable" do
15
+ webhook_endpoint = Stripe::WebhookEndpoint.retrieve("we_123")
16
+ assert_requested :get, "#{Stripe.api_base}/v1/webhook_endpoints/we_123"
17
+ assert webhook_endpoint.is_a?(Stripe::WebhookEndpoint)
18
+ end
19
+
20
+ should "be creatable" do
21
+ webhook_endpoint = Stripe::WebhookEndpoint.create(
22
+ enabled_events: ["charge.succeeded"],
23
+ url: "https://stripe.com"
24
+ )
25
+ assert_requested :post, "#{Stripe.api_base}/v1/webhook_endpoints"
26
+ assert webhook_endpoint.is_a?(Stripe::WebhookEndpoint)
27
+ end
28
+
29
+ should "be saveable" do
30
+ webhook_endpoint = Stripe::WebhookEndpoint.retrieve("we_123")
31
+ webhook_endpoint.enabled_events = ["charge.succeeded"]
32
+ webhook_endpoint.save
33
+ assert_requested :post, "#{Stripe.api_base}/v1/webhook_endpoints/#{webhook_endpoint.id}"
34
+ end
35
+
36
+ should "be updateable" do
37
+ webhook_endpoint = Stripe::WebhookEndpoint.update("we_123", enabled_events: ["charge.succeeded"])
38
+ assert_requested :post, "#{Stripe.api_base}/v1/webhook_endpoints/we_123"
39
+ assert webhook_endpoint.is_a?(Stripe::WebhookEndpoint)
40
+ end
41
+
42
+ context "#delete" do
43
+ should "be deletable" do
44
+ webhook_endpoint = Stripe::WebhookEndpoint.retrieve("we_123")
45
+ webhook_endpoint = webhook_endpoint.delete
46
+ assert_requested :delete, "#{Stripe.api_base}/v1/webhook_endpoints/#{webhook_endpoint.id}"
47
+ assert webhook_endpoint.is_a?(Stripe::WebhookEndpoint)
48
+ end
49
+ end
50
+
51
+ context ".delete" do
52
+ should "be deletable" do
53
+ webhook_endpoint = Stripe::WebhookEndpoint.delete("we_123")
54
+ assert_requested :delete, "#{Stripe.api_base}/v1/webhook_endpoints/we_123"
55
+ assert webhook_endpoint.is_a?(Stripe::WebhookEndpoint)
56
+ end
57
+ end
58
+ end
59
+ end