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'

Но, к сожалению, это решение убивает кроссплатформенность.

Другие вопросы по тегам