webentwicklung-frage-antwort-db.com.de

React-Native assembleRelease schlägt für Task 'fehl: app: bundleReleaseJsAndAssets'

Beim Ausführen von ./gradlew assembleRelease schlägt der Build mit diesem Fehler fehl:

Error:Execution failed for task ':app:bundleReleaseJsAndAssets. 
> A problem occurred starting process 'command 'node'

Ich habe im Internet gesucht und einige Themen gefunden, aber ich konnte mein Problem nicht lösen.

Reaktive-native Version: 0.54.0

BEARBEITEN:
Jetzt verwende ich ./gradlew assembleRelease --info vom Terminal anstelle von Android Studio und erhalte unterschiedliche Fehler.
Hier ist das Ergebnis:

> Task :app:processReleaseResources
Putting task artifact state for task ':app:processReleaseResources' into context took 0.007 secs.
file or directory '**/Android/app/libs', not found
file or directory '**/node_modules/appcenter-crashes/Android/libs', not found
file or directory '**/node_modules/appcenter-analytics/Android/libs', not found
file or directory '**/node_modules/appcenter/Android/libs', not found
file or directory '**/node_modules/react-native-interactable/lib/Android/libs', not found
file or directory '**/node_modules/react-native-navigation/Android/app/libs', not found
file or directory '**/Android/app/libs', not found
file or directory '**/node_modules/appcenter-crashes/Android/libs', not found
file or directory '**/appcenter-analytics/Android/libs', not found
file or directory '**/node_modules/appcenter/Android/libs', not found
file or directory '**/node_modules/react-native-interactable/lib/Android/libs', not found
file or directory '**/node_modules/react-native-navigation/Android/app/libs', not found
Executing task ':app:processReleaseResources' (up-to-date check took 0.035 secs) due to:
  Task has failed previously.
All input files are considered out-of-date for incremental task ':app:processReleaseResources'.
Unable do incremental execution: full task run
file or directory '**/Android/app/libs', not found
file or directory '**/node_modules/appcenter-crashes/Android/libs', not found
file or directory '**/node_modules/appcenter-analytics/Android/libs', not found
file or directory '**/node_modules/appcenter/Android/libs', not found
file or directory '**/node_modules/react-native-interactable/lib/Android/libs', not found
file or directory '**/node_modules/react-native-navigation/Android/app/libs', not found
file or directory '**/Android/app/libs', not found
file or directory '**/node_modules/appcenter-crashes/Android/libs', not found
file or directory '**/node_modules/appcenter-analytics/Android/libs', not found
file or directory '**/node_modules/appcenter/Android/libs', not found
file or directory '**/node_modules/react-native-interactable/lib/Android/libs', not found
file or directory '**/node_modules/react-native-navigation/Android/app/libs', not found
Aapt2QueuedResourceProcessor is using **/Android/sdk/build-tools/26.0.2/aapt2
Failed to execute aapt
com.Android.ide.common.process.ProcessException: Failed to execute aapt
*
*
*
FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':app:processReleaseResources'.
> Failed to execute aapt


Es scheint, dass gradle in allen Modulen nach libs-Ordnern sucht, aber in den Knotenmodulen gibt es keine libs-Ordner. Das stimmt, aber ich weiß nicht, warum Gradle nach Libs-Ordner sucht.

5
Hamid

Zuerst:

react-native bundle --platform Android --dev false --entry-file index.js --bundle-output Android/app/src/main/assets/index.Android.bundle --assets-dest Android/app/src/main/res

endlich bauen:

./gradlew assembleRelease -x bundleReleaseJsAndAssets
11
anibalajt

Nur mit ./gradlew --stop und dann ./gradlew assembleRelease hat für mich gearbeitet.

5
Behzad Fattahi

Ich jetzt das ist spät. Vielleicht hilft das jemandem.

Für mich musste ich auf den neuesten react-native-sentry Upgraden.

apply from: "../../node_modules/react-native-sentry/sentry.gradle"

verursachte Problem

2
dasl

Dies funktioniert für mich, bitte folgen Sie den nachstehenden Schritten: -

1) Stoppen Sie, Gradle zu laufen  

 $ cd RectNatoveProjectName & cd Android  (Open your project and go to Android folder)  
 $ ./gradlew --stop (Run this command to stop old running Gradle service )

2) Aktualisieren Sie die Android App Build Gradle  

project.ext.react = [
        nodeExecutableAndArgs : ["/usr/local/bin/node"]
];

3) Node Details abrufen

$ which node 

> (Das Ergebnis ist wie "/usr/username/.nvm/versions/node/v10.7.0/bin/node")

4) Link Node (sehr imp Schritt kopieren Sie das obige Ergebnis in Schritt 3)

- ln -s /usr/username/.nvm/versions/node/v10.7.0/bin/node /usr/local/bin/node

5) Wenn die Rückgabedatei von Schritt 4 vorhanden ist - Gehen Sie in den Ordner/usr/local/bin/und löschen Sie die "Node" -Datei, und führen Sie den Schritt -4 erneut aus.

6) Wenn Schritt - 4 erfolgreich ausgeführt wird, wird dieses Knotenproblem gelöst.

2
omprakash8080

Die obigen Schritte haben wirklich geholfen. 

Hier sind die Skripte, die für uns mit react-native 0.55.3 funktionieren. 

Führen Sie den Befehl Android-build lokal oder CI aus, um eine APK zu generieren.

/packages.json (reag-native):

"Android-bundle": "react-native bundle --platform Android --dev false --entry-file index.js --bundle-output Android/app/src/main/assets/index.Android.bundle --assets-dest Android/app/src/main/res",
"Android-release-fix": "node ./Android-release-gradle-fix.js",
"Android-build": "yarn killbin && yarn Android-clean && yarn Android-release-fix && yarn Android-bundle && cd Android && ./gradlew assembleRelease -x bundleReleaseJsAndAssets --info",
"Android-clean": "cd Android && ./gradlew clean",
"killbin": "rm -rf ./node_modules/.bin",

Android-release-gradle-fix.js :

const fs = require('fs')

// Fix issues with Android resources like duplicate files
// CI: run install with --unsafe-perm option
// https://stackoverflow.com/questions/47084810/react-native-Android-duplicate-file-error-when-generating-apk
try {
        var curDir = __dirname
        var rootDir = process.cwd()

        var file = `${rootDir}/node_modules/react-native/react.gradle`
        var dataFix = fs.readFileSync(`${curDir}/Android-react-gradle-fix`, 'utf8')
        var data = fs.readFileSync(file, 'utf8')

        var doLast = "doLast \{"
        if (data.indexOf(doLast) !== -1) {
            throw "Already fixed."
        }

        var result = data.replace(/                \/\/ Set up inputs and outputs so gradle can cache the result/g, dataFix);
        fs.writeFileSync(file, result, 'utf8')
        console.log('Done')
    } catch (error) {
        console.error(error)
    }

Android-React-Gradle-Fix

doLast {
    def moveFunc = { resSuffix ->
        File originalDir = file("${resourcesDir}/drawable-${resSuffix}")
        if (originalDir.exists()) {
            File destDir = file("${resourcesDir}/drawable-${resSuffix}-v4")
            ant.move(file: originalDir, tofile: destDir)
        }
    }
    moveFunc.curry("ldpi").call()
    moveFunc.curry("mdpi").call()
    moveFunc.curry("hdpi").call()
    moveFunc.curry("xhdpi").call()
    moveFunc.curry("xxhdpi").call()
    moveFunc.curry("xxxhdpi").call()
}

// Set up inputs and outputs so gradle can cache the result

/Android/build.gradle :

buildscript {
    ext {
        buildToolsVersion = "27.0.3"
        minSdkVersion = 21
        compileSdkVersion = 27
        targetSdkVersion = 27
        supportLibVersion = "27.1.1"
        googlePlayServicesVersion = "15.0.1"
        androidMapsUtilsVersion = "0.5+"
    }
...
subprojects {
    afterEvaluate {project ->
        if (project.hasProperty("Android")) {
            Android {
                compileSdkVersion 27
                buildToolsVersion '27.0.3'
            }
        }
    }
}

/Android/app/build.gradle :

dependencies {
    implementation project(':Amazon-cognito-identity-js')
    implementation project(':appcenter-Push')
    implementation project(':react-native-fbsdk')
    implementation(project(':react-native-google-signin')) {
        exclude group: "com.google.Android.gms" // very important
    }
    implementation project(':react-native-image-picker')
    implementation project(':react-native-vector-icons')
    implementation project(':react-native-sentry')
    implementation project(':react-native-maps')
    implementation "com.google.Android.gms:play-services-auth:$googlePlayServicesVersion" // Google signin
    implementation project(':react-native-sentry')
    implementation(project(':react-native-maps')) {
        exclude group: 'com.google.Android.gms', module: 'play-services-base'
        exclude group: 'com.google.Android.gms', module: 'play-services-maps'
    }
    implementation "com.google.Android.gms:play-services-base:$googlePlayServicesVersion"
    implementation "com.google.Android.gms:play-services-maps:$googlePlayServicesVersion"
    implementation "com.google.firebase:firebase-core:15.0.2"
    implementation "com.google.firebase:firebase-messaging:15.0.2"
    implementation project(':react-native-vector-icons')
    implementation fileTree(include: ['*.jar'], dir: 'libs')
    implementation "com.Android.support:appcompat-v7:$supportLibVersion"
    implementation 'com.facebook.react:react-native:+'
    // implementation "com.Android.support:$supportLibVersion"
}
1

Ich habe die falsche Bildgröße verwendet (d. H. [email protected]), wodurch dieses Problem verursacht wurde. Als ich die Datei [email protected] gelöscht habe ... hat es funktioniert !!

0
Akhilesh Sinha

Ab RN 0.58 lauten die Befehle für CI-Builds wie folgt:

Erstelle zuerst Verzeichnisse:

mkdir -p app/build/generated/assets/react/production/release/ && mkdir -p app/build/generated/res/react/production/release

Nächster:

node ../node_modules/react-native/local-cli/cli.js bundle --platform Android --dev false --entry-file index.Android.js --bundle-output app/build/generated/assets/react/production/release/index.Android.bundle --assets-dest app/build/generated/res/react/production/release --max-workers 1 --reset-cache

Außerdem möchten Sie möglicherweise auch für Ihre Produktions-Builds Folgendes hinzufügen: this ;

--minify true

Entnommen aus Quelle von RN

HINWEIS: Wir haben --max-workers 1 CI-Ressourcen nicht erschöpfen, da sie auf niedrigere Werte (mem & cpu) beschränkt sind.

0
px5x2

Sieht aus, als hätten Sie noch kein js-Bundle erstellt. Erstellen Sie daher zunächst ein Bundle mit dem Befehl: -

 react-native bundle --platform Android --dev false --entry-file index.js --bundle-output Android/app/src/main/assets/index.Android.bundle --assets-dest Android/app/src/main/res

dann in Ihrem Projektverzeichnis 

 cd Android 

Reinige deinen Schulabschluss

 ./gradlew clean

und endlich einen Build machen

./gradlew assembleDebug

Probieren Sie das aus ... __Hoffentlich hilft es Ihnen.

0
Kartik Shah