integration-testing - 如何以 strip 方式测试订阅续订流程?

标签 integration-testing stripe-payments

当订阅支付完成(或失败)时,我想测试我的应用程序对来自 strip 的 webhook 事件的处理。这是我迄今为止尝试过的:

  • 设置新订阅
  • 将用户的信用卡更新为可以添加到帐户的信用卡,但不会实际收费
  • 将试用结束日期更改为一秒
  • 等待几秒钟等待发送 webhook

  • 然而,根据 the documentation :

    If you have configured webhooks, the invoice will wait until one hour after the last webhook is successfully sent (or the last webhook times out after failing).



    一小时的等待时间很长,因为我正在尝试将其作为自动化集成测试套件的一部分。

    一个建议(来自 IRC)是伪造 webhook 请求,以便我的集成测试发送事件,而不是 Stripe 发送它。但是,由于 Stripe 在 webhook 中不包含任何类型的 HMAC,我不能信任有效负载中的数据。因此,我的应用程序只是从 webhook 有效负载中获取事件 ID 并获取 event from the Stripe API :

    If security is a concern, or if it's important to confirm that Stripe sent the webhook, you should only use the ID sent in your webhook and should request the remaining details from the API directly.



    如果我试图为我的测试注入(inject)虚假事件(按设计),这显然不起作用。

    测试这种场景的最佳实践是什么?

    最佳答案

    似乎没有完美的方法来做到这一点。正如@koopajah 在 comment 中所建议的那样,我在我的应用程序中添加了一个配置值,它将禁用从 Stripe 获取事件,而是只信任 webhook 中的事件数据。这允许我以几乎与生产环境相同的方式测试我的流程,因为 webhook 中的事件数据和从 Stripe 获取的事件是相同的(假设它是一个真实的 webhook 请求:)

    除非/直到 Stripe 在 webhook 请求中包含 HMAC 签名以验证它来自它们,否则我认为这是解决问题的最佳方法。

    关于integration-testing - 如何以 strip 方式测试订阅续订流程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29836883/

    相关文章:

    javascript - 如何让nock.js回复发布的数据?

    php - 如何在 symfony2 中包含 strip 客户端 api。如何在 symfony2 中包含没有类的文件

    ios - Stripe API 通过 iOS 代码创建费用?

    ruby-on-rails - 如何向卖家提供订单详细信息 Stripe

    javascript - Stripe : Use apple pay on the web for a subscription

    c# - 使用 Mock HttpClient 进行 Mock Refit SDK 注入(inject)以进行集成测试

    java - Spring/Hibernate 测试 - 完成后如何删除模式?

    javascript - Ember 组件集成测试 : `link-to` href empty

    java - 如何在测试中只执行一次方法设置

    ruby-on-rails - Stripe,取消订阅 Ruby on Rails