Testing specific payment methods
See the dedicated instructions for testing chargeback scenarios for:
To test the dispute flow, you can simulate a chargeback and then make Disputes API calls to handle the simulated dispute, or test the process in your Customer Area.
This is how it works:
- Create a test payment with a
holderName
value that triggers one of the chargeback scenarios that you can simulate. - Capture the test payment.
- Wait for the webhook that indicates the simulated chargeback is created.
- Use the information from your test environment to test handling the chargeback using the Disputes API, or use your test Customer Area.
Test the dispute flow
-
In your test environment, submit a payment request with the
holderName
set to any of the following values, depending on the scenario you want to simulate:- Chargeback:{reason_code}: A chargeback with a specific reason code. For a list of available reason codes, refer to Dispute reason codes.
You may have to temporarily disable or lower the risk score for the Card/bank account holder name contains a non-alphabetic character risk check.
- Chargeback: A chargeback without an explicit reason code.
- Chargeback Reversed: A ChargebackReversed status without an explicit reason code.
- Second Chargeback: A SecondChargeback status without an explicit reason code.
The following example shows a /payments request to simulate a chargeback with reason code 10.4.
Payment request to simulate chargeback reason code 10.4Expand viewCopy link to code blockCopy codecurl https://checkout-test.adyen.com/v71/payments -H 'x-api-key: ADYEN_API_KEY' \ -H 'content-type: application/json' \ -d '{ "amount": { "currency": "EUR", "value": 1000 }, "reference": "YOUR_ORDER_NUMBER", "paymentMethodIf you are using the /authorise endpoint, change the object to card": { "type": "scheme", "encryptedCardNumber": "test_4111111111111111", "encryptedExpiryMonth": "test_03", "encryptedExpiryYear": "test_2030", "encryptedSecurityCode": "test_737", "holderName": "chargeback:10.4" }, "returnUrl": "https://your-company.com/...", "merchantAccount": "YOUR_MERCHANT_ACCOUNT" }' You receive a response containing a
pspReference
, our unique identifier for the payment. You need thispspReference
in the next step. - Chargeback:{reason_code}: A chargeback with a specific reason code. For a list of available reason codes, refer to Dispute reason codes.
-
To capture the test payment, make a /payments/{paymentPspReference}/captures request, where
{paymentPspReference}
is thepspReference
you received in the payment response. Specify:amount
: Thevalue
andcurrency
specified in the payment request.
Capture requestExpand viewCopy link to code blockCopy codecurl https://checkout-test.adyen.com/v71/payments/{paymentPspReference}/captures \ -H 'x-api-key: ADYEN_API_KEY' \ -H 'content-type: application/json' \ -d '{ "merchantAccount": "YOUR_MERCHANT_ACCOUNT", "amount": { "currency": "EUR", "value": 1000 }, "reference": "YOUR_UNIQUE_REFERENCE" }' You receive a response containing:
pspReference
: the PSP reference associated with this capture request. Note that this is different from the PSP reference associated with the original payment request.
The payment will then go through SentforSettle, Settled, and finally the Chargeback status. This process can take up to 24 hours to complete.
-
Wait for the webhook. In this example, you will receive a NOTIFICATION_OF_CHARGEBACK. This webhook contains a
pspReference
, which is the unique identifier for the dispute. For example:NOTIFICATION_OF_CHARGEBACK webhookExpand viewCopy link to code blockCopy code{ "live":"false", "notificationItems":[ { "NotificationRequestItem":{ "additionalData":{ "chargebackReasonCode":"10.4", "modificationMerchantReferences":"", "chargebackSchemeCode":"visa", "defensePeriodEndsAt":"2021-11-29T01:30:57+01:00", "autoDefended":"false", "defendable" : "true", "disputeStatus":"Undefended" }, "amount":{ "currency":"EUR", "value":1000 }, "eventCode":"NOTIFICATION_OF_CHARGEBACK", "eventDate":"2021-11-11T01:30:57+01:00", "merchantAccountCode":"YOUR_MERCHANT_ACCOUNT", "merchantReference":"YOUR_REFERENCE", "originalReference":"8515785619639602", "paymentMethod":"visa", "pspReference":"9915555555555555", "reason":"Other Fraud-Card Absent Environment", "success":"true" } } ] } -
After the chargeback is created, you can use the Disputes API to handle the simulated dispute, or use your Customer Area.
Using the Disputes API:
Using the Customer Area:
- Go to Revenue & risk > Disputes
- Select the simulated dispute and either accept or defend the dispute.