Skip to main content
Solved

Testing Agreement Interruption does not refresh purchaseinfo


Michael
Forum|alt.badge.img+2

Hi there! I’m using an App Store sandbox user, auto-renewable subscriptions, and have enabled the “Interrupt Purchases for This Tester” option in App Store Connect.

When forcing the interruption, the `purchasePackage:` method fails with the correct error description.

I’ve set my delegate to call the method `didReceiveUpdatedPurchaserInfo:`. After the user agrees to the new terms, the App Store window closes and confirms the purchase but the delegate method `didReceiveUpdatedPurchaserInfo:` isn’t called. If I try to purchase the subscription again, I’m told I already own it.

I would expect the `didReceiveUpdatedPurchaserInfo:`delegate method to be called in this case. I’ve set up Apple Server-to-Server Notifications via the link provided by RevenueCat with no luck. Anyone know what might be going on?

Best answer by Michael

tina wrote:

Hello @Michael!

Via Tina: Revenuecat support drafted a bug report for Apple on this topic.

View original
Did this post help you find an answer to your question?

4 replies

tina
RevenueCat Staff
Forum|alt.badge.img+10
  • RevenueCat Staff
  • 338 replies
  • August 31, 2021

Hello @Michael!

I saw that this community post was opened up in our ticketing system. Pasting my response below:

I had the chance to test this with our iOS sample app to try to reproduce the same behavior you're seeing. I placed a print statement inside this code block to test if after agreeing to the new terms would hit this block.

After I agreed to the new terms, the purchase was successful. I tried subscribing again to confirm payment did go through and the print statement did indeed print, indicating that the delegate was called.

Can you double check your app if the delegate is part of the AppDelegate delegate? Documentation for reference: https://docs.revenuecat.com/docs/getting-started#optional-listening-for-purchaser-info-updates It would also be worth to try to reproduce in the sample app with a fresh sandbox account. The instructions to run the sample app are indicated in the directory's README file. You can change the sample app's configurations (bundle id, API keys, entitlement name) to match your app's settings.

 


Forum|alt.badge.img+2
  • New Member
  • 3 replies
  • September 4, 2021

Thank you for your reply @tina 

I have tested with interrupted condition (using appconnect sandbox setting).  Yes, this delegate/closure “didReceiveUpdated purchaserInfo” is called, but it is called after 5 minutes.  It’s conform RevenueCat documentation below https://docs.revenuecat.com/docs/purchaserinfo

This delegate/closure will be executed after one of the following action:  call getPurchaserInfo(), make a purchase, restore purchases.  I’ve tested this, and I can confirm what is written on the documentation.

Related with interruption testing from sandbox (accepting a new user agreement), the purchaseInfo delegate won’t automatically be called. We need to trigger actions such are written in the documentation (call getPurchaserInfo(), make a purchase, or restore purchases).  Unfortunately, when I called getPurchaserInfo() the cache will be updated if the cache is older than 5 minutes.

 

My questions are:

  1.  Is it possible that the PurchaserInfo cache to be updated automatically when there is update in device Payment queue by AppStore? https://developer.apple.com/documentation/storekit/original_api_for_in-app_purchase/testing_in-app_purchases_with_sandbox/testing_an_interrupted_purchase
  2. Is it possible to change the 5 minutes cache value programmatically/manually ? 

Michael
Forum|alt.badge.img+2
  • Author
  • Helper
  • 1 reply
  • Answer
  • September 7, 2021
tina wrote:

Hello @Michael!

Via Tina: Revenuecat support drafted a bug report for Apple on this topic.


Forum|alt.badge.img+6
  • Dedicated Member
  • 15 replies
  • April 28, 2022

Any resolution or movement on this issue? Thanks.


Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings