stripe-ruby-mock 3.1.0.rc2 → 3.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (117) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/rspec_tests.yml +38 -0
  3. data/.rspec +2 -1
  4. data/CHANGELOG.md +34 -0
  5. data/README.md +5 -3
  6. data/lib/stripe_mock/api/webhooks.rb +65 -26
  7. data/lib/stripe_mock/data.rb +80 -11
  8. data/lib/stripe_mock/instance.rb +6 -2
  9. data/lib/stripe_mock/request_handlers/accounts.rb +17 -6
  10. data/lib/stripe_mock/request_handlers/charges.rb +5 -0
  11. data/lib/stripe_mock/request_handlers/checkout_session.rb +165 -2
  12. data/lib/stripe_mock/request_handlers/events.rb +30 -3
  13. data/lib/stripe_mock/request_handlers/helpers/coupon_helpers.rb +1 -0
  14. data/lib/stripe_mock/request_handlers/helpers/subscription_helpers.rb +28 -9
  15. data/lib/stripe_mock/request_handlers/invoices.rb +6 -1
  16. data/lib/stripe_mock/request_handlers/payment_intents.rb +13 -2
  17. data/lib/stripe_mock/request_handlers/payment_methods.rb +5 -1
  18. data/lib/stripe_mock/request_handlers/prices.rb +18 -0
  19. data/lib/stripe_mock/request_handlers/promotion_codes.rb +43 -0
  20. data/lib/stripe_mock/request_handlers/refunds.rb +13 -2
  21. data/lib/stripe_mock/request_handlers/setup_intents.rb +16 -9
  22. data/lib/stripe_mock/request_handlers/subscriptions.rb +93 -4
  23. data/lib/stripe_mock/request_handlers/transfers.rb +12 -1
  24. data/lib/stripe_mock/request_handlers/validators/param_validators.rb +5 -8
  25. data/lib/stripe_mock/server.rb +2 -2
  26. data/lib/stripe_mock/test_strategies/base.rb +51 -25
  27. data/lib/stripe_mock/version.rb +1 -1
  28. data/lib/stripe_mock/webhook_fixtures/account.updated.json +1 -1
  29. data/lib/stripe_mock/webhook_fixtures/balance.available.json +26 -20
  30. data/lib/stripe_mock/webhook_fixtures/charge.captured.json +143 -0
  31. data/lib/stripe_mock/webhook_fixtures/charge.dispute.created.json +63 -16
  32. data/lib/stripe_mock/webhook_fixtures/charge.failed.json +49 -120
  33. data/lib/stripe_mock/webhook_fixtures/charge.refund.updated.json +35 -0
  34. data/lib/stripe_mock/webhook_fixtures/charge.refunded.json +145 -50
  35. data/lib/stripe_mock/webhook_fixtures/charge.succeeded.json +114 -43
  36. data/lib/stripe_mock/webhook_fixtures/checkout.session.completed.json +79 -0
  37. data/lib/stripe_mock/webhook_fixtures/checkout.session.completed.payment_mode.json +53 -0
  38. data/lib/stripe_mock/webhook_fixtures/checkout.session.completed.setup_mode.json +45 -0
  39. data/lib/stripe_mock/webhook_fixtures/customer.created.json +37 -46
  40. data/lib/stripe_mock/webhook_fixtures/customer.deleted.json +36 -32
  41. data/lib/stripe_mock/webhook_fixtures/customer.source.created.json +31 -22
  42. data/lib/stripe_mock/webhook_fixtures/customer.source.updated.json +36 -25
  43. data/lib/stripe_mock/webhook_fixtures/customer.subscription.created.json +135 -47
  44. data/lib/stripe_mock/webhook_fixtures/customer.subscription.deleted.json +134 -45
  45. data/lib/stripe_mock/webhook_fixtures/customer.subscription.updated.json +135 -56
  46. data/lib/stripe_mock/webhook_fixtures/customer.updated.json +38 -47
  47. data/lib/stripe_mock/webhook_fixtures/invoice.created.json +176 -49
  48. data/lib/stripe_mock/webhook_fixtures/invoice.finalized.json +171 -0
  49. data/lib/stripe_mock/webhook_fixtures/invoice.paid.json +171 -0
  50. data/lib/stripe_mock/webhook_fixtures/invoice.payment_action_required.json +171 -0
  51. data/lib/stripe_mock/webhook_fixtures/invoice.payment_failed.json +149 -83
  52. data/lib/stripe_mock/webhook_fixtures/invoice.payment_succeeded.json +149 -90
  53. data/lib/stripe_mock/webhook_fixtures/invoice.upcoming.json +70 -0
  54. data/lib/stripe_mock/webhook_fixtures/invoice.updated.json +178 -50
  55. data/lib/stripe_mock/webhook_fixtures/invoiceitem.created.json +87 -13
  56. data/lib/stripe_mock/webhook_fixtures/invoiceitem.updated.json +88 -14
  57. data/lib/stripe_mock/webhook_fixtures/mandate.updated.json +34 -0
  58. data/lib/stripe_mock/webhook_fixtures/payment_intent.amount_capturable_updated.json +170 -0
  59. data/lib/stripe_mock/webhook_fixtures/payment_intent.canceled.json +73 -0
  60. data/lib/stripe_mock/webhook_fixtures/payment_intent.created.json +86 -0
  61. data/lib/stripe_mock/webhook_fixtures/payment_intent.payment_failed.json +118 -79
  62. data/lib/stripe_mock/webhook_fixtures/payment_intent.processing.json +162 -0
  63. data/lib/stripe_mock/webhook_fixtures/payment_intent.requires_action.json +191 -0
  64. data/lib/stripe_mock/webhook_fixtures/payment_intent.succeeded.json +85 -53
  65. data/lib/stripe_mock/webhook_fixtures/payment_link.created.json +47 -0
  66. data/lib/stripe_mock/webhook_fixtures/payment_link.updated.json +50 -0
  67. data/lib/stripe_mock/webhook_fixtures/payment_method.attached.json +63 -0
  68. data/lib/stripe_mock/webhook_fixtures/payment_method.detached.json +62 -0
  69. data/lib/stripe_mock/webhook_fixtures/payout.created.json +40 -0
  70. data/lib/stripe_mock/webhook_fixtures/payout.paid.json +40 -0
  71. data/lib/stripe_mock/webhook_fixtures/payout.updated.json +46 -0
  72. data/lib/stripe_mock/webhook_fixtures/plan.created.json +30 -13
  73. data/lib/stripe_mock/webhook_fixtures/plan.deleted.json +30 -13
  74. data/lib/stripe_mock/webhook_fixtures/plan.updated.json +34 -14
  75. data/lib/stripe_mock/webhook_fixtures/price.created.json +42 -0
  76. data/lib/stripe_mock/webhook_fixtures/price.deleted.json +42 -0
  77. data/lib/stripe_mock/webhook_fixtures/price.updated.json +48 -0
  78. data/lib/stripe_mock/webhook_fixtures/product.created.json +19 -13
  79. data/lib/stripe_mock/webhook_fixtures/product.deleted.json +20 -14
  80. data/lib/stripe_mock/webhook_fixtures/product.updated.json +24 -15
  81. data/lib/stripe_mock/webhook_fixtures/quote.accepted.json +92 -0
  82. data/lib/stripe_mock/webhook_fixtures/quote.canceled.json +92 -0
  83. data/lib/stripe_mock/webhook_fixtures/quote.created.json +92 -0
  84. data/lib/stripe_mock/webhook_fixtures/quote.finalized.json +92 -0
  85. data/lib/stripe_mock/webhook_fixtures/setup_intent.canceled.json +46 -0
  86. data/lib/stripe_mock/webhook_fixtures/setup_intent.created.json +51 -0
  87. data/lib/stripe_mock/webhook_fixtures/setup_intent.setup_failed.json +100 -0
  88. data/lib/stripe_mock/webhook_fixtures/setup_intent.succeeded.json +46 -0
  89. data/lib/stripe_mock/webhook_fixtures/subscription_schedule.canceled.json +119 -0
  90. data/lib/stripe_mock/webhook_fixtures/subscription_schedule.created.json +114 -0
  91. data/lib/stripe_mock/webhook_fixtures/subscription_schedule.released.json +111 -0
  92. data/lib/stripe_mock/webhook_fixtures/subscription_schedule.updated.json +125 -0
  93. data/lib/stripe_mock/webhook_fixtures/tax_rate.created.json +32 -0
  94. data/lib/stripe_mock/webhook_fixtures/tax_rate.updated.json +37 -0
  95. data/lib/stripe_mock.rb +3 -1
  96. data/spec/instance_spec.rb +3 -1
  97. data/spec/integration_examples/completing_checkout_sessions_example.rb +37 -0
  98. data/spec/readme_spec.rb +1 -1
  99. data/spec/shared_stripe_examples/account_examples.rb +9 -1
  100. data/spec/shared_stripe_examples/checkout_session_examples.rb +99 -0
  101. data/spec/shared_stripe_examples/invoice_examples.rb +21 -0
  102. data/spec/shared_stripe_examples/payment_intent_examples.rb +74 -0
  103. data/spec/shared_stripe_examples/payment_method_examples.rb +32 -27
  104. data/spec/shared_stripe_examples/price_examples.rb +42 -2
  105. data/spec/shared_stripe_examples/product_examples.rb +1 -9
  106. data/spec/shared_stripe_examples/promotion_code_examples.rb +68 -0
  107. data/spec/shared_stripe_examples/refund_examples.rb +13 -0
  108. data/spec/shared_stripe_examples/setup_intent_examples.rb +17 -0
  109. data/spec/shared_stripe_examples/subscription_examples.rb +213 -2
  110. data/spec/shared_stripe_examples/transfer_examples.rb +10 -1
  111. data/spec/shared_stripe_examples/webhook_event_examples.rb +51 -5
  112. data/spec/support/stripe_examples.rb +3 -1
  113. data/stripe-ruby-mock.gemspec +1 -1
  114. metadata +54 -11
  115. data/.travis.yml +0 -25
  116. data/lib/stripe_mock/request_handlers/checkout.rb +0 -15
  117. data/spec/shared_stripe_examples/checkout_examples.rb +0 -38
@@ -69,6 +69,16 @@ module StripeMock
69
69
  end
70
70
  end
71
71
 
72
+ if params[:promotion_code]
73
+ promotion_code_id = params[:promotion_code]
74
+
75
+ promotion_code = promotion_codes[promotion_code_id]
76
+
77
+ unless promotion_code
78
+ raise Stripe::InvalidRequestError.new("No such promotion code: #{promotion_code_id}", 'promotion_code', http_status: 400)
79
+ end
80
+ end
81
+
72
82
  subscriptions[subscription[:id]] = subscription
73
83
  add_subscription_to_customer(customer, subscription)
74
84
 
@@ -97,7 +107,7 @@ module StripeMock
97
107
  customer[:default_source] = new_card[:id]
98
108
  end
99
109
 
100
- allowed_params = %w(customer application_fee_percent coupon items metadata plan quantity source tax_percent trial_end trial_period_days current_period_start created prorate billing_cycle_anchor billing days_until_due idempotency_key enable_incomplete_payments cancel_at_period_end default_tax_rates payment_behavior pending_invoice_item_interval default_payment_method collection_method off_session trial_from_plan expand)
110
+ allowed_params = %w(id customer application_fee_percent coupon items metadata plan quantity source tax_percent trial_end trial_period_days current_period_start created prorate billing_cycle_anchor billing days_until_due idempotency_key enable_incomplete_payments cancel_at_period_end default_tax_rates payment_behavior pending_invoice_item_interval default_payment_method collection_method off_session trial_from_plan proration_behavior backdate_start_date transfer_data expand automatic_tax payment_settings trial_settings promotion_code)
101
111
  unknown_params = params.keys - allowed_params.map(&:to_sym)
102
112
  if unknown_params.length > 0
103
113
  raise Stripe::InvalidRequestError.new("Received unknown parameter: #{unknown_params.join}", unknown_params.first.to_s, http_status: 400)
@@ -113,6 +123,10 @@ module StripeMock
113
123
  # Note: needs updating for subscriptions with multiple plans
114
124
  verify_card_present(customer, subscription_plans.first, subscription, params)
115
125
 
126
+ if params[:coupon] && params[:promotion_code]
127
+ raise Stripe::InvalidRequestError.new("You may only specify one of these parameters: coupon, promotion_code", "coupon", http_status: 400)
128
+ end
129
+
116
130
  if params[:coupon]
117
131
  coupon_id = params[:coupon]
118
132
 
@@ -128,15 +142,50 @@ module StripeMock
128
142
  end
129
143
  end
130
144
 
145
+ if params[:promotion_code]
146
+ promotion_code_id = params[:promotion_code]
147
+
148
+ promotion_code = promotion_codes[promotion_code_id]
149
+
150
+ unless promotion_code
151
+ raise Stripe::InvalidRequestError.new("No such promotion code: #{promotion_code_id}", 'promotion_code', http_status: 400)
152
+ end
153
+ end
154
+
131
155
  if params[:trial_period_days]
132
156
  subscription[:status] = 'trialing'
133
157
  end
134
158
 
159
+ if params[:payment_behavior] == 'default_incomplete'
160
+ subscription[:status] = 'incomplete'
161
+ end
162
+
135
163
  if params[:cancel_at_period_end]
136
164
  subscription[:cancel_at_period_end] = true
137
165
  subscription[:canceled_at] = Time.now.utc.to_i
138
166
  end
139
167
 
168
+ if params[:transfer_data] && !params[:transfer_data].empty?
169
+ throw Stripe::InvalidRequestError.new(missing_param_message("transfer_data[destination]")) unless params[:transfer_data][:destination]
170
+ subscription[:transfer_data] = params[:transfer_data].dup
171
+ subscription[:transfer_data][:amount_percent] ||= 100
172
+ end
173
+
174
+ if (s = params[:expand]&.find { |s| s.start_with? 'latest_invoice' })
175
+ payment_intent = nil
176
+ unless subscription[:status] == 'trialing'
177
+ intent_status = subscription[:status] == 'incomplete' ? 'requires_payment_method' : 'succeeded'
178
+ intent = Data.mock_payment_intent({
179
+ status: intent_status,
180
+ amount: subscription[:plan][:amount],
181
+ currency: subscription[:plan][:currency]
182
+ })
183
+ payment_intent = s.include?('latest_invoice.payment_intent') ? intent : intent.id
184
+ end
185
+ invoice = Data.mock_invoice([], { payment_intent: payment_intent })
186
+ subscription[:latest_invoice] = invoice
187
+ end
188
+
140
189
  subscriptions[subscription[:id]] = subscription
141
190
  add_subscription_to_customer(customer, subscription)
142
191
 
@@ -153,15 +202,34 @@ module StripeMock
153
202
  # stripe_account = headers && headers[:stripe_account] || Stripe.api_key
154
203
  route =~ method_url
155
204
 
156
- Data.mock_list_object(subscriptions.values, params)
157
- #customer = assert_existence :customer, $1, customers[stripe_account][$1]
158
- #customer[:subscriptions]
205
+ subs = subscriptions.values
206
+
207
+ case params[:status]
208
+ when nil
209
+ subs = subs.filter {|subscription| subscription[:status] != "canceled"}
210
+ when "all"
211
+ # Include all subscriptions
212
+ else
213
+ subs = subs.filter {|subscription| subscription[:status] == params[:status]}
214
+ end
215
+ if params[:current_period_end]
216
+ subs = filter_by_timestamp(subs, field: :current_period_end, value: params[:current_period_end])
217
+ end
218
+ if params[:current_period_start]
219
+ subs = filter_by_timestamp(subs, field: :current_period_start, value: params[:current_period_start])
220
+ end
221
+
222
+ Data.mock_list_object(subs, params)
159
223
  end
160
224
 
161
225
  def update_subscription(route, method_url, params, headers)
162
226
  stripe_account = headers && headers[:stripe_account] || Stripe.api_key
163
227
  route =~ method_url
164
228
 
229
+ if params[:billing_cycle_anchor] == 'now'
230
+ params[:billing_cycle_anchor] = Time.now.utc.to_i
231
+ end
232
+
165
233
  subscription_id = $2 ? $2 : $1
166
234
  subscription = assert_existence :subscription, subscription_id, subscriptions[subscription_id]
167
235
  verify_active_status(subscription)
@@ -198,6 +266,26 @@ module StripeMock
198
266
  end
199
267
  end
200
268
 
269
+ if params[:promotion_code]
270
+ promotion_code_id = params[:promotion_code]
271
+
272
+ promotion_code = promotion_codes[promotion_code_id]
273
+
274
+ if promotion_code
275
+ # You can't apply a promotion code with amount restrictions on the Customer object or on a subscription
276
+ # update API call
277
+ if promotion_code[:restrictions][:minimum_amount]
278
+ raise Stripe::InvalidRequestError.new(
279
+ "This promotion code cannot be redeemed on a subcription update because it uses the `minimum_amount` restriction.",
280
+ "promotion_code",
281
+ http_status: 400
282
+ )
283
+ end
284
+ else
285
+ raise Stripe::InvalidRequestError.new("No such promotion code: #{promotion_code_id}", 'promotion_code', http_status: 400)
286
+ end
287
+ end
288
+
201
289
  if params[:trial_period_days]
202
290
  subscription[:status] = 'trialing'
203
291
  end
@@ -285,6 +373,7 @@ module StripeMock
285
373
  return if customer[:invoice_settings][:default_payment_method]
286
374
  return if customer[:trial_end]
287
375
  return if params[:trial_end]
376
+ return if params[:payment_behavior] == 'default_incomplete'
288
377
  return if subscription[:default_payment_method]
289
378
 
290
379
  plan_trial_period_days = plan[:trial_period_days] || 0
@@ -45,7 +45,18 @@ module StripeMock
45
45
  raise Stripe::InvalidRequestError.new("Invalid integer: #{params[:amount]}", 'amount', http_status: 400)
46
46
  end
47
47
 
48
- transfers[id] = Data.mock_transfer(params.merge :id => id)
48
+ bal_trans_params = { amount: params[:amount].to_i, source: id }
49
+
50
+ balance_transaction_id = new_balance_transaction('txn', bal_trans_params)
51
+
52
+ transfers[id] = Data.mock_transfer(params.merge(id: id, balance_transaction: balance_transaction_id))
53
+
54
+ transfer = transfers[id].clone
55
+ if params[:expand] == ['balance_transaction']
56
+ transfer[:balance_transaction] = balance_transactions[balance_transaction_id]
57
+ end
58
+
59
+ transfer
49
60
  end
50
61
 
51
62
  def get_transfer(route, method_url, params, headers)
@@ -29,10 +29,6 @@ module StripeMock
29
29
  raise Stripe::InvalidRequestError.new(missing_param_message(k), k) if params[k].nil?
30
30
  end
31
31
 
32
- if !%w[good service].include?(params[:type])
33
- raise Stripe::InvalidRequestError.new("Invalid type: must be one of good or service", :type)
34
- end
35
-
36
32
  if products[ params[:id] ]
37
33
  raise Stripe::InvalidRequestError.new(already_exists_message(Stripe::Product), :id)
38
34
  end
@@ -112,13 +108,14 @@ module StripeMock
112
108
 
113
109
  def validate_create_price_params(params)
114
110
  price_id = params[:id].to_s
115
- product_id = params[:product]
116
111
 
117
- @base_strategy.create_price_params.keys.each do |attr_name|
118
- message = "Missing required param: #{attr_name}."
119
- raise Stripe::InvalidRequestError.new(message, attr_name) if params[attr_name].nil?
112
+ require_param(:currency) unless params[:currency]
113
+ unless params[:product] || params[:product_data]
114
+ raise Stripe::InvalidRequestError("Requires product or product_data")
120
115
  end
121
116
 
117
+ product_id = params[:product] || create_product(nil, nil, params[:product_data], nil).id
118
+
122
119
  if prices[price_id]
123
120
  message = already_exists_message(Stripe::Price)
124
121
  raise Stripe::InvalidRequestError.new(message, :id)
@@ -16,9 +16,9 @@ module StripeMock
16
16
  self.clear_data
17
17
  end
18
18
 
19
- def mock_request(*args)
19
+ def mock_request(*args, **kwargs)
20
20
  begin
21
- @instance.mock_request(*args)
21
+ @instance.mock_request(*args, **kwargs)
22
22
  rescue Stripe::InvalidRequestError => e
23
23
  {
24
24
  :error_raised => 'invalid_request',
@@ -10,11 +10,10 @@ module StripeMock
10
10
  Stripe::Product.create create_product_params(params)
11
11
  end
12
12
 
13
- def create_product_params(params={})
13
+ def create_product_params(params = {})
14
14
  {
15
15
  :id => 'stripe_mock_default_product_id',
16
16
  :name => 'Default Product',
17
- :type => 'service'
18
17
  }.merge(params)
19
18
  end
20
19
 
@@ -22,16 +21,15 @@ module StripeMock
22
21
  Stripe::Product.retrieve(product_id)
23
22
  end
24
23
 
25
-
26
24
  def list_plans(limit)
27
25
  Stripe::Plan.list(limit: limit)
28
26
  end
29
27
 
30
- def create_plan(params={})
28
+ def create_plan(params = {})
31
29
  Stripe::Plan.create create_plan_params(params)
32
30
  end
33
31
 
34
- def create_plan_params(params={})
32
+ def create_plan_params(params = {})
35
33
  {
36
34
  :id => 'stripe_mock_default_plan_id',
37
35
  :interval => 'month',
@@ -41,23 +39,28 @@ module StripeMock
41
39
  }.merge(params)
42
40
  end
43
41
 
44
- def create_price(params={})
42
+ def create_price(params = {})
45
43
  Stripe::Price.create create_price_params(params)
46
44
  end
47
45
 
48
- def create_price_params(params={})
49
- {
50
- :currency => StripeMock.default_currency,
46
+ def create_price_params(params = {})
47
+ price_params = {
48
+ currency: StripeMock.default_currency,
51
49
  }.merge(params)
50
+ unless price_params.key?(:product) || price_params.key?(:product_data)
51
+ price_params[:product_data] = {
52
+ name: 'Product created for price'
53
+ }
54
+ end
55
+ price_params
52
56
  end
53
57
 
54
58
  def list_subscriptions(limit)
55
59
  Stripe::Subscription.list(limit: limit)
56
60
  end
57
61
 
58
-
59
- def generate_card_token(card_params={})
60
- card_data = { :number => "4242424242424242", :exp_month => 9, :exp_year => (Time.now.year + 5), :cvc => "999", :tokenization_method => nil }
62
+ def generate_card_token(card_params = {})
63
+ card_data = {:number => "4242424242424242", :exp_month => 9, :exp_year => (Time.now.year + 5), :cvc => "999", :tokenization_method => nil}
61
64
  card = StripeMock::Util.card_merge(card_data, card_params)
62
65
  card[:fingerprint] = StripeMock::Util.fingerprint(card[:number]) if StripeMock.state == 'local'
63
66
 
@@ -65,7 +68,7 @@ module StripeMock
65
68
  stripe_token.id
66
69
  end
67
70
 
68
- def generate_bank_token(bank_account_params={})
71
+ def generate_bank_token(bank_account_params = {})
69
72
  currency = bank_account_params[:currency] || StripeMock.default_currency
70
73
  bank_account = {
71
74
  :country => "US",
@@ -81,7 +84,6 @@ module StripeMock
81
84
  stripe_token.id
82
85
  end
83
86
 
84
-
85
87
  def create_coupon_params(params = {})
86
88
  currency = params[:currency] || StripeMock.default_currency
87
89
  {
@@ -106,27 +108,51 @@ module StripeMock
106
108
  }.merge(params)
107
109
  end
108
110
 
111
+ def create_checkout_session(params = {})
112
+ Stripe::Checkout::Session.create create_checkout_session_params(params)
113
+ end
114
+
109
115
  def create_checkout_session_params(params = {})
110
116
  {
111
- payment_method_types: ['card'],
112
- line_items: [{
113
- name: 'T-shirt',
114
- quantity: 1,
115
- amount: 500,
116
- currency: 'usd',
117
- }],
117
+ payment_method_types: ['card'],
118
+ line_items: params[:mode] == "setup" ? nil : [{
119
+ name: 'T-shirt',
120
+ quantity: 1,
121
+ amount: 500,
122
+ currency: 'usd',
123
+ }],
124
+ cancel_url: "https://example.com/cancel",
125
+ success_url: "https://example.com/success",
118
126
  }.merge(params)
119
127
  end
120
128
 
129
+ def complete_checkout_session(session, payment_method)
130
+ session = session.is_a?(Stripe::Checkout::Session) ? session : Stripe::Checkout::Session.retrieve(session)
131
+ payment_method = payment_method.is_a?(Stripe::PaymentMethod) ? payment_method : Stripe::PaymentMethod.retrieve(payment_method)
132
+ case session.mode
133
+ when "payment"
134
+ Stripe::PaymentIntent.retrieve(session.payment_intent).confirm(payment_method: payment_method.id)
135
+ when "setup"
136
+ Stripe::SetupIntent.update(session.setup_intent, {payment_method: payment_method.id})
137
+ when "subscription"
138
+ line_items = Stripe::Checkout::Session.list_line_items(session.id)
139
+ Stripe::Subscription.create({
140
+ customer: session.customer,
141
+ items: line_items.map do |line_item|
142
+ {
143
+ price: line_item.price.id,
144
+ quantity: line_item.quantity
145
+ }
146
+ end,
147
+ default_payment_method: payment_method.id
148
+ })
149
+ end
150
+ end
121
151
 
122
152
  def create_coupon(params = {})
123
153
  Stripe::Coupon.create create_coupon_params(params)
124
154
  end
125
155
 
126
- def create_checkout_session(params = {})
127
- Stripe::Checkout::Session.create create_checkout_session_params(params)
128
- end
129
-
130
156
  def delete_all_coupons
131
157
  coupons = Stripe::Coupon.list
132
158
  coupons.data.map(&:delete) if coupons.data.count > 0
@@ -1,4 +1,4 @@
1
1
  module StripeMock
2
2
  # stripe-ruby-mock version
3
- VERSION = "3.1.0.rc2"
3
+ VERSION = "3.1.0"
4
4
  end
@@ -10,7 +10,7 @@
10
10
  "email": "test@stripe.com",
11
11
  "statement_descriptor": "TEST",
12
12
  "details_submitted": true,
13
- "charge_enabled": false,
13
+ "charges_enabled": false,
14
14
  "payouts_enabled": false,
15
15
  "currencies_supported": [
16
16
  "USD"
@@ -1,31 +1,37 @@
1
1
  {
2
- "created": 1326853478,
3
- "livemode": false,
4
- "id": "evt_00000000000000",
5
- "type": "balance.available",
2
+ "id": "evt_000000000000000000000000",
6
3
  "object": "event",
4
+ "api_version": "2020-08-27",
5
+ "created": 1648319937,
7
6
  "data": {
8
7
  "object": {
9
- "pending": [
10
- {
11
- "amount": 2217,
12
- "currency": "usd"
13
- }
14
- ],
8
+ "object": "balance",
15
9
  "available": [
16
10
  {
17
- "amount": 0,
18
- "currency": "usd"
11
+ "amount": 7648,
12
+ "currency": "usd",
13
+ "source_types": {
14
+ "card": 7648
15
+ }
19
16
  }
20
17
  ],
21
- "instant_available": [
18
+ "livemode": false,
19
+ "pending": [
22
20
  {
23
- "amount": 0,
24
- "currency": "usd"
21
+ "amount": 37734,
22
+ "currency": "usd",
23
+ "source_types": {
24
+ "card": 37734
25
+ }
25
26
  }
26
- ],
27
- "livemode": false,
28
- "object": "balance"
27
+ ]
29
28
  }
30
- }
31
- }
29
+ },
30
+ "livemode": false,
31
+ "pending_webhooks": 2,
32
+ "request": {
33
+ "id": null,
34
+ "idempotency_key": null
35
+ },
36
+ "type": "balance.available"
37
+ }
@@ -0,0 +1,143 @@
1
+ {
2
+ "id": "evt_000000000000000000000000",
3
+ "object": "event",
4
+ "api_version": "2020-08-27",
5
+ "created": 1648319938,
6
+ "data": {
7
+ "object": {
8
+ "id": "ch_000000000000000000000000",
9
+ "object": "charge",
10
+ "amount": 100,
11
+ "amount_captured": 100,
12
+ "amount_refunded": 0,
13
+ "application": null,
14
+ "application_fee": null,
15
+ "application_fee_amount": null,
16
+ "balance_transaction": "txn_000000000000000000000000",
17
+ "billing_details": {
18
+ "address": {
19
+ "city": null,
20
+ "country": null,
21
+ "line1": null,
22
+ "line2": null,
23
+ "postal_code": null,
24
+ "state": null
25
+ },
26
+ "email": null,
27
+ "name": null,
28
+ "phone": null
29
+ },
30
+ "calculated_statement_descriptor": "EXAMPLECOMPANY",
31
+ "captured": true,
32
+ "created": 1648319937,
33
+ "currency": "usd",
34
+ "customer": null,
35
+ "description": "(created by Stripe CLI)",
36
+ "destination": null,
37
+ "dispute": null,
38
+ "disputed": false,
39
+ "failure_code": null,
40
+ "failure_message": null,
41
+ "fraud_details": {
42
+ },
43
+ "invoice": null,
44
+ "livemode": false,
45
+ "metadata": {
46
+ },
47
+ "on_behalf_of": null,
48
+ "order": null,
49
+ "outcome": {
50
+ "network_status": "approved_by_network",
51
+ "reason": null,
52
+ "risk_level": "normal",
53
+ "risk_score": 64,
54
+ "seller_message": "Payment complete.",
55
+ "type": "authorized"
56
+ },
57
+ "paid": true,
58
+ "payment_intent": null,
59
+ "payment_method": "card_000000000000000000000000",
60
+ "payment_method_details": {
61
+ "card": {
62
+ "brand": "visa",
63
+ "checks": {
64
+ "address_line1_check": null,
65
+ "address_postal_code_check": null,
66
+ "cvc_check": null
67
+ },
68
+ "country": "US",
69
+ "exp_month": 3,
70
+ "exp_year": 2023,
71
+ "fingerprint": "ZoVSX2dK5igWt2SB",
72
+ "funding": "credit",
73
+ "installments": null,
74
+ "last4": "4242",
75
+ "mandate": null,
76
+ "network": "visa",
77
+ "three_d_secure": null,
78
+ "wallet": null
79
+ },
80
+ "type": "card"
81
+ },
82
+ "receipt_email": null,
83
+ "receipt_number": null,
84
+ "receipt_url": "https://pay.stripe.com/receipts/acct_0000000000000000/ch_000000000000000000000000/rcpt_0000000000000000000000000000000",
85
+ "refunded": false,
86
+ "refunds": {
87
+ "object": "list",
88
+ "data": [
89
+
90
+ ],
91
+ "has_more": false,
92
+ "total_count": 0,
93
+ "url": "/v1/charges/ch_000000000000000000000000/refunds"
94
+ },
95
+ "review": null,
96
+ "shipping": null,
97
+ "source": {
98
+ "id": "card_000000000000000000000000",
99
+ "object": "card",
100
+ "address_city": null,
101
+ "address_country": null,
102
+ "address_line1": null,
103
+ "address_line1_check": null,
104
+ "address_line2": null,
105
+ "address_state": null,
106
+ "address_zip": null,
107
+ "address_zip_check": null,
108
+ "brand": "Visa",
109
+ "country": "US",
110
+ "customer": null,
111
+ "cvc_check": null,
112
+ "dynamic_last4": null,
113
+ "exp_month": 3,
114
+ "exp_year": 2023,
115
+ "fingerprint": "ZoVSX2dK5igWt2SB",
116
+ "funding": "credit",
117
+ "last4": "4242",
118
+ "metadata": {
119
+ },
120
+ "name": null,
121
+ "tokenization_method": null
122
+ },
123
+ "source_transfer": null,
124
+ "statement_descriptor": null,
125
+ "statement_descriptor_suffix": null,
126
+ "status": "succeeded",
127
+ "transfer_data": null,
128
+ "transfer_group": null
129
+ },
130
+ "previous_attributes": {
131
+ "amount_captured": 0,
132
+ "balance_transaction": null,
133
+ "captured": false
134
+ }
135
+ },
136
+ "livemode": false,
137
+ "pending_webhooks": 2,
138
+ "request": {
139
+ "id": "req_00000000000000",
140
+ "idempotency_key": "d67cfb41-4cc5-47d0-b2ca-c571e6420952"
141
+ },
142
+ "type": "charge.captured"
143
+ }
@@ -1,22 +1,69 @@
1
1
  {
2
- "created": 1326853478,
3
- "livemode": false,
4
- "id": "evt_00000000000000",
5
- "type": "charge.dispute.created",
2
+ "id": "evt_000000000000000000000000",
6
3
  "object": "event",
4
+ "api_version": "2020-08-27",
5
+ "created": 1648319940,
7
6
  "data": {
8
7
  "object": {
9
- "charge": "ch_00000000000000",
10
- "amount": 1000,
11
- "created": 1381080223,
12
- "status": "needs_response",
13
- "livemode": false,
14
- "currency": "usd",
8
+ "id": "dp_000000000000000000000000",
15
9
  "object": "dispute",
16
- "reason": "general",
17
- "balance_transaction": "txn_00000000000000",
18
- "evidence_due_by": 1382745599,
19
- "evidence": null
10
+ "amount": 100,
11
+ "balance_transaction": null,
12
+ "balance_transactions": [
13
+
14
+ ],
15
+ "charge": "ch_000000000000000000000000",
16
+ "created": 1648319940,
17
+ "currency": "usd",
18
+ "evidence": {
19
+ "access_activity_log": null,
20
+ "billing_address": null,
21
+ "cancellation_policy": null,
22
+ "cancellation_policy_disclosure": null,
23
+ "cancellation_rebuttal": null,
24
+ "customer_communication": null,
25
+ "customer_email_address": null,
26
+ "customer_name": null,
27
+ "customer_purchase_ip": null,
28
+ "customer_signature": null,
29
+ "duplicate_charge_documentation": null,
30
+ "duplicate_charge_explanation": null,
31
+ "duplicate_charge_id": null,
32
+ "product_description": null,
33
+ "receipt": null,
34
+ "refund_policy": null,
35
+ "refund_policy_disclosure": null,
36
+ "refund_refusal_explanation": null,
37
+ "service_date": null,
38
+ "service_documentation": null,
39
+ "shipping_address": null,
40
+ "shipping_carrier": null,
41
+ "shipping_date": null,
42
+ "shipping_documentation": null,
43
+ "shipping_tracking_number": null,
44
+ "uncategorized_file": null,
45
+ "uncategorized_text": null
46
+ },
47
+ "evidence_details": {
48
+ "due_by": 1649116799,
49
+ "has_evidence": false,
50
+ "past_due": false,
51
+ "submission_count": 0
52
+ },
53
+ "is_charge_refundable": true,
54
+ "livemode": false,
55
+ "metadata": {
56
+ },
57
+ "payment_intent": null,
58
+ "reason": "fraudulent",
59
+ "status": "warning_needs_response"
20
60
  }
21
- }
22
- }
61
+ },
62
+ "livemode": false,
63
+ "pending_webhooks": 2,
64
+ "request": {
65
+ "id": "req_00000000000000",
66
+ "idempotency_key": "fa04076c-aa1f-40b8-9191-95465afc576e"
67
+ },
68
+ "type": "charge.dispute.created"
69
+ }