Nicolas
Nicolas

Reputation: 894

react-native FATAL EXCEPTION caused by java.lang.NoClassDefFoundError

I'm getting this fatal exception only on my new test phone (Android 6.0). Here's the error log:

E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #2

Process: com.***, PID: 19024
java.lang.RuntimeException: An error occurred while executing doInBackground()
   at android.os.AsyncTask$3.done(AsyncTask.java:309)
   at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:354)
   at java.util.concurrent.FutureTask.setException(FutureTask.java:223)
   at java.util.concurrent.FutureTask.run(FutureTask.java:242)
   at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
   at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
   at java.lang.Thread.run(Thread.java:818)

Caused by: java.lang.NoClassDefFoundError: com.facebook.react.devsupport.InspectorPackagerConnection$Connection
   at com.facebook.react.devsupport.InspectorPackagerConnection.<init>(InspectorPackagerConnection.java:39)
   at com.facebook.react.devsupport.DevServerHelper$3.doInBackground(DevServerHelper.java:203)
   at com.facebook.react.devsupport.DevServerHelper$3.doInBackground(DevServerHelper.java:200)
   at android.os.AsyncTask$2.call(AsyncTask.java:295)
   at java.util.concurrent.FutureTask.run(FutureTask.java:237)
   at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113) 
   at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588) 
   at java.lang.Thread.run(Thread.java:818) 

I'm using quite a lot of libraries, here you go:

"buffer": "^5.0.6",
"fetchival": "^0.3.2",
"lodash": "^4.17.4",
"native-base": "^2.1.3",
"qs": "^6.4.0",
"react": "16.0.0-alpha.12",
"react-native": "0.45.1",
"react-native-background-upload": "^3.0.0-beta",
"react-native-camera": "git+https://github.com/lwansbrough/react-native-camera.git",
"react-native-datepicker": "^1.6.0",
"react-native-easy-grid": "^0.1.13",
"react-native-fetch-blob": "^0.10.6",
"react-native-fs": "^2.3.3",
"react-native-image-picker": "^0.26.3",
"react-native-keyboard-aware-scroll-view": "^0.2.9",
"react-native-linear-gradient": "^2.0.0",
"react-native-message-bar": "^1.6.0",
"react-native-swiper": "^1.5.4",
"react-native-vector-icons": "^4.0.1",
"react-native-video": "^1.0.0",
"react-native-video-controls": "^1.2.0",
"react-navigation": "git+https://github.com/react-community/react-navigation.git",
"react-redux": "^5.0.5",
"redux": "^3.6.0",
"redux-persist": "^4.8.0",
"redux-persist-transform-filter": "0.0.10",
"redux-thunk": "^2.2.0",
"remote-redux-devtools": "^0.5.11"

Also, here's my app/build.gradle file:

android {
    compileSdkVersion 24
    buildToolsVersion "24.0.1"

    defaultConfig {
        applicationId "com.***"
        minSdkVersion 16
        targetSdkVersion 22
        versionCode 1
        versionName "1.0"
        ndk {
            abiFilters "armeabi-v7a", "x86"
        }
    }

    signingConfigs {
        release {
            if (project.hasProperty('MYAPP_RELEASE_STORE_FILE')) {
                storeFile file(MYAPP_RELEASE_STORE_FILE)
                storePassword MYAPP_RELEASE_STORE_PASSWORD
                keyAlias MYAPP_RELEASE_KEY_ALIAS
                keyPassword MYAPP_RELEASE_KEY_PASSWORD
            }
        }
    }

    splits {
        abi {
            reset()
            enable enableSeparateBuildPerCPUArchitecture
            universalApk false  // If true, also generate a universal APK
            include "armeabi-v7a", "x86"
        }
    }
    buildTypes {
        release {
            minifyEnabled enableProguardInReleaseBuilds
            proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
            signingConfig signingConfigs.release
        }
    }
    // applicationVariants are e.g. debug, release
    applicationVariants.all { variant ->
        variant.outputs.each { output ->
            // For each separate APK per architecture, set a unique version code as described here:
            // http://tools.android.com/tech-docs/new-build-system/user-guide/apk-splits
            def versionCodes = ["armeabi-v7a":1, "x86":2]
            def abi = output.getFilter(OutputFile.ABI)
            if (abi != null) {  // null for the universal-debug, universal-release variants
                output.versionCodeOverride =
                        versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
            }
        }
    }
}

dependencies {
    compile project(':react-native-fetch-blob')
    compile project(':react-native-image-picker')
    compile project(':react-native-background-upload')
    compile project(':react-native-fs')
    compile project(':react-native-video')
    compile project(':react-native-vector-icons')
    compile project(':react-native-linear-gradient')
    compile project(':react-native-camera')
    compile fileTree(dir: "libs", include: ["*.jar"])
    compile "com.android.support:appcompat-v7:24.0.1"
    compile "com.facebook.react:react-native:+"  // From node_modules
}

// Run this once to be able to run the application with BUCK
// puts all compile dependencies into folder libs for BUCK to use
task copyDownloadableDepsToLibs(type: Copy) {
    from configurations.compile
    into 'libs'
}

This is an android only problem, the app works just fine on iOS. Also, it seems to be a dev-only problem. The release APK doesn't have this problem. Is anyone facing or faced a similar problem?

Thanks

Upvotes: 2

Views: 1303

Answers (1)

egv
egv

Reputation: 21

I got the same thing, and figured out that it was because I was resolving com.squareup.okhttp3.okhttp not to the latest version.

Making it resolve to 3.6.0 solved the problem for me

Upvotes: 2

Related Questions