2017-05-25 58 views
0

家伙,我有两个问题: 1)如何测试完整的应用程序(我的意思运行测试,而不是单元)从minSDK版本每个API,我成立。这是什么自动过程? 2)发布后,我的应用我有我的应用程序发布控制台(系统运行4.4奇巧)的ANR错误:奇巧4.4 ANR错误后发布

java.lang.RuntimeException: 
    at android.app.ActivityThread.installProvider(ActivityThread.java:5011) 
    at android.app.ActivityThread.installContentProviders(ActivityThread.java:4582) 
    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4522) 
    at android.app.ActivityThread.access$1500(ActivityThread.java:151) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1381) 
    at android.os.Handler.dispatchMessage(Handler.java:110) 
    at android.os.Looper.loop(Looper.java:193) 
    at android.app.ActivityThread.main(ActivityThread.java:5292) 
    at java.lang.reflect.Method.invokeNative(Native Method:0) 
    at java.lang.reflect.Method.invoke(Method.java:515) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:824) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:640) 
    at dalvik.system.NativeStart.main(Native Method:0) 
Caused by: java.lang.ClassNotFoundException: 
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:497) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:457) 
    at android.app.ActivityThread.installProvider(ActivityThread.java:4996) 

我设置了类似配置的AVD模拟器上我的Android工作室我编译后我有例外如下:

1829-2839/com.google.android.gms.persistent E/LoadManifestTask: Can't find Chimera operation impl class com.google.android.location.copresence.GcmRegistrationChimeraReceiver dropping operation 
                        java.lang.ClassNotFoundException: Didn't find class "com.google.android.location.copresence.GcmRegistrationChimeraReceiver" on path: DexPathList[[zip file "/system/framework/com.android.media.remotedisplay.jar", zip file "/system/framework/com.android.location.provider.jar", zip file "/system/priv-app/PrebuiltGmsCore.apk", zip file "/data/data/com.google.android.gms/code_cache/secondary-dexes/PrebuiltGmsCore.apk.classes2.zip", zip file "/data/data/com.google.android.gms/code_cache/secondary-dexes/PrebuiltGmsCore.apk.classes3.zip", zip file "/data/data/com.google.android.gms/code_cache/secondary-dexes/PrebuiltGmsCore.apk.classes4.zip", zip file "/data/data/com.google.android.gms/code_cache/secondary-dexes/PrebuiltGmsCore.apk.classes5.zip"],nativeLibraryDirectories=[/vendor/lib, /system/lib]] 
                         at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) 
                         at java.lang.ClassLoader.loadClass(ClassLoader.java:497) 
                         at java.lang.ClassLoader.loadClass(ClassLoader.java:457) 
                         at bws.<init>(:com.google.android.gms:799) 
                         at bwt.run(:com.google.android.gms:2049) 
                         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
                         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
                         at java.lang.Thread.run(Thread.java:841) 


                        [ 05-25 03:04:16.195 1623: 1638 D/   ] 
                        HostConnection::get() New Host Connection established 0xb9183a30, tid 1638 

任何想法什么cuse这个问题? 我的应用在棒棒糖和Nugat上运行良好。 我也贴我的gradle产出: 应用插件: 'com.android.application' 应用插件:'境界,Android的

android { 
    compileSdkVersion 25 
    buildToolsVersion "25.0.2" 
    defaultConfig { 
     applicationId 'com.fff.hhh' 
     minSdkVersion 15 
     targetSdkVersion 25 
     versionCode 8 
     versionName '4.0' 
     testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" 
     multiDexEnabled true 
    } 
    buildTypes { 
     release { 
      minifyEnabled false 
      proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 
     } 
    } 
    productFlavors { 
    } 
} 

dependencies { 
    compile fileTree(include: ['*.jar'], dir: 'libs') 
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', { 
     exclude group: 'com.android.support', module: 'support-annotations' 
    }) 
    compile 'com.android.support:appcompat-v7:25.3.1' 
    compile 'com.android.support:design:25.3.1' 
    compile 'com.google.android.gms:play-services:10.2.6' 
    compile 'com.android.support:cardview-v7:25.3.1' 
    compile 'com.github.bumptech.glide:glide:3.8.0' 
    compile 'com.android.support:recyclerview-v7:25.3.1' 
    compile 'com.jakewharton:butterknife:8.5.1' 
    compile 'com.squareup.retrofit2:retrofit:2.3.0' 
    compile 'com.squareup.retrofit2:converter-gson:2.3.0' 
    testCompile 'junit:junit:4.12' 
    annotationProcessor 'com.jakewharton:butterknife-compiler:8.5.1' 
} 
+0

您在使用之前检查播放服务的可用性? –

回答

0

如上所述官方docs

我们强烈鼓励使用GoogleApiClient类到 访问Google Play服务功能。这种方法可以让你 附加一个OnConnectionFailedListener对象到你的客户端。要 检测,如果该设备具有谷歌的相应版本播放 服务APK,实现onConnectionFailed()回调方法。如果 连接失败因丢失或过期的 谷歌Play版本APK,回调会收到错误代码,如 SERVICE_MISSINGSERVICE_VERSION_UPDATE_REQUIRED,或 SERVICE_DISABLED。 ...另一种方法是使用 isGooglePlayServicesAvailable()方法。你到了 单对象,它提供使用 GoogleApiAvailability.getInstance()这个方法的引用。你可以拨打 这种方法的主要活动的onResume()方法。如果结果代码是 SUCCESS,那么Google Play服务APK是最新的,您可以继续连接 。

请确保您遵循这些规则。

0

要测试的应用程序对特定版本:

1. Write espresso test 
2. run those tests on the device with desired api level 

为了解决这个问题,GCM添加​​

apply plugin: 'com.google.gms.google-services' 

你在上面贴上你的build.gradle结束。

+0

android studio说“11:41 \t Gradle同步失败:找不到id为'com.google.gms.google-services'的插件”。 –