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
@@ -1,46 +1,95 @@
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 StripeResponseTest < Test::Unit::TestCase
5
- context ".from_faraday_hash" do
6
- should "converts to StripeResponse" do
7
- body = '{"foo": "bar"}'
7
+ context "Headers" do
8
+ should "allow case-insensitive header access" do
8
9
  headers = { "Request-Id" => "request-id" }
10
+ http_resp = create_net_http_resp(200, "", headers)
9
11
 
10
- http_resp = {
11
- body: body,
12
- headers: headers,
13
- status: 200,
14
- }
12
+ headers = StripeResponse::Headers.from_net_http(http_resp)
15
13
 
16
- resp = StripeResponse.from_faraday_hash(http_resp)
14
+ assert_equal "request-id", headers["request-id"]
15
+ assert_equal "request-id", headers["Request-Id"]
16
+ assert_equal "request-id", headers["Request-ID"]
17
+ end
17
18
 
18
- assert_equal JSON.parse(body, symbolize_names: true), resp.data
19
- assert_equal body, resp.http_body
20
- assert_equal headers, resp.http_headers
21
- assert_equal 200, resp.http_status
22
- assert_equal "request-id", resp.request_id
19
+ should "initialize without error" do
20
+ StripeResponse::Headers.new({})
21
+ StripeResponse::Headers.new("Request-Id" => [])
22
+ StripeResponse::Headers.new("Request-Id" => ["request-id"])
23
+ end
24
+
25
+ should "initialize with error on a malformed hash" do
26
+ assert_raises(ArgumentError) do
27
+ StripeResponse::Headers.new(nil)
28
+ end
29
+
30
+ assert_raises(ArgumentError) do
31
+ StripeResponse::Headers.new(1 => [])
32
+ end
33
+
34
+ assert_raises(ArgumentError) do
35
+ StripeResponse::Headers.new("Request-Id" => 1)
36
+ end
37
+
38
+ assert_raises(ArgumentError) do
39
+ StripeResponse::Headers.new("Request-Id" => [1])
40
+ end
41
+ end
42
+
43
+ should "warn on duplicate header values" do
44
+ old_stderr = $stderr
45
+ $stderr = StringIO.new
46
+ begin
47
+ headers = StripeResponse::Headers.new("Duplicated" => %w[a b])
48
+ assert_equal "a", headers["Duplicated"]
49
+ assert_equal "Duplicate header values for `Duplicated`; returning only first",
50
+ $stderr.string.rstrip
51
+ ensure
52
+ $stderr = old_stderr
53
+ end
23
54
  end
24
55
  end
25
56
 
26
- context ".from_faraday_response" do
57
+ context ".from_net_http" do
27
58
  should "converts to StripeResponse" do
59
+ code = 200
28
60
  body = '{"foo": "bar"}'
29
61
  headers = { "Request-Id" => "request-id" }
62
+ http_resp = create_net_http_resp(code, body, headers)
30
63
 
31
- env = Faraday::Env.from(
32
- :status => 200, :body => body,
33
- :response_headers => headers)
34
- http_resp = Faraday::Response.new(env)
35
-
36
- resp = StripeResponse.from_faraday_response(http_resp)
64
+ resp = StripeResponse.from_net_http(http_resp)
37
65
 
38
66
  assert_equal JSON.parse(body, symbolize_names: true), resp.data
39
67
  assert_equal body, resp.http_body
40
- assert_equal headers, resp.http_headers
41
- assert_equal 200, resp.http_status
68
+ assert_equal "request-id", resp.http_headers["Request-ID"]
69
+ assert_equal code, resp.http_status
42
70
  assert_equal "request-id", resp.request_id
43
71
  end
44
72
  end
73
+
74
+ # Synthesizes a `Net::HTTPResponse` object for testing purposes.
75
+ private def create_net_http_resp(code, body, headers)
76
+ # The "1.1" is HTTP version.
77
+ http_resp = Net::HTTPResponse.new("1.1", code.to_s, nil)
78
+ http_resp.body = body
79
+
80
+ # This is obviously super sketchy, but the Ruby team has done everything
81
+ # in their power to make these objects as difficult to test with as
82
+ # possible. Even if you specify a body, accessing `#body` the first time
83
+ # will attempt to read from a non-existent socket which will subsequently
84
+ # blow up. Setting this internal variable skips that read and allows the
85
+ # object to use the body that we specified above.
86
+ http_resp.instance_variable_set(:@read, true)
87
+
88
+ headers.each do |name, value|
89
+ http_resp[name] = value
90
+ end
91
+
92
+ http_resp
93
+ end
45
94
  end
46
95
  end
@@ -1,32 +1,33 @@
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 SubscriptionItemTest < Test::Unit::TestCase
5
7
  should "be listable" do
6
8
  items = Stripe::SubscriptionItem.list(
7
- subscription: "sub_123",
9
+ subscription: "sub_123"
8
10
  )
9
11
  assert_requested :get, "#{Stripe.api_base}/v1/subscription_items",
10
- query: { subscription: "sub_123" }
11
- assert items.data.kind_of?(Array)
12
- assert items.data[0].kind_of?(Stripe::SubscriptionItem)
12
+ query: { subscription: "sub_123" }
13
+ assert items.data.is_a?(Array)
14
+ assert items.data[0].is_a?(Stripe::SubscriptionItem)
13
15
  end
14
16
 
15
17
  should "be retrievable" do
16
18
  item = Stripe::SubscriptionItem.retrieve("si_123")
17
19
  assert_requested :get, "#{Stripe.api_base}/v1/subscription_items/si_123"
18
- assert item.kind_of?(Stripe::SubscriptionItem)
20
+ assert item.is_a?(Stripe::SubscriptionItem)
19
21
  end
20
22
 
21
23
  should "be creatable" do
22
24
  item = Stripe::SubscriptionItem.create(
23
- item: 'silver',
24
25
  plan: "sapphire-elite",
25
26
  quantity: 3,
26
27
  subscription: "sub_123"
27
28
  )
28
29
  assert_requested :post, "#{Stripe.api_base}/v1/subscription_items"
29
- assert item.kind_of?(Stripe::SubscriptionItem)
30
+ assert item.is_a?(Stripe::SubscriptionItem)
30
31
  end
31
32
 
32
33
  should "be saveable" do
@@ -37,16 +38,47 @@ module Stripe
37
38
  end
38
39
 
39
40
  should "be updateable" do
40
- item = Stripe::SubscriptionItem.update("si_123", metadata: {foo: 'bar'})
41
+ item = Stripe::SubscriptionItem.update("si_123", metadata: { foo: "bar" })
41
42
  assert_requested :post, "#{Stripe.api_base}/v1/subscription_items/si_123"
42
- assert item.kind_of?(Stripe::SubscriptionItem)
43
+ assert item.is_a?(Stripe::SubscriptionItem)
43
44
  end
44
45
 
45
- should "be deletable" do
46
- item = Stripe::SubscriptionItem.retrieve("si_123")
47
- item = item.delete
48
- assert_requested :delete, "#{Stripe.api_base}/v1/subscription_items/#{item.id}"
49
- assert item.kind_of?(Stripe::SubscriptionItem)
46
+ context "#delete" do
47
+ should "be deletable" do
48
+ item = Stripe::SubscriptionItem.retrieve("si_123")
49
+ item = item.delete
50
+ assert_requested :delete, "#{Stripe.api_base}/v1/subscription_items/#{item.id}"
51
+ assert item.is_a?(Stripe::SubscriptionItem)
52
+ end
53
+ end
54
+
55
+ context ".delete" do
56
+ should "be deletable" do
57
+ item = Stripe::SubscriptionItem.delete("si_123")
58
+ assert_requested :delete, "#{Stripe.api_base}/v1/subscription_items/si_123"
59
+ assert item.is_a?(Stripe::SubscriptionItem)
60
+ end
61
+ end
62
+
63
+ context "#create_usage_record" do
64
+ should "create a usage record" do
65
+ Stripe::SubscriptionItem.create_usage_record(
66
+ "si_123",
67
+ quantity: 5000,
68
+ timestamp: Time.now.to_i,
69
+ action: "increment"
70
+ )
71
+ assert_requested :post, "#{Stripe.api_base}/v1/subscription_items/si_123/usage_records"
72
+ end
73
+ end
74
+
75
+ context "#list_usage_record_summaries" do
76
+ should "list usage record summaries" do
77
+ Stripe::SubscriptionItem.list_usage_record_summaries(
78
+ "si_123"
79
+ )
80
+ assert_requested :get, "#{Stripe.api_base}/v1/subscription_items/si_123/usage_record_summaries"
81
+ end
50
82
  end
51
83
  end
52
84
  end
@@ -0,0 +1,82 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ class SubscriptionScheduleTest < Test::Unit::TestCase
7
+ should "be listable" do
8
+ subscriptions = Stripe::SubscriptionSchedule.list
9
+ assert_requested :get, "#{Stripe.api_base}/v1/subscription_schedules"
10
+ assert subscriptions.data.is_a?(Array)
11
+ assert subscriptions.data[0].is_a?(Stripe::SubscriptionSchedule)
12
+ end
13
+
14
+ should "be retrievable" do
15
+ schedule = Stripe::SubscriptionSchedule.retrieve("sub_sched_123")
16
+ assert_requested :get,
17
+ "#{Stripe.api_base}/v1/subscription_schedules/sub_sched_123"
18
+ assert schedule.is_a?(Stripe::SubscriptionSchedule)
19
+ end
20
+
21
+ should "be creatable" do
22
+ schedule = Stripe::SubscriptionSchedule.create(
23
+ customer: "cus_123"
24
+ )
25
+ assert_requested :post, "#{Stripe.api_base}/v1/subscription_schedules"
26
+ assert schedule.is_a?(Stripe::SubscriptionSchedule)
27
+ end
28
+
29
+ should "be saveable" do
30
+ schedule = Stripe::SubscriptionSchedule.retrieve("sub_sched_123")
31
+ schedule.metadata["key"] = "value"
32
+ schedule.save
33
+ assert_requested :post,
34
+ "#{Stripe.api_base}/v1/subscription_schedules/#{schedule.id}"
35
+ end
36
+
37
+ should "be updateable" do
38
+ schedule = Stripe::SubscriptionSchedule.update("sub_sched_123", metadata: { foo: "bar" })
39
+ assert_requested :post,
40
+ "#{Stripe.api_base}/v1/subscription_schedules/sub_sched_123"
41
+ assert schedule.is_a?(Stripe::SubscriptionSchedule)
42
+ end
43
+
44
+ context "#cancel" do
45
+ should "cancel a subscription schedule" do
46
+ schedule = Stripe::SubscriptionSchedule.retrieve("sub_sched_123")
47
+ schedule = schedule.cancel
48
+ assert_requested :post,
49
+ "#{Stripe.api_base}/v1/subscription_schedules/#{schedule.id}/cancel"
50
+ assert schedule.is_a?(Stripe::SubscriptionSchedule)
51
+ end
52
+ end
53
+
54
+ context ".cancel" do
55
+ should "cancel a subscription schedule" do
56
+ schedule = Stripe::SubscriptionSchedule.cancel("sub_sched_123")
57
+ assert_requested :post,
58
+ "#{Stripe.api_base}/v1/subscription_schedules/sub_sched_123/cancel"
59
+ assert schedule.is_a?(Stripe::SubscriptionSchedule)
60
+ end
61
+ end
62
+
63
+ context "#release" do
64
+ should "release a subscription schedule" do
65
+ schedule = Stripe::SubscriptionSchedule.retrieve("sub_sched_123")
66
+ schedule = schedule.release
67
+ assert_requested :post,
68
+ "#{Stripe.api_base}/v1/subscription_schedules/#{schedule.id}/release"
69
+ assert schedule.is_a?(Stripe::SubscriptionSchedule)
70
+ end
71
+ end
72
+
73
+ context ".release" do
74
+ should "release a subscription schedule" do
75
+ schedule = Stripe::SubscriptionSchedule.release("sub_sched_123")
76
+ assert_requested :post,
77
+ "#{Stripe.api_base}/v1/subscription_schedules/sub_sched_123/release"
78
+ assert schedule.is_a?(Stripe::SubscriptionSchedule)
79
+ end
80
+ end
81
+ end
82
+ end
@@ -1,19 +1,21 @@
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 SubscriptionTest < Test::Unit::TestCase
5
7
  should "be listable" do
6
8
  subscriptions = Stripe::Subscription.list
7
9
  assert_requested :get, "#{Stripe.api_base}/v1/subscriptions"
8
- assert subscriptions.data.kind_of?(Array)
9
- assert subscriptions.data[0].kind_of?(Stripe::Subscription)
10
+ assert subscriptions.data.is_a?(Array)
11
+ assert subscriptions.data[0].is_a?(Stripe::Subscription)
10
12
  end
11
13
 
12
14
  should "be retrievable" do
13
15
  subscription = Stripe::Subscription.retrieve("sub_123")
14
16
  assert_requested :get,
15
- "#{Stripe.api_base}/v1/subscriptions/sub_123"
16
- assert subscription.kind_of?(Stripe::Subscription)
17
+ "#{Stripe.api_base}/v1/subscriptions/sub_123"
18
+ assert subscription.is_a?(Stripe::Subscription)
17
19
  end
18
20
 
19
21
  should "be creatable" do
@@ -21,37 +23,57 @@ module Stripe
21
23
  customer: "cus_123"
22
24
  )
23
25
  assert_requested :post, "#{Stripe.api_base}/v1/subscriptions"
24
- assert subscription.kind_of?(Stripe::Subscription)
26
+ assert subscription.is_a?(Stripe::Subscription)
25
27
  end
26
28
 
27
29
  should "be saveable" do
28
30
  subscription = Stripe::Subscription.retrieve("sub_123")
29
- subscription.metadata['key'] = 'value'
31
+ subscription.metadata["key"] = "value"
30
32
  subscription.save
31
33
  assert_requested :post,
32
- "#{Stripe.api_base}/v1/subscriptions/#{subscription.id}"
34
+ "#{Stripe.api_base}/v1/subscriptions/#{subscription.id}"
33
35
  end
34
36
 
35
37
  should "be updateable" do
36
- subscription = Stripe::Subscription.update("sub_123", metadata: {foo: 'bar'})
38
+ subscription = Stripe::Subscription.update("sub_123", metadata: { foo: "bar" })
37
39
  assert_requested :post,
38
- "#{Stripe.api_base}/v1/subscriptions/sub_123"
39
- assert subscription.kind_of?(Stripe::Subscription)
40
+ "#{Stripe.api_base}/v1/subscriptions/sub_123"
41
+ assert subscription.is_a?(Stripe::Subscription)
40
42
  end
41
43
 
42
- should "be deletable" do
43
- subscription = Stripe::Subscription.retrieve("sub_123")
44
- subscription = subscription.delete
45
- assert_requested :delete,
46
- "#{Stripe.api_base}/v1/subscriptions/#{subscription.id}"
47
- assert subscription.kind_of?(Stripe::Subscription)
44
+ context "#delete" do
45
+ should "be deletable" do
46
+ subscription = Stripe::Subscription.retrieve("sub_123")
47
+ subscription = subscription.delete
48
+ assert_requested :delete,
49
+ "#{Stripe.api_base}/v1/subscriptions/#{subscription.id}"
50
+ assert subscription.is_a?(Stripe::Subscription)
51
+ end
52
+ end
53
+
54
+ context ".delete" do
55
+ should "be deletable" do
56
+ subscription = Stripe::Subscription.delete("sub_123")
57
+ assert_requested :delete,
58
+ "#{Stripe.api_base}/v1/subscriptions/sub_123"
59
+ assert subscription.is_a?(Stripe::Subscription)
60
+ end
48
61
  end
49
62
 
50
63
  context "#delete_discount" do
51
64
  should "be able to delete a subscriptions's discount" do
52
65
  subscription = Stripe::Subscription.retrieve("sub_123")
53
- subscription = subscription.delete_discount
54
- assert subscription.kind_of?(Stripe::Subscription)
66
+ discount = subscription.delete_discount
67
+ assert_requested :delete, "#{Stripe.api_base}/v1/subscriptions/sub_123/discount"
68
+ assert discount.is_a?(Stripe::Discount)
69
+ end
70
+ end
71
+
72
+ context ".delete_discount" do
73
+ should "be able to delete a subscriptions's discount" do
74
+ discount = Stripe::Subscription.delete_discount("sub_123")
75
+ assert_requested :delete, "#{Stripe.api_base}/v1/subscriptions/sub_123/discount"
76
+ assert discount.is_a?(Stripe::Discount)
55
77
  end
56
78
  end
57
79
  end
@@ -0,0 +1,31 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ class TaxIdTest < Test::Unit::TestCase
7
+ context "#resource_url" do
8
+ should "return a resource URL" do
9
+ tax_id = Stripe::TaxId.construct_from(
10
+ id: "txi_123",
11
+ customer: "cus_123"
12
+ )
13
+ assert_equal "/v1/customers/cus_123/tax_ids/txi_123",
14
+ tax_id.resource_url
15
+ end
16
+
17
+ should "raise without a customer" do
18
+ tax_id = Stripe::TaxId.construct_from(id: "txi_123")
19
+ assert_raises NotImplementedError do
20
+ tax_id.resource_url
21
+ end
22
+ end
23
+ end
24
+
25
+ should "raise on #retrieve" do
26
+ assert_raises NotImplementedError do
27
+ Stripe::TaxId.retrieve("txi_123")
28
+ end
29
+ end
30
+ end
31
+ end
@@ -0,0 +1,43 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ class TaxRateTest < Test::Unit::TestCase
7
+ should "be listable" do
8
+ tax_rates = Stripe::TaxRate.list
9
+ assert_requested :get, "#{Stripe.api_base}/v1/tax_rates"
10
+ assert tax_rates.data.is_a?(Array)
11
+ assert tax_rates.first.is_a?(Stripe::TaxRate)
12
+ end
13
+
14
+ should "be retrievable" do
15
+ tax_rate = Stripe::TaxRate.retrieve("txr_123")
16
+ assert_requested :get, "#{Stripe.api_base}/v1/tax_rates/txr_123"
17
+ assert tax_rate.is_a?(Stripe::TaxRate)
18
+ end
19
+
20
+ should "be creatable" do
21
+ tax_rate = Stripe::TaxRate.create(
22
+ display_name: "name",
23
+ inclusive: false,
24
+ percentage: 10.15
25
+ )
26
+ assert_requested :post, "#{Stripe.api_base}/v1/tax_rates"
27
+ assert tax_rate.is_a?(Stripe::TaxRate)
28
+ end
29
+
30
+ should "be saveable" do
31
+ tax_rate = Stripe::TaxRate.retrieve("txr_123")
32
+ tax_rate.metadata["key"] = "value"
33
+ tax_rate.save
34
+ assert_requested :post, "#{Stripe.api_base}/v1/tax_rates/#{tax_rate.id}"
35
+ end
36
+
37
+ should "be updateable" do
38
+ tax_rate = Stripe::TaxRate.update("txr_123", metadata: { key: "value" })
39
+ assert_requested :post, "#{Stripe.api_base}/v1/tax_rates/txr_123"
40
+ assert tax_rate.is_a?(Stripe::TaxRate)
41
+ end
42
+ end
43
+ end
@@ -0,0 +1,16 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ module Terminal
7
+ class ConnectionTokenTest < Test::Unit::TestCase
8
+ should "be creatable" do
9
+ connection_token = Stripe::Terminal::ConnectionToken.create
10
+
11
+ assert_requested :post, "#{Stripe.api_base}/v1/terminal/connection_tokens"
12
+ assert connection_token.is_a?(Stripe::Terminal::ConnectionToken)
13
+ end
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,68 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ module Terminal
7
+ class LocationTest < Test::Unit::TestCase
8
+ should "be creatable" do
9
+ location = Stripe::Terminal::Location.create(
10
+ address: {
11
+ line1: "line1",
12
+ country: "US",
13
+ postal_code: "12345",
14
+ city: "San Francisco",
15
+ state: "CA",
16
+ },
17
+ display_name: "name"
18
+ )
19
+ assert_requested :post, "#{Stripe.api_base}/v1/terminal/locations"
20
+ assert location.is_a?(Stripe::Terminal::Location)
21
+ end
22
+
23
+ should "be listable" do
24
+ locations = Stripe::Terminal::Location.list
25
+ assert_requested :get, "#{Stripe.api_base}/v1/terminal/locations"
26
+ assert locations.data.is_a?(Array)
27
+ assert locations.data[0].is_a?(Stripe::Terminal::Location)
28
+ end
29
+
30
+ should "be retrievable" do
31
+ location = Stripe::Terminal::Location.retrieve("loc_123")
32
+ assert_requested :get, "#{Stripe.api_base}/v1/terminal/locations/loc_123"
33
+ assert location.is_a?(Stripe::Terminal::Location)
34
+ end
35
+
36
+ should "be saveable" do
37
+ location = Stripe::Terminal::Location.retrieve("loc_123")
38
+ location["display_name"] = "new name"
39
+ location.save
40
+ assert_requested :post, "#{Stripe.api_base}/v1/terminal/locations/loc_123"
41
+ assert location.is_a?(Stripe::Terminal::Location)
42
+ end
43
+
44
+ should "be updateable" do
45
+ location = Stripe::Terminal::Location.update("loc_123", display_name: "new name")
46
+ assert_requested :post, "#{Stripe.api_base}/v1/terminal/locations/loc_123"
47
+ assert location.is_a?(Stripe::Terminal::Location)
48
+ end
49
+
50
+ context "#delete" do
51
+ should "be deletable" do
52
+ location = Stripe::Terminal::Location.retrieve("loc_123")
53
+ location = location.delete
54
+ assert_requested :delete, "#{Stripe.api_base}/v1/terminal/locations/#{location.id}"
55
+ assert location.is_a?(Stripe::Terminal::Location)
56
+ end
57
+ end
58
+
59
+ context ".delete" do
60
+ should "be deletable" do
61
+ location = Stripe::Terminal::Location.delete("loc_123")
62
+ assert_requested :delete, "#{Stripe.api_base}/v1/terminal/locations/loc_123"
63
+ assert location.is_a?(Stripe::Terminal::Location)
64
+ end
65
+ end
66
+ end
67
+ end
68
+ end
@@ -0,0 +1,62 @@
1
+ # frozen_string_literal: true
2
+
3
+ require ::File.expand_path("../../test_helper", __dir__)
4
+
5
+ module Stripe
6
+ module Terminal
7
+ class ReaderTest < Test::Unit::TestCase
8
+ should "be creatable" do
9
+ reader = Stripe::Terminal::Reader.create(
10
+ registration_code: "elegant-orange-aqua",
11
+ label: "label"
12
+ )
13
+ assert_requested :post, "#{Stripe.api_base}/v1/terminal/readers"
14
+ assert reader.is_a?(Stripe::Terminal::Reader)
15
+ end
16
+
17
+ should "be listable" do
18
+ readers = Stripe::Terminal::Reader.list
19
+ assert_requested :get, "#{Stripe.api_base}/v1/terminal/readers"
20
+ assert readers.data.is_a?(Array)
21
+ assert readers.data[0].is_a?(Stripe::Terminal::Reader)
22
+ end
23
+
24
+ should "be retrievable" do
25
+ reader = Stripe::Terminal::Reader.retrieve("rdr_123")
26
+ assert_requested :get, "#{Stripe.api_base}/v1/terminal/readers/rdr_123"
27
+ assert reader.is_a?(Stripe::Terminal::Reader)
28
+ end
29
+
30
+ should "be saveable" do
31
+ reader = Stripe::Terminal::Reader.retrieve("rdr_123")
32
+ reader["label"] = "new label"
33
+ reader.save
34
+ assert_requested :post, "#{Stripe.api_base}/v1/terminal/readers/rdr_123"
35
+ assert reader.is_a?(Stripe::Terminal::Reader)
36
+ end
37
+
38
+ should "be updateable" do
39
+ reader = Stripe::Terminal::Reader.update("rdr_123", label: "new label")
40
+ assert_requested :post, "#{Stripe.api_base}/v1/terminal/readers/rdr_123"
41
+ assert reader.is_a?(Stripe::Terminal::Reader)
42
+ end
43
+
44
+ context "#delete" do
45
+ should "be deletable" do
46
+ reader = Stripe::Terminal::Reader.retrieve("rdr_123")
47
+ reader = reader.delete
48
+ assert_requested :delete, "#{Stripe.api_base}/v1/terminal/readers/#{reader.id}"
49
+ assert reader.is_a?(Stripe::Terminal::Reader)
50
+ end
51
+ end
52
+
53
+ context ".delete" do
54
+ should "be deletable" do
55
+ reader = Stripe::Terminal::Reader.delete("rdr_123")
56
+ assert_requested :delete, "#{Stripe.api_base}/v1/terminal/readers/rdr_123"
57
+ assert reader.is_a?(Stripe::Terminal::Reader)
58
+ end
59
+ end
60
+ end
61
+ end
62
+ end
@@ -1,11 +1,13 @@
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 ThreeDSecureTest < Test::Unit::TestCase
5
7
  should "be retrievable" do
6
8
  secure = Stripe::ThreeDSecure.retrieve("tdsrc_123")
7
9
  assert_requested :get, "#{Stripe.api_base}/v1/3d_secure/tdsrc_123"
8
- assert secure.kind_of?(Stripe::ThreeDSecure)
10
+ assert secure.is_a?(Stripe::ThreeDSecure)
9
11
  end
10
12
 
11
13
  should "be creatable" do