java - 触发 Gradle 测试时无法使用 commons-exec 在 Java 中运行命令行

标签 java intellij-idea gradle

它是如此连线,当我在 Intellij 中通过 Gradle 插件运行测试用例时,我无法运行“npm -v”

public class Main {
    public static void main(String[] args) throws IOException, InterruptedException {
        DefaultExecutor executor = new DefaultExecutor();
        executor.execute(CommandLine.parse("npm -v"));
    }
}

public class MainTest {
    @Test
    public void name() throws Exception {
        Main.main(new String[]{});
    }
}

当我执行以下操作时一切正常:
1. 使用jar启动应用
2.使用IntelliJ触发测试用例(右键单击并运行“MainTest”)
3.运行gradle clean check

但是当我使用 Gradle 插件运行测试时,一切都变得不稳定。 enter image description here

输出为

:compileJava
:processResources NO-SOURCE
:classes
:compileTestJava UP-TO-DATE
:processTestResources NO-SOURCE
:testClasses UP-TO-DATE
:test
me.imlc.helloworld.MainTest > name FAILED
    java.io.IOException at MainTest.java:12
        Caused by: java.io.IOException at MainTest.java:12

Cannot run program "npm" (in directory "."): error=2, No such file or directory
java.io.IOException: Cannot run program "npm" (in directory "."): error=2, No such file or directory
    at java.lang.ProcessBuilder.start(ProcessBuilder.java:1048)
    at java.lang.Runtime.exec(Runtime.java:620)
    at org.apache.commons.exec.launcher.Java13CommandLauncher.exec(Java13CommandLauncher.java:61)
    at org.apache.commons.exec.DefaultExecutor.launch(DefaultExecutor.java:279)
    at org.apache.commons.exec.DefaultExecutor.executeInternal(DefaultExecutor.java:336)
    at org.apache.commons.exec.DefaultExecutor.execute(DefaultExecutor.java:166)
    at org.apache.commons.exec.DefaultExecutor.execute(DefaultExecutor.java:153)
    at me.imlc.helloworld.Main.main(Main.java:11)
    at me.imlc.helloworld.MainTest.name(MainTest.java:12)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassExecuter.runTestClass(JUnitTestClassExecuter.java:114)
    at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassExecuter.execute(JUnitTestClassExecuter.java:57)
    at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassProcessor.processTestClass(JUnitTestClassProcessor.java:66)
    at org.gradle.api.internal.tasks.testing.SuiteTestClassProcessor.processTestClass(SuiteTestClassProcessor.java:51)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:35)
    at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24)

如果您需要更多信息,请告诉我。 TT

最佳答案

我在 mac 机器上遇到了同样的问题。

从 IntellijIDEA 中运行 sbt 时,它给出了与问题中提到的相同的错误,但从终端运行它工作正常。

事实证明,intellijIDEA 使用的 PATH 与环境变量中设置的 PATH 不同。

有关更多详细信息,请参阅博客 fix PATH environment variable for IntelliJ IDEA on Mac OS X

作为解决方案,我创建了一个 shell 脚本

#!/usr/bin/env bash
open -a "IntelliJ IDEA"

并使其在登录时执行 refer this answer to launch an executable at login

这似乎是一个 intellijIDEA 问题,因为其他人也遇到了同样的问题,可以引用 here

关于java - 触发 Gradle 测试时无法使用 commons-exec 在 Java 中运行命令行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46159276/

相关文章:

java - 我想在Java中除两个二进制数

java - intellij 想法 - 错误 : java: invalid source release 1. 9

intellij-idea - 在 Intellij IDEA 中哪里可以找到 Quarkus 运行配置?

java - 如何在 Debug模式下启动 Apache Zeppelin?

gradle - Gradle构建中的文件编码问题

android - 在 gradle 中重命名类

java - 如何从操作监听器运行具有多个线程的方法

java - 注解处理: how to change annotation target in Kotlin code?

java - Spring分层Fat Jar和Gradle插件layertools jarmode

java - 从 Wikipedia XML 转储中提取表