Adyen-for-platform icon

Test verification/KYC scenarios

Learn how you can test your error handling flows.

When verifying users, the verification checks performed by Adyen can return a range of error messages.

In your test environment, all verification checks are passed by default when the required fields and documents are provided. To test your error handling flow, you can force a scenario where one or more verification checks fail.

This allows you to reproduce an unsuccessful verification flow, including the result and corresponding verification codes. You can then also test the remediating flow to resolve the verification errors.

Requirements

Make sure that you have API credentials for the Legal Entity Management APIand Configuration API.

Step 1: Make an API request

Using the Legal Entity Management API, you can include a x-requested-verification-code in the header of your API request.

Note that requested verification codes cannot be used with hosted onboarding.

You can use requested verification codes for the following endpoints:

Use a suberror code as your requested verification code. You can include one code at a time in your request header. Requested verification codes can only be used in your test environment.

In this example, you want to test the 1_3004 suberror code The name and residence country couldn't be verified for an individual legal entity. This triggers the following verification checks:

  • Name and date of birth check
  • Residency country check

In the header of your POST /legalEntities request, include x-requested-verification-code: 1_3004.

Force legal entity verification
Expand view
Copy link to code block
Copy code
Copy code
curl https://kyc-test.adyen.com/lem/v3/legalEntities \
-H 'x-api-key: ADYEN_LEGAL_ENTITY_MANAGEMENT_API_KEY' \
-H 'content-type: application/json' \
-H 'x-requested-verification-code: 1_3004' \
-X POST \
-d '{
"type": "individual",
"individual": {
"phone": {
"number": "+31612345678",
"type": "mobile"
},
"birthData": {
"dateOfBirth": "1977-01-01"
},
"name": {
"firstName": "KYC",
"lastName": "My Test scenario"
},
"nationality": "NL",
"residentialAddress": {
"city": "Amsterdam",
"country": "NL",
"postalCode": "1111AB",
"street": "Main street"
},
"identificationData": {
"type": "nationalIdNumber",
"number": "12345678",
"issuerState": "NL"
}
}
}'

Step 2: Create account holder

For error tests for legal entities, you need to create an account holder for the legal entity of the organization, individual, or sole proprietorship.

For error tests for documents or transfer instruments, you need to create an account holder for the legal entity who owns the resource.

Step 3: Check verification errors

To get updates about the failed verification and the corresponding error codes, you can:

Make a GET /legalEntities/{id} request, specifying the id in the path.

Verification result-API response
Expand view
Copy link to code block
Copy code
Copy code
{
"verificationErrors": [
{
"code": "1_30",
"message": "Individual details couldn't be verified",
"remediatingActions": [
{
"code": "1_300",
"message": "Update individual details"
}
],
"subErrors": [
{
"code": "1_3004",
"message": "The name and residence country couldn't be verified",
"remediatingActions": [
{
"code": "1_305",
"message": "Upload a different proof of residency"
},
{
"code": "1_300",
"message": "Update individual details"
}
],
"type": "invalidInput"
}
],
"type": "invalidInput"
}
]
}
Verification result-webhook
Expand view
Copy link to code block
Copy code
Copy code
{
"data":{
"balancePlatform": "YOUR_BALANCE_PLATFORM",
"accountHolder": {
"description": "YOUR_DESCRIPTION",
"reference": "YOUR_REFERENCE",
"legalEntityId": "LE00000000000000000000001",
"capabilities": {
"sendToTransferInstrument": {
"allowed": false,
"requested": true,
"enabled": true,
"problems": [
{
"entity": {
"id": "LE00000000000000000000001",
"type": "LegalEntity"
},
"verificationErrors": [
{
"code": "1_30",
"message": "Individual details couldn't be verified.",
"remediatingActions": [
{
"code": "1_300",
"message": "Update individual details"
}
],
"subErrors": [
{
"code": "1_3004",
"message": "The name and residence country couldn't be verified",
"remediatingActions": [
{
"code": "1_305",
"message": "Upload a different proof of residency"
},
{
"code": "1_300",
"message": "Update individual details"
}
],
"type": "invalidInput"
}
]
}
]
}
],
"transferInstruments": [
{
"enabled": true,
"requested": true,
"allowed": false,
"id": "SE00000000000000000000001",
"verificationStatus": "invalid"
}
],
"verificationStatus": "invalid"
}
},
"id": "AH00000000000000000000001",
"status": "Active"
}
},
"environment": "test",
"type": "balancePlatform.accountHolder.updated"
}

The response returns the specified requested verification code and associated error codes.

Step 4: Test the remediating flow and resolve verification errors

To simulate the resolution of the verification errors, in your test environment, include the x-requested-verification-code: 0_0001 in the header of your API request.

Note that requested verification codes cannot be used with hosted onboarding.

The requested verification code can be used for the following endpoints in the Legal Entity Management API:

If your error handling is successful, the requested verification code resolves any suberrors associated with the legal entity, document, or transfer instrument.

Make a PATCH /legalEntities/{id} request, specifying the id in the path and x-requested-verification-code: 0_0001in the API header.