Gradle exec `ошибка =2, нет такого файла или каталога` в Android Studio Bumblebee | 2021.1.1
После обновления до Android Studio Bumblebee | 2021.1.1 (Mac OS), плагин gradle exec не работал.
Вот пример задачи gradle с exec:
task testExec(type: Exec) {
commandLine 'npm', '--version'
}
При запуске этой задачи в Android Studio получите эту ошибку:
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
Но при запуске из консоли -
./gradlew app:testExec
, все ок:
> Task :app:testExec
8.3.1
1 ответ
Выяснил причину проблемы.
Новая Android Studio заменяет
$PATH
переменная по какой-то причине. При запуске
commandLine 'bash', '-c', 'echo $PATH'
, он печатает:
/usr/bin:/bin:/usr/sbin:/sbin
. Но
npm
расположен в
/usr/local/bin/npm
.
Временное решение на данный момент состоит в том, чтобы добавить
/usr/local/bin/
в PATH следующим образом:
commandLine 'bash', '-c', 'PATH=$PATH:/usr/local/bin/; npm --version'
Но, к сожалению, это решение убивает кроссплатформенность.