stripe 2.0.3 → 5.55.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (214) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.md +1036 -0
  3. data/CODE_OF_CONDUCT.md +77 -0
  4. data/Gemfile +24 -23
  5. data/History.txt +1 -593
  6. data/Makefile +7 -0
  7. data/README.md +252 -53
  8. data/Rakefile +18 -24
  9. data/VERSION +1 -1
  10. data/bin/stripe-console +5 -3
  11. data/lib/stripe/api_operations/create.rb +4 -2
  12. data/lib/stripe/api_operations/delete.rb +31 -3
  13. data/lib/stripe/api_operations/list.rb +4 -13
  14. data/lib/stripe/api_operations/nested_resource.rb +73 -0
  15. data/lib/stripe/api_operations/request.rb +92 -10
  16. data/lib/stripe/api_operations/save.rb +25 -13
  17. data/lib/stripe/api_operations/search.rb +19 -0
  18. data/lib/stripe/api_resource.rb +55 -11
  19. data/lib/stripe/api_resource_test_helpers.rb +47 -0
  20. data/lib/stripe/connection_manager.rb +200 -0
  21. data/lib/stripe/error_object.rb +93 -0
  22. data/lib/stripe/errors.rb +98 -13
  23. data/lib/stripe/instrumentation.rb +84 -0
  24. data/lib/stripe/list_object.rb +55 -21
  25. data/lib/stripe/multipart_encoder.rb +131 -0
  26. data/lib/stripe/oauth.rb +65 -0
  27. data/lib/stripe/object_types.rb +119 -0
  28. data/lib/stripe/{account.rb → resources/account.rb} +75 -38
  29. data/lib/stripe/resources/account_link.rb +10 -0
  30. data/lib/stripe/resources/alipay_account.rb +34 -0
  31. data/lib/stripe/{apple_pay_domain.rb → resources/apple_pay_domain.rb} +6 -1
  32. data/lib/stripe/resources/application_fee.rb +14 -0
  33. data/lib/stripe/resources/application_fee_refund.rb +31 -0
  34. data/lib/stripe/resources/balance.rb +8 -0
  35. data/lib/stripe/resources/balance_transaction.rb +10 -0
  36. data/lib/stripe/resources/bank_account.rb +43 -0
  37. data/lib/stripe/resources/billing_portal/configuration.rb +14 -0
  38. data/lib/stripe/resources/billing_portal/session.rb +12 -0
  39. data/lib/stripe/{bitcoin_receiver.rb → resources/bitcoin_receiver.rb} +8 -4
  40. data/lib/stripe/resources/bitcoin_transaction.rb +16 -0
  41. data/lib/stripe/resources/capability.rb +34 -0
  42. data/lib/stripe/resources/card.rb +38 -0
  43. data/lib/stripe/resources/cash_balance.rb +22 -0
  44. data/lib/stripe/resources/charge.rb +32 -0
  45. data/lib/stripe/resources/checkout/session.rb +27 -0
  46. data/lib/stripe/resources/country_spec.rb +10 -0
  47. data/lib/stripe/{coupon.rb → resources/coupon.rb} +6 -1
  48. data/lib/stripe/resources/credit_note.rb +33 -0
  49. data/lib/stripe/resources/credit_note_line_item.rb +8 -0
  50. data/lib/stripe/resources/customer.rb +74 -0
  51. data/lib/stripe/resources/customer_balance_transaction.rb +31 -0
  52. data/lib/stripe/resources/discount.rb +8 -0
  53. data/lib/stripe/resources/dispute.rb +22 -0
  54. data/lib/stripe/resources/ephemeral_key.rb +20 -0
  55. data/lib/stripe/resources/event.rb +10 -0
  56. data/lib/stripe/resources/exchange_rate.rb +10 -0
  57. data/lib/stripe/resources/file.rb +36 -0
  58. data/lib/stripe/resources/file_link.rb +12 -0
  59. data/lib/stripe/resources/financial_connections/account.rb +31 -0
  60. data/lib/stripe/resources/financial_connections/account_owner.rb +10 -0
  61. data/lib/stripe/resources/financial_connections/account_ownership.rb +10 -0
  62. data/lib/stripe/resources/financial_connections/session.rb +12 -0
  63. data/lib/stripe/resources/funding_instructions.rb +16 -0
  64. data/lib/stripe/resources/identity/verification_report.rb +12 -0
  65. data/lib/stripe/resources/identity/verification_session.rb +35 -0
  66. data/lib/stripe/resources/invoice.rb +83 -0
  67. data/lib/stripe/{invoice_item.rb → resources/invoice_item.rb} +6 -1
  68. data/lib/stripe/resources/invoice_line_item.rb +8 -0
  69. data/lib/stripe/resources/issuing/authorization.rb +34 -0
  70. data/lib/stripe/resources/issuing/card.rb +25 -0
  71. data/lib/stripe/resources/issuing/card_details.rb +10 -0
  72. data/lib/stripe/resources/issuing/cardholder.rb +14 -0
  73. data/lib/stripe/resources/issuing/dispute.rb +25 -0
  74. data/lib/stripe/resources/issuing/transaction.rb +13 -0
  75. data/lib/stripe/resources/line_item.rb +8 -0
  76. data/lib/stripe/resources/login_link.rb +15 -0
  77. data/lib/stripe/resources/mandate.rb +8 -0
  78. data/lib/stripe/resources/order.rb +33 -0
  79. data/lib/stripe/resources/order_return.rb +10 -0
  80. data/lib/stripe/resources/payment_intent.rb +82 -0
  81. data/lib/stripe/resources/payment_link.rb +23 -0
  82. data/lib/stripe/resources/payment_method.rb +33 -0
  83. data/lib/stripe/resources/payout.rb +33 -0
  84. data/lib/stripe/resources/person.rb +32 -0
  85. data/lib/stripe/{plan.rb → resources/plan.rb} +5 -0
  86. data/lib/stripe/resources/price.rb +21 -0
  87. data/lib/stripe/resources/product.rb +22 -0
  88. data/lib/stripe/resources/promotion_code.rb +12 -0
  89. data/lib/stripe/resources/quote.rb +105 -0
  90. data/lib/stripe/resources/radar/early_fraud_warning.rb +12 -0
  91. data/lib/stripe/resources/radar/value_list.rb +15 -0
  92. data/lib/stripe/resources/radar/value_list_item.rb +14 -0
  93. data/lib/stripe/resources/recipient.rb +14 -0
  94. data/lib/stripe/resources/recipient_transfer.rb +7 -0
  95. data/lib/stripe/resources/refund.rb +42 -0
  96. data/lib/stripe/resources/reporting/report_run.rb +13 -0
  97. data/lib/stripe/resources/reporting/report_type.rb +13 -0
  98. data/lib/stripe/resources/reversal.rb +30 -0
  99. data/lib/stripe/resources/review.rb +21 -0
  100. data/lib/stripe/resources/setup_attempt.rb +10 -0
  101. data/lib/stripe/resources/setup_intent.rb +43 -0
  102. data/lib/stripe/resources/shipping_rate.rb +12 -0
  103. data/lib/stripe/resources/sigma/scheduled_query_run.rb +16 -0
  104. data/lib/stripe/{sku.rb → resources/sku.rb} +7 -2
  105. data/lib/stripe/resources/source.rb +47 -0
  106. data/lib/stripe/resources/source_transaction.rb +8 -0
  107. data/lib/stripe/resources/subscription.rb +35 -0
  108. data/lib/stripe/resources/subscription_item.rb +26 -0
  109. data/lib/stripe/resources/subscription_schedule.rb +33 -0
  110. data/lib/stripe/resources/tax_code.rb +10 -0
  111. data/lib/stripe/resources/tax_id.rb +27 -0
  112. data/lib/stripe/{product.rb → resources/tax_rate.rb} +7 -3
  113. data/lib/stripe/resources/terminal/configuration.rb +15 -0
  114. data/lib/stripe/resources/terminal/connection_token.rb +12 -0
  115. data/lib/stripe/resources/terminal/location.rb +15 -0
  116. data/lib/stripe/resources/terminal/reader.rb +75 -0
  117. data/lib/stripe/resources/test_helpers/test_clock.rb +25 -0
  118. data/lib/stripe/{three_d_secure.rb → resources/three_d_secure.rb} +5 -0
  119. data/lib/stripe/resources/token.rb +10 -0
  120. data/lib/stripe/resources/topup.rb +23 -0
  121. data/lib/stripe/resources/transfer.rb +27 -0
  122. data/lib/stripe/resources/usage_record.rb +8 -0
  123. data/lib/stripe/resources/usage_record_summary.rb +8 -0
  124. data/lib/stripe/{recipient.rb → resources/webhook_endpoint.rb} +6 -5
  125. data/lib/stripe/resources.rb +100 -0
  126. data/lib/stripe/search_result_object.rb +86 -0
  127. data/lib/stripe/singleton_api_resource.rb +10 -4
  128. data/lib/stripe/stripe_client.rb +886 -223
  129. data/lib/stripe/stripe_configuration.rb +194 -0
  130. data/lib/stripe/stripe_object.rb +301 -132
  131. data/lib/stripe/stripe_response.rb +89 -27
  132. data/lib/stripe/util.rb +272 -122
  133. data/lib/stripe/version.rb +3 -1
  134. data/lib/stripe/webhook.rb +121 -0
  135. data/lib/stripe.rb +94 -116
  136. data/stripe.gemspec +35 -16
  137. metadata +127 -156
  138. data/.gitattributes +0 -4
  139. data/.github/ISSUE_TEMPLATE.md +0 -5
  140. data/.gitignore +0 -5
  141. data/.travis.yml +0 -15
  142. data/lib/stripe/alipay_account.rb +0 -20
  143. data/lib/stripe/application_fee.rb +0 -20
  144. data/lib/stripe/application_fee_refund.rb +0 -18
  145. data/lib/stripe/balance.rb +0 -4
  146. data/lib/stripe/balance_transaction.rb +0 -9
  147. data/lib/stripe/bank_account.rb +0 -28
  148. data/lib/stripe/bitcoin_transaction.rb +0 -9
  149. data/lib/stripe/card.rb +0 -25
  150. data/lib/stripe/charge.rb +0 -80
  151. data/lib/stripe/country_spec.rb +0 -9
  152. data/lib/stripe/customer.rb +0 -77
  153. data/lib/stripe/dispute.rb +0 -15
  154. data/lib/stripe/event.rb +0 -5
  155. data/lib/stripe/file_upload.rb +0 -31
  156. data/lib/stripe/invoice.rb +0 -27
  157. data/lib/stripe/order.rb +0 -27
  158. data/lib/stripe/order_return.rb +0 -9
  159. data/lib/stripe/refund.rb +0 -7
  160. data/lib/stripe/reversal.rb +0 -18
  161. data/lib/stripe/source.rb +0 -11
  162. data/lib/stripe/subscription.rb +0 -31
  163. data/lib/stripe/subscription_item.rb +0 -12
  164. data/lib/stripe/token.rb +0 -5
  165. data/lib/stripe/transfer.rb +0 -16
  166. data/openapi/fixtures.json +0 -1383
  167. data/openapi/fixtures.yaml +0 -1130
  168. data/openapi/spec.json +0 -19749
  169. data/openapi/spec.yaml +0 -15359
  170. data/test/api_fixtures.rb +0 -29
  171. data/test/api_stub_helpers.rb +0 -125
  172. data/test/stripe/account_test.rb +0 -204
  173. data/test/stripe/alipay_account_test.rb +0 -19
  174. data/test/stripe/api_operations_test.rb +0 -31
  175. data/test/stripe/api_resource_test.rb +0 -496
  176. data/test/stripe/apple_pay_domain_test.rb +0 -33
  177. data/test/stripe/application_fee_refund_test.rb +0 -38
  178. data/test/stripe/application_fee_test.rb +0 -14
  179. data/test/stripe/balance_test.rb +0 -11
  180. data/test/stripe/bank_account_test.rb +0 -41
  181. data/test/stripe/bitcoin_receiver_test.rb +0 -70
  182. data/test/stripe/bitcoin_transaction_test.rb +0 -21
  183. data/test/stripe/charge_test.rb +0 -59
  184. data/test/stripe/country_spec_test.rb +0 -20
  185. data/test/stripe/coupon_test.rb +0 -44
  186. data/test/stripe/customer_card_test.rb +0 -42
  187. data/test/stripe/customer_test.rb +0 -116
  188. data/test/stripe/dispute_test.rb +0 -42
  189. data/test/stripe/errors_test.rb +0 -18
  190. data/test/stripe/file_upload_test.rb +0 -66
  191. data/test/stripe/invoice_item_test.rb +0 -55
  192. data/test/stripe/invoice_test.rb +0 -66
  193. data/test/stripe/list_object_test.rb +0 -170
  194. data/test/stripe/order_return_test.rb +0 -21
  195. data/test/stripe/order_test.rb +0 -59
  196. data/test/stripe/plan_test.rb +0 -52
  197. data/test/stripe/product_test.rb +0 -47
  198. data/test/stripe/recipient_card_test.rb +0 -40
  199. data/test/stripe/recipient_test.rb +0 -50
  200. data/test/stripe/refund_test.rb +0 -39
  201. data/test/stripe/reversal_test.rb +0 -43
  202. data/test/stripe/sku_test.rb +0 -50
  203. data/test/stripe/source_test.rb +0 -43
  204. data/test/stripe/stripe_client_test.rb +0 -440
  205. data/test/stripe/stripe_object_test.rb +0 -361
  206. data/test/stripe/stripe_response_test.rb +0 -46
  207. data/test/stripe/subscription_item_test.rb +0 -54
  208. data/test/stripe/subscription_test.rb +0 -60
  209. data/test/stripe/three_d_secure_test.rb +0 -23
  210. data/test/stripe/transfer_test.rb +0 -50
  211. data/test/stripe/util_test.rb +0 -149
  212. data/test/stripe_test.rb +0 -41
  213. data/test/test_data.rb +0 -59
  214. data/test/test_helper.rb +0 -41
data/test/api_fixtures.rb DELETED
@@ -1,29 +0,0 @@
1
- # APIFixtures loads fixture data generated by the core Stripe API so that we
2
- # can have slightly more accurate and up-to-date resource information in our
3
- # tests.
4
- class APIFixtures
5
- def initialize
6
- @fixtures = ::JSON.parse(File.read("#{PROJECT_ROOT}/openapi/fixtures.json"),
7
- symbolize_names: true)
8
- freeze_recursively(@fixtures)
9
- end
10
-
11
- def [](name)
12
- @fixtures[name]
13
- end
14
-
15
- def fetch(*args)
16
- @fixtures.fetch(*args)
17
- end
18
-
19
- private
20
-
21
- def freeze_recursively(data)
22
- data.each do |k, v|
23
- if v.is_a?(Hash)
24
- freeze_recursively(v)
25
- end
26
- end
27
- data.freeze
28
- end
29
- end
@@ -1,125 +0,0 @@
1
- require "json"
2
-
3
- # Provides a set of helpers for a test suite that help to mock out the Stripe
4
- # API.
5
- module APIStubHelpers
6
- protected
7
-
8
- # Uses Webmock to stub out the Stripe API for testing purposes. The stub will
9
- # by default respond on any routes that are defined in the bundled OpenAPI
10
- # spec with generated response data.
11
- #
12
- # An `override_app` can be specified to get finer grain control over how a
13
- # stubbed endpoint responds. It can be used to modify generated responses,
14
- # mock expectations, or even to override the default stub completely.
15
- def stub_api
16
- stub_request(:any, /^#{Stripe.api_base}/).to_rack(new_api_stub)
17
- end
18
-
19
- def stub_connect
20
- stub_request(:any, /^#{Stripe.connect_base}/).to_return(:body => "{}")
21
- end
22
-
23
- private
24
-
25
- # APIStubMiddleware intercepts a response generated by Committee's stubbing
26
- # middleware, and tries to replace it with a better version from a set of
27
- # sample fixtures data generated from Stripe's core API service.
28
- class APIStubMiddleware
29
- API_FIXTURES = APIFixtures.new
30
-
31
- def initialize(app)
32
- @app = app
33
- end
34
-
35
- def call(env)
36
- # We use a vendor specific prefix (`x-resourceId`) embedded in the schema
37
- # of any resource in our spec to identify it (e.g. "charge"). This allows
38
- # us to cross-reference that response with some data that we might find
39
- # in our fixtures file so that we can respond with a higher fidelity
40
- # response.
41
- schema = env["committee.response_schema"]
42
- resource_id = schema.data["x-resourceId"] || ""
43
-
44
- if data = API_FIXTURES[resource_id.to_sym]
45
- # standard top-level API resource
46
- data = fixturize_lists_recursively(schema, data)
47
- env["committee.response"] = data
48
- elsif schema.properties["object"].enum == ["list"]
49
- # top level list (like from a list endpoint)
50
- data = fixturize_list(schema, env["committee.response"])
51
- env["committee.response"] = data
52
- else
53
- raise "no fixture for: #{resource_id}"
54
- end
55
- @app.call(env)
56
- end
57
-
58
- private
59
-
60
- # If schema looks like a Stripe list object, then we look up the resource
61
- # that the list is supposed to include and inject it into `data` as a
62
- # fixture. Also calls into that other schema recursively so that sublists
63
- # within it will also be assigned a fixture.
64
- def fixturize_list(schema, data)
65
- object_schema = schema.properties["object"]
66
- if object_schema && object_schema.enum == ["list"]
67
- subschema = schema.properties["data"].items
68
- resource_id = subschema.data["x-resourceId"] || ""
69
- if subdata = API_FIXTURES[resource_id.to_sym]
70
- subdata = fixturize_lists_recursively(subschema, subdata)
71
-
72
- data = data ? data.dup : {}
73
- data[:data] = [subdata]
74
- end
75
- end
76
- data
77
- end
78
-
79
- # Examines each of the given schema's properties and calls #fixturize_list
80
- # on them so that any sublists will be populated with sample fixture data.
81
- def fixturize_lists_recursively(schema, data)
82
- data = data.dup
83
- schema.properties.each do |key, subschema|
84
- data[key.to_sym] = fixturize_list(subschema, data[key.to_sym])
85
- end
86
- data
87
- end
88
- end
89
-
90
- # A descendant of the standard `Sinatra::Base` that we can use to enrich
91
- # certain types of responses.
92
- class APIStubApp < Sinatra::Base
93
- not_found do
94
- "endpoint not found in API stub: #{request.request_method} #{request.path_info}"
95
- end
96
- end
97
-
98
- # Finds the latest OpenAPI specification in ROOT/openapi/ and parses it for
99
- # use with Committee.
100
- def self.initialize_spec
101
- spec_data = ::JSON.parse(File.read("#{PROJECT_ROOT}/openapi/spec.json"))
102
-
103
- driver = Committee::Drivers::OpenAPI2.new
104
- driver.parse(spec_data)
105
- end
106
-
107
- # Creates a new Rack app with Committee middleware it.
108
- def new_api_stub
109
- Rack::Builder.new {
110
- use Committee::Middleware::RequestValidation, schema: @@spec,
111
- params_response: true, strict: true
112
- use Committee::Middleware::Stub, schema: @@spec,
113
- call: true
114
- use APIStubMiddleware
115
- run APIStubApp.new
116
- }
117
- end
118
-
119
- # Parse and initialize the OpenAPI spec only once for the entire test suite.
120
- @@spec = initialize_spec
121
-
122
- # The default override app. Doesn't respond on any route so generated
123
- # responses will always take precedence.
124
- @@default_override_app = Sinatra.new
125
- end
@@ -1,204 +0,0 @@
1
- require File.expand_path('../../test_helper', __FILE__)
2
-
3
- module Stripe
4
- class AccountTest < Test::Unit::TestCase
5
- FIXTURE = API_FIXTURES.fetch(:account)
6
-
7
- should "be listable" do
8
- accounts = Stripe::Account.list
9
- assert_requested :get, "#{Stripe.api_base}/v1/accounts"
10
- assert accounts.data.kind_of?(Array)
11
- assert accounts.data[0].kind_of?(Stripe::Account)
12
- end
13
-
14
- should "be retrievable using singular endpoint" do
15
- account = Stripe::Account.retrieve
16
- assert_requested :get, "#{Stripe.api_base}/v1/account"
17
- assert account.kind_of?(Stripe::Account)
18
- end
19
-
20
- should "be retrievable using plural endpoint" do
21
- account = Stripe::Account.retrieve(FIXTURE[:id])
22
- assert_requested :get, "#{Stripe.api_base}/v1/accounts/#{FIXTURE[:id]}"
23
- assert account.kind_of?(Stripe::Account)
24
- end
25
-
26
- should "be rejectable" do
27
- account_data = {:id => 'acct_foo'}
28
- stub_request(:get, "#{Stripe.api_base}/v1/accounts/acct_foo").
29
- to_return(body: JSON.generate(account_data))
30
-
31
- stub_request(:post, "#{Stripe.api_base}/v1/accounts/acct_foo/reject").
32
- to_return(body: JSON.generate(account_data))
33
-
34
- account = Stripe::Account.retrieve('acct_foo')
35
- account.reject(:reason => 'fraud')
36
- end
37
-
38
- should "be creatable" do
39
- account = Stripe::Account.create(:metadata => {})
40
- assert_requested :post, "#{Stripe.api_base}/v1/accounts"
41
- assert account.kind_of?(Stripe::Account)
42
- end
43
-
44
- should "be saveable" do
45
- account = Stripe::Account.retrieve(FIXTURE[:id])
46
- account.metadata['key'] = 'value'
47
- account.save
48
- assert_requested :post, "#{Stripe.api_base}/v1/accounts/#{FIXTURE[:id]}"
49
- end
50
-
51
- should "be updateable" do
52
- account = Stripe::Account.update(FIXTURE[:id], metadata: {foo: 'bar'})
53
- assert_requested :post, "#{Stripe.api_base}/v1/accounts/#{FIXTURE[:id]}"
54
- assert account.kind_of?(Stripe::Account)
55
- end
56
-
57
- should "be deletable" do
58
- account = Stripe::Account.retrieve(FIXTURE[:id])
59
- account = account.delete
60
- assert_requested :delete, "#{Stripe.api_base}/v1/accounts/#{FIXTURE[:id]}"
61
- assert account.kind_of?(Stripe::Account)
62
- end
63
-
64
- context "#bank_account=" do
65
- should "warn that #bank_account= is deprecated" do
66
- old_stderr = $stderr
67
- $stderr = StringIO.new
68
- begin
69
- account = Stripe::Account.retrieve(FIXTURE[:id])
70
- account.bank_account = "tok_123"
71
- message = "NOTE: Stripe::Account#bank_account= is " +
72
- "deprecated; use #external_account= instead"
73
- assert_match Regexp.new(message), $stderr.string
74
- ensure
75
- $stderr = old_stderr
76
- end
77
- end
78
- end
79
-
80
- context "#deauthorize" do
81
- should "deauthorize an account" do
82
- account = Stripe::Account.retrieve(FIXTURE[:id])
83
-
84
- # Unfortunately, the OpenAPI spec doesn't yet cover anything under the
85
- # Connect endpoints, so for just stub this out with Webmock.
86
- stub_request(:post, "#{Stripe.connect_base}/oauth/deauthorize").
87
- with(body: { 'client_id' => 'ca_1234', 'stripe_user_id' => account.id}).
88
- to_return(body: JSON.generate({ 'stripe_user_id' => account.id }))
89
- account.deauthorize('ca_1234', 'sk_test_1234')
90
- end
91
- end
92
-
93
- context "#legal_entity=" do
94
- should 'disallow direct overrides' do
95
- account = Stripe::Account.retrieve(FIXTURE[:id])
96
-
97
- assert_raise NoMethodError do
98
- account.legal_entity = {:first_name => 'Blah'}
99
- end
100
-
101
- account.legal_entity.first_name = 'Blah'
102
- end
103
- end
104
-
105
- context "#serialize_params" do
106
- should "serialize an a new additional_owners" do
107
- obj = Stripe::Util.convert_to_stripe_object({
108
- :object => "account",
109
- :legal_entity => Stripe::StripeObject.construct_from({
110
- }),
111
- }, {})
112
- obj.legal_entity.additional_owners = [
113
- { :first_name => "Joe" },
114
- { :first_name => "Jane" },
115
- ]
116
-
117
- expected = {
118
- :legal_entity => {
119
- :additional_owners => {
120
- "0" => { :first_name => "Joe" },
121
- "1" => { :first_name => "Jane" },
122
- }
123
- }
124
- }
125
- assert_equal(expected, obj.serialize_params)
126
- end
127
-
128
- should "serialize on an partially changed additional_owners" do
129
- obj = Stripe::Util.convert_to_stripe_object({
130
- :object => "account",
131
- :legal_entity => {
132
- :additional_owners => [
133
- Stripe::StripeObject.construct_from({
134
- :first_name => "Joe"
135
- }),
136
- Stripe::StripeObject.construct_from({
137
- :first_name => "Jane"
138
- }),
139
- ]
140
- }
141
- }, {})
142
- obj.legal_entity.additional_owners[1].first_name = "Stripe"
143
-
144
- expected = {
145
- :legal_entity => {
146
- :additional_owners => {
147
- "1" => { :first_name => "Stripe" }
148
- }
149
- }
150
- }
151
- assert_equal(expected, obj.serialize_params)
152
- end
153
-
154
- should "serialize on an unchanged additional_owners" do
155
- obj = Stripe::Util.convert_to_stripe_object({
156
- :object => "account",
157
- :legal_entity => {
158
- :additional_owners => [
159
- Stripe::StripeObject.construct_from({
160
- :first_name => "Joe"
161
- }),
162
- Stripe::StripeObject.construct_from({
163
- :first_name => "Jane"
164
- }),
165
- ]
166
- }
167
- }, {})
168
-
169
- expected = {
170
- :legal_entity => {
171
- :additional_owners => {}
172
- }
173
- }
174
- assert_equal(expected, obj.serialize_params)
175
- end
176
-
177
- # Note that the empty string that we send for this one has a special
178
- # meaning for the server, which interprets it as an array unset.
179
- should "serialize on an unset additional_owners" do
180
- obj = Stripe::Util.convert_to_stripe_object({
181
- :object => "account",
182
- :legal_entity => {
183
- :additional_owners => [
184
- Stripe::StripeObject.construct_from({
185
- :first_name => "Joe"
186
- }),
187
- Stripe::StripeObject.construct_from({
188
- :first_name => "Jane"
189
- }),
190
- ]
191
- }
192
- }, {})
193
- obj.legal_entity.additional_owners = nil
194
-
195
- expected = {
196
- :legal_entity => {
197
- :additional_owners => ""
198
- }
199
- }
200
- assert_equal(expected, obj.serialize_params)
201
- end
202
- end
203
- end
204
- end
@@ -1,19 +0,0 @@
1
- require File.expand_path('../../test_helper', __FILE__)
2
-
3
- module Stripe
4
- class AlipayAccountTest < Test::Unit::TestCase
5
- FIXTURE = API_FIXTURES.fetch(:alipay_account)
6
-
7
- should "raise on #retrieve" do
8
- assert_raises NotImplementedError do
9
- Stripe::AlipayAccount.retrieve FIXTURE[:id]
10
- end
11
- end
12
-
13
- should "raise on #update" do
14
- assert_raises NotImplementedError do
15
- Stripe::AlipayAccount.update FIXTURE[:id], {}
16
- end
17
- end
18
- end
19
- end
@@ -1,31 +0,0 @@
1
- # -*- coding: utf-8 -*-
2
- require File.expand_path('../../test_helper', __FILE__)
3
-
4
- module Stripe
5
- class ApiOperationsTest < Test::Unit::TestCase
6
- class UpdateableResource < APIResource
7
- include Stripe::APIOperations::Save
8
-
9
- def self.protected_fields
10
- [:protected]
11
- end
12
- end
13
-
14
- context ".update" do
15
- should "post the correct parameters to the resource URL" do
16
- stub_request(:post, "#{Stripe.api_base}/v1/updateableresources/id").
17
- with(body: { foo: "bar" }).
18
- to_return(body: JSON.generate({ foo: "bar" }))
19
- resource = UpdateableResource::update("id", { foo: "bar" })
20
- assert_equal('bar', resource.foo)
21
- end
22
-
23
- should "error on protected fields" do
24
- e = assert_raises do
25
- UpdateableResource::update("id", { protected: "bar" })
26
- end
27
- assert_equal "Cannot update protected field: protected", e.message
28
- end
29
- end
30
- end
31
- end