2017-06-23 3 views
0

je reçois l'erreur suivante sur 2 appareils lors du test de mon application dans Firebase Test Lab, il se marie bien avec 2 autres dispositifs:Iabhelper plante dans Firebase laboratoire de test sur certains appareils

java.lang.RuntimeException: Unable to start activity ComponentInfo{MyActivity}: java.lang.NullPointerException: Attempt to invoke interface method 'boolean java.util.List.isEmpty()' on a null object reference 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2345) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2407) 
at android.app.ActivityThread.access$800(ActivityThread.java:149) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1324) 
at android.os.Handler.dispatchMessage(Handler.java:102) 
at android.os.Looper.loop(Looper.java:211) 
at android.app.ActivityThread.main(ActivityThread.java:5321) 
at java.lang.reflect.Method.invoke(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:372) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1016) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:811) 


Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'boolean java.util.List.isEmpty()' on a null object reference 
at util.IabHelper.startSetup(IabHelper.java:267) 
at MenuActivity.onCreate(MenuActivity.java:68) 
at CameraActivity.onCreate(CameraActivity.java:19) 
at android.app.Activity.performCreate(Activity.java:5933) 
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105) 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298) 
... 10 more 

Il semble donc être un problème venant de l'initialisation de IabHelper, voici le code où je l'ai mis en place:

String base64EncodedPublicKey = "MyKey"; 

    mHelper = new IabHelper(this, base64EncodedPublicKey); 

    mHelper.startSetup(new IabHelper.OnIabSetupFinishedListener() { 
          public void onIabSetupFinished(IabResult result) 
          { 
           if (!result.isSuccess()) { 
            Log.d(TAG, "In-app Billing setup failed: " + 
              result); 
           } else { 
            Log.d(TAG, "In-app Billing is set up OK"); 
           } 
          } 
         }); 

il fonctionne parfaitement sur mon téléphone de test et sur le téléphone de mes 2 testeurs alpha. Quelqu'un a une idée à ce sujet?

Répondre

0

Donc, c'était un bug qui a été corrigé, il semble que j'utilisais une ancienne version de IabHelper. Au cas où quelqu'un cherche, voici ce que vous devez changer IabHelper.java, ligne 267:

Remplacer:

if (!mContext.getPackageManager().queryIntentServices(serviceIntent, 0).isEmpty()) { 

avec:

List<ResolveInfo> resolveInfoList = mContext.getPackageManager().queryIntentServices(serviceIntent, 0); 
if (resolveInfoList != null && !resolveInfoList.isEmpty()) {