在升级到AndroidStudioBumblebees2021.1.1 (Mac )之后,gradle exec插件无法工作。
下面是使用exec进行分级任务的一个示例:
task testExec(type: Exec) {
commandLine 'npm', '--version'
}
在Android中运行此任务时,获取以下错误:
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
但是当从console - ./gradlew app:testExec
运行它时,一切都很好:
> Task :app:testExec
8.3.1
发布于 2022-01-28 22:32:32
找出了问题的原因。
由于某种原因,新的Android取代了$PATH
变量。当启动commandLine 'bash', '-c', 'echo $PATH'
时,它会打印:/usr/bin:/bin:/usr/sbin:/sbin
。但npm
位于/usr/local/bin/npm
。
目前的临时解决方案是向路径添加/usr/local/bin/
,如下所示:
commandLine 'bash', '-c', 'PATH=$PATH:/usr/local/bin/; npm --version'
但是,不幸的是,这个解决方案扼杀了跨平台。
https://stackoverflow.com/questions/70901018
复制相似问题