Crash in 'BrowserSwitchClient' in version 3.14.0
See original GitHub issueFrom: @TatyanaRTB
General information
- SDK/Library version: Android SDK 4.0.1
- Environment: Development
- Android Version and Device: All Android versions with various devices
- Braintree dependencies:
- com.braintreepayments.api:braintree:3.14.0
- com.braintreepayments.api:drop-in:4.6.0
- com.braintreepayments.api:google-payment:3.3.1
Issue description
The issue is related to https://github.com/braintree/braintree_android/issues/308. Firstly we observed crash from the #308 and now after fixes crash happens in next step by code, when BrowserSwitchOptions.start is called:
ThreeDSecure:
public static void continuePerformVerification(BraintreeFragment fragment, ThreeDSecureRequest request, ThreeDSecureLookup threeDSecureLookup) {
boolean showChallenge = threeDSecureLookup.getAcsUrl() != null;
String threeDSecureVersion = threeDSecureLookup.getThreeDSecureVersion();
fragment.sendAnalyticsEvent(String.format("three-d-secure.verification-flow.challenge-presented.%b", showChallenge));
fragment.sendAnalyticsEvent(String.format("three-d-secure.verification-flow.3ds-version.%s", threeDSecureVersion));
if (!showChallenge) {
completeVerificationFlowWithNoncePayload(fragment, threeDSecureLookup.getCardNonce());
} else if (!threeDSecureVersion.startsWith("2.")) {
fragment.browserSwitch(13487, ThreeDSecureV1BrowserSwitchHelper.getUrl(fragment.getReturnUrlScheme(), fragment.getConfiguration().getAssetsUrl(), request, threeDSecureLookup));
} else {
performCardinalAuthentication(fragment, threeDSecureLookup);
}
}
BrowserSwitchFragment:
public void browserSwitch(int requestCode, String url) {
BrowserSwitchOptions browserSwitchOptions = (new BrowserSwitchOptions()).requestCode(requestCode).url(Uri.parse(url));
this.browserSwitchClient.start(browserSwitchOptions, this);
}
BrowserSwitchClient:
public void start(BrowserSwitchOptions browserSwitchOptions, Fragment fragment) {
if (fragment instanceof BrowserSwitchListener) {
this.start(browserSwitchOptions, fragment, (BrowserSwitchListener)fragment);
} else {
throw new IllegalArgumentException("Fragment must implement BrowserSwitchListener.");
}
}
The issue can be reproduced by the following steps:
- Select credit card option in DropIn dialog
- Enter card parameters
- Press Go/Next button on the keyboard two-three times: https://monosnap.com/file/kcCFXR7wLZkKU7MtGu1bgvD6dHJaqF
Please block the button from several payment attempts if request to Braintree API is already in progress. Several payment flows are started in parallel and BraintreeFragment is detached from Activity when receive first successful payment result. Other payment results cause this crash.
java.lang.IllegalStateException: Fragment must be attached to an activity.
at com.braintreepayments.browserswitch.BrowserSwitchClient.start(BrowserSwitchClient.java:206) ~[na:0.0]
at com.braintreepayments.browserswitch.BrowserSwitchClient.start(BrowserSwitchClient.java:186) ~[na:0.0]
at com.braintreepayments.browserswitch.BrowserSwitchFragment.browserSwitch(BrowserSwitchFragment.java:59) ~[na:0.0]
at com.braintreepayments.api.ThreeDSecure.continuePerformVerification(ThreeDSecure.java:266) ~[na:0.0]
at com.braintreepayments.api.ThreeDSecure$3.onLookupComplete(ThreeDSecure.java:155) ~[na:0.0]
at com.braintreepayments.api.ThreeDSecure$7.success(ThreeDSecure.java:503) ~[na:0.0]
at com.braintreepayments.api.internal.HttpClient$3.run(HttpClient.java:288) ~[na:0.0]
at android.os.Handler.handleCallback(Handler.java:739) ~[na:0.0]
at android.os.Handler.dispatchMessage(Handler.java:95) ~[na:0.0]
at android.os.Looper.loop(Looper.java:157) ~[na:0.0]
at android.app.ActivityThread.main(ActivityThread.java:5429) ~[na:0.0]
at java.lang.reflect.Method.invoke(Native Method) ~[na:0.0]
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) ~[na:0.0]
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) ~[na:0.0]
Issue Analytics
- State:
- Created 3 years ago
- Reactions:1
- Comments:17 (8 by maintainers)
Top Results From Across the Web
Crash in 'BrowserSwitchClient' in version 3.14.0 #313
General information SDK/Library version: Android SDK 4.0.1 Environment: ... Crash in 'BrowserSwitchClient' in version 3.14.0 #313.
Read more >Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start FreeTop Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
Top GitHub Comments
@sshropshire Hello,
Here you can find log: log_braintree_crash.txt
We hope it will be informative. Note that we can not reproduce the issue with Braintree Demo project. The issue happens if press twice on this button: https://monosnap.com/file/kcCFXR7wLZkKU7MtGu1bgvD6dHJaqF Affected different devices: Samsung S10e (Android 9), Google Pixel 3XL (Android 10), Huawei P9 EVA-L09 (Android 6)
Here is a fragment of our code: braintree_intergration_code.txt
Thank you in advance and hope to hear back from you soon.
Version
6.0.0
of the Drop-in SDK has been released, which is compatible with v4 of the Braintree Android SDK and should resolve this issue.