'Gradle exec `error=2, No such file or directory` in Android Studio Bumblebee | 2021.1.1
After updating to Android Studio Bumblebee | 2021.1.1 (Mac OS), gradle exec plugin failed to work.
Here is an example of gradle task with exec:
task testExec(type: Exec) {
commandLine 'npm', '--version'
}
When run this task in Android Studio, get this error:
Caused by: org.gradle.process.internal.ExecException: A problem occurred starting process 'command 'npm''
at org.gradle.process.internal.DefaultExecHandle.execExceptionFor(DefaultExecHandle.java:241)
at org.gradle.process.internal.DefaultExecHandle.setEndStateInfo(DefaultExecHandle.java:218)
at org.gradle.process.internal.DefaultExecHandle.failed(DefaultExecHandle.java:369)
at org.gradle.process.internal.ExecHandleRunner.run(ExecHandleRunner.java:87)
at org.gradle.internal.operations.CurrentBuildOperationPreservingRunnable.run(CurrentBuildOperationPreservingRunnable.java:42)
... 3 more
Caused by: net.rubygrapefruit.platform.NativeException: Could not start 'npm'
at net.rubygrapefruit.platform.internal.DefaultProcessLauncher.start(DefaultProcessLauncher.java:27)
at net.rubygrapefruit.platform.internal.WrapperProcessLauncher.start(WrapperProcessLauncher.java:36)
at org.gradle.process.internal.ExecHandleRunner.startProcess(ExecHandleRunner.java:98)
at org.gradle.process.internal.ExecHandleRunner.run(ExecHandleRunner.java:71)
... 4 more
Caused by: java.io.IOException: Cannot run program "npm" (in directory "/Users/pavel/AndroidStudioProjects/tempexec/app"): error=2, No such file or directory
at net.rubygrapefruit.platform.internal.DefaultProcessLauncher.start(DefaultProcessLauncher.java:25)
... 7 more
Caused by: java.io.IOException: error=2, No such file or directory
... 8 more
But when run it from console - ./gradlew app:testExec, everything is ok:
> Task :app:testExec
8.3.1
Solution 1:[1]
Found out the cause of the problem.
New Android Studio replaces $PATH variable for some reason. When launch commandLine 'bash', '-c', 'echo $PATH', it prints: /usr/bin:/bin:/usr/sbin:/sbin. But npm is located in /usr/local/bin/npm.
The temporary solution for now is to add /usr/local/bin/ to PATH like this:
commandLine 'bash', '-c', 'PATH=$PATH:/usr/local/bin/; npm --version'
But, unfortunately, this solution kills cross-platform.
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | pavelperc |
