测试对接
开始之前
Easily test with our SDK wizard
To successfully complete the test in this document, you must:
Test iOS SDK integration
The test consists of:
- Simulating an ad click and installing the app:
- If you implement ATT, follow these instructions.
- If you don't implement ATT, follow these instructions.
- Inspection the conversion data of the install.
Apps that implement ATT
Follow these instructions if you implement App Tracking Transparency (ATT) in your app.
Attribution will occur via ID matching if the following conditions are met:
- The attribution link contains the
idfa
parameter - ATT is implemented and:
requestTrackingAuthorization
is called beforestart
(by utilizingwaitForATTUserAuthorization
)- User consent is given.
Step 1: Simulate ad click
Simulate an ad click via an attribution link. Structure the attribution link as follows:
https://app.appsflyer.com/<app_id>?pid=<media_source>
&idfa=<registered_device_idfa>
Where:
app_id
is your AppsFlyer app ID (includingid
suffix)pid
is the media source to which the install should be attributed toidfa
is the registered device's IDFA.
举例
If your app ID is id123456789
, the attribution link might look like this:
https://app.appsflyer.com/id123456789?pid=conversionTest1&idfa=1A2B3C4D-9128-4597-1234-
04E23D654321
Step 2: Install the app
Enable debug mode and install the app on a registered test device.
Step 3: Execute test
Proceed to inspect conversion data.
Apps that don't implement ATT
Step 1: Simulate an ad click
Simulate an ad click via an attribution link. Structure the attribution link as follows:
https://app.appsflyer.com/<app_id>?pid=<media_source>
Where:
app_id
is your AppsFlyer app ID (includingid
prefix)pid
is the media source to which the install should be attributed to.
举例
If your app ID is id123456789
, the attribution link might look like this:
https://app.appsflyer.com/id123456789?pid=conversionTest1
Step 2: Install the app
Enable debug mode and install the app on any device–since the IDFA used to register the device isn't available, device registration has no effect in this case.
Step 3: Execute test
Proceed to inspect conversion data.
建议
More often than not, tests using attribution links are performed more than once. That's why it's recommended to use one of the attribution parameters to "version" your tests–it makes it easier to understand which link triggered which conversion.
In the above example, the value of
pid
isconversionTest1
. In consecutive tests, increment the value ofpid
toconversionTest2
,conversionTest3
, and so on.
Inspect conversion data
After simulating an ad click and installing the app, follow these steps to inspect the install's conversion data.
Step 1: Retrieve install UID
Once the app is installed, In the Xcode terminal, search for conversions.appsflyer
. Look for the uid
parameter and copy its value.
Step 2: Inspect conversion data
Go to the conversion data test API and fill in the required fields:
app-id
: Your app IDdevice_id
: paste the value ofuid
from step 1.devkey
- Application's devkey. Learn here how to get it.
Then, click Try it! to execute the test.
如测试成功,您会看到:
If ATT is implemented and user consent is given, the result is a 200 response similar to (truncated for readability):
{
...
"af_status" = "Non-organic";
...
"match_type" = id_matching;
"media_source" = conversionTest1;
...
}
Otherwise, attribution occurs probabilistically and the result is a 200 response similar to (truncated for readability):
{
...
"af_status" = "Non-organic";
...
"match_type" = probabilistic;
"media_source" = conversionTest1;
...
}
If the install isn't attributed, the result is a 200 response with the following payload:
{
"af_message" = "organic install";
"af_status" = Organic;
"install_time" = "2021-08-23 06:59:51.194";
"is_first_launch" = 1;
}
注意
It might take up to 30 minutes for installs to appear in the dashboard.
Troubleshooting the iOS SDK integration
Installs and events are not recorded
There could be several reasons why installs and events are not recorded:
-
Bad App ID format: If you specify an app ID in the wrong format, installs and events are not recorded. When setting the app ID in the delegate file, make sure that it is comprised of numbers only. In case the app ID is in the wrong format, the log displays the following error:
\[ERROR\] AppsFlyer: -\[AppsFlyerTracker validateAppID\] AppsFlyer Error: appleAppID should be a number!
-
Incorrect App ID: If you specify an app ID that doesn't exist in your account, install and events are not recorded. The log shows the following error:
AppsFlyer: -[AppsFlyerHTTPClient sendRequestEventToServer:isRequestFromCache:appID:isDebug: completionHandler:]_block_invoke sent information to server, status = 404
The 404
error indicates that the SDK is unable to find the app in your account.
-
Bad Dev Key: If you specify an incorrect dev key, installs and events are not recorded. The log shows the following error:
AppsFlyer: -[AppsFlyerHTTPClient sendRequestEventToServer:isRequestFromCache:appID:isDebug:completionHandler:] _block_invoke sent information to server, status = 400
The 400 error indicates that the SDK is unable to authenticate the request to record installs and events. Check that the dev key is the correct one. Also, make sure that the dev key contains only alphanumeric characters.
正确:
[AppsFlyerLib shared].appleAppID = @"340954503";
不正确:
[AppsFlyerLib shared].appleAppID = @"id340954503";
不正确:
[AppsFlyerLib shared].appleAppID = @"com.appslyer.sampleapp";
App ID and dev key are correct but install is not recorded
场景
The app contains the correct app ID and dev key but installs are not recorded.
可能的原因
The SDK is not initiated correctly. Make sure to call the start
method in applicationDidBecomeActive
:
- (void)applicationDidBecomeActive:(UIApplication *)application {
[[AppsFlyerLib shared] start];
}
func applicationDidBecomeActive(application: UIApplication) {
AppsFlyerLib.shared().start()
}
The log shows "AppsFlyer dev key missing or empty. aborting"
场景
You are trying to see installs and in-app events in the log. The log shows "AppsFlyer dev key missing or empty. Aborting".
可能的原因
The dev key is not set. Make sure to set it in appDelegate in the didFinishLaunchingWithOptions
method:
[AppsFlyerLib shared].appsFlyerDevKey = @"<YOUR_DEV_KEY>";
AppsFlyerLib.shared().appsFlyerDevKey = "<YOUR_DEV_KEY>"
安装始终归因于自然安装
场景
You are testing attribution using attribution links. You've implemented the SDK conversion listener but the log always shows that the install is organic. In addition, no non-organic install is recorded in the dashboard.
可能的原因
- The attribution link you are using is incorrect. See our guide on attribution links.
- Make sure that the device you are testing on is registered.
Revenue is not recorded properly
场景
您正在测试具有收入的应用内事件。事件显示在控制面板中,但不记录收入
可能的原因
收入参数的格式不正确。不要给收入值设置任何格式。它不应包含逗号分隔符、货币符号或文本。例如,收入事件应类似于 1234.56。
I'm getting a 404 on install or event recording
场景
You are testing installs and in-app events to see that they are attributed to the correct media source. However, response 404 appears for both install and in-app events. Neither the install nor the in-app events appear in the dashboard.
可能的原因
A 404 response indicates that the app ID is incorrect. See Installs and Events are not recorded.
I get response 400 on install or event recording
场景
您正在尝试在日志中测试应用内事件。触发事件时,在日志中看到响应 400。
可能的原因
This might indicate an issue with the dev key. Check that the dev key is the correct one. Also, make sure that the dev key contains only alphanumeric characters. See Installs and Events are not recorded.
I get response 403 on install or event recording
场景
You are trying to test installs and other conversion events in the log. When you trigger these events, you see response 403 (forbidden) in the logs.
可能的原因
This might be because you have the Zero package, which does not include attribution data; only data on clicks and impressions. To start receiving attribution data, learn more about the different AppsFlyer packages, and update as needed. You can also contact our customer engagement team at [email protected] if you have questions about our packages.
Creating an iOS debug app
可选
You can utilize Xcode's compilation configuration capabilities to configure an easy-to-use debug app. It will enable you to switch between your debug and production apps by tapping into Xcode's active compilation conditions.
注意
If you don't mind mixing production data with test traffic, you can skip to testing the integration. All tests can be performed for both production and debug apps.
This is achieved by configuring a User-Defined Setting in your project's Build Settings and exposing it via an info.plist
property.
Step 1: Add a debug app to AppsFlyer
Add a new pending iOS app to AppsFlyer or ask a team member with dashboard access to add it. Choose any available app ID–You will need it in step 3. Make sure the ID is 9 digits and starts with four 1s, for example, 111167538.
Step 2: Add a User-Defined Setting
- In Xcode, in the file navigator view, select your project root and go to Build Settings.
- Click + in the toolbar and select Add User-Defined Setting. In this case, we name it
AF_APP_ID
. - Expand the newly created User-Defined Setting:
- Set the Debug Conditional Setting to your test app's app ID (mentioned in step 1)
- Set the Release Conditional Setting to your production app's app ID.
Step 3: Expose app IDs via info.plist
Go to the project's info.plist
and add a new property (called AFAppID
in this case). Set its value to $(AF_APP_ID)
(based on the User-Defined Setting name in step 2).
Step 4: Retrieve and set the app ID
To access and use app ID during SDK initialization, add the following code to didFinishLaunchingWithOptions
in your AppDelegate
:
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// ...
guard let appID : String = Bundle.main.object(forInfoDictionaryKey: "AFAppID") as? String else {
fatalError("Cannot find app ID")
}
AppsFlyerLib.shared().appleAppID = appID
// ...
return true
}
Step 5: Run app using Debug build configuration
To change the active build configuration:
- go to Product > Scheme > Edit Scheme....
- Select Run and change the Build configuration to Debug or Release, as needed.
Now, when you use the Debug configuration to build your app, Xcode will use the debug app ID that you configured in step 2.
已更新 3 months ago