How to code and test StoreKit pending purchases in Swift and XCode
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/cd7c1/cd7c1af904ba09d13e483d8721cf3120f6f11aad" alt="Three flowers that represent StoreKit, Swift and XCode side by side. Beneath them sits the text “Code & Test StoreKit Product Pending Purchases.”"
A step by step guide on implementing and testing StoreKit product pending purchases for In-App Purchases and Subscriptions.
The guide was made using our Free iOS StoreKit 2 Open Source project which is recommended for developers or business folk wishing to learn about how In-App Purchases or Subscriptions work and the code behind them.
The following walkthrough assumes that you have already setup StoreKit with an offering and developed a UI that allows an app to display products.
Please consult the guides below to learn how to setup StoreKit, create a StoreKit offering or design a UI that considers all StoreKit scenarios.
Step One: Setup StoreKit Purchases
data:image/s3,"s3://crabby-images/c2fac/c2fac5080ef3d3ce4344c3b41f027133db01b90e" alt="A screenshot of an iOS app showing a completed purchase."
Follow our guide below to setup StoreKit purchases.
Step Two: Enable Ask to Buy
data:image/s3,"s3://crabby-images/a0442/a04429c941a84e0b2ade45ed8cd2a85b086fe863" alt="A screenshot of Xcode highlighting the location of the Editor tab in the Xcode menu and Enable Ask to Buy. If Ask to Buy is already enabled, this will say Disable Ask to Buy."
Follow our guide below to enable Ask to Buy in XCode.
Step Three: Make the purchase
data:image/s3,"s3://crabby-images/16d1d/16d1d4a64c6ed922f8078df43cab00b939b240e1" alt="A screenshot of an iOS app asking for permission after requesting a purchase of a non-consumable in-app purchase."
Run the app and attempt to make a purchase.
The app will prompt you to ask for permission.
You should also consider marking the transaction as pending using UI similar to the one below.
data:image/s3,"s3://crabby-images/3e386/3e38625f843e5ef04b3712714bf122cf11389836" alt="A screenshot of an iOS app showing a non-consumable in-app purchase in a pending state."
Step Four: Approve or Deny
data:image/s3,"s3://crabby-images/075f0/075f0ffc700307c05a80de4fddbb6e91a38421e7" alt="A screenshot of the XCode StoreKit Transaction Manager. Highlighted is a pending transaction. We have used arrows to point out the tick and cross that appear after selected a pending transaction. The tick approves the transaction whilst the x denies it."
Follow our guide below to learn how to approve or deny a pending transaction.
If you deny a pending purchase, your app will not be notified via the StoreKit listener. This means that in order to update from the pending UI, your app must request the product purchase state again for it to know the transaction is not pending. We recommend requesting product statuses every time an app enters the foreground.
If you approved the purchase, your app will be notified via the StoreKit listener and you should use this to update the UI to show that it has been successfully purchased.
data:image/s3,"s3://crabby-images/bb23b/bb23b947613b8ba51d1e0b1b8310291261ef4a1d" alt="A screenshot of an iOS app showing a non-consumable in-app purchase in a purchased state."
Looking to learn more about developing apps with StoreKit 2?
Read our comprehensive development guide linked below to learn about all the secrets behind developing In-App Purchases and Subscriptions with StoreKit 2.