无法使用公地EXEC运行命令行中使用Java时触发摇篮测试
问题描述:
它是如此的有线,我不能跑“NPM -v”当我在的IntelliJ无法使用公地EXEC运行命令行中使用Java时触发摇篮测试
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.启动应用
2.使用的IntelliJ触发测试用例(右键点击并运行“MainTest”)
3.运行gradle clean check
输出是
: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)
让我知道如果你需要多少信息。 T.T
答
我面对mac机器的同样的问题。
从IntellijIDEA运行sbt时,它给出了与问题中提到的相同的错误,但从终端运行它工作正常。
事实证明,intellijidea使用不同于在环境变量中设置的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
尝试打印'PATH'环境从你的代码中剔除变量,并且在它的工作和不工作时比较结果。 PATH是否一样?它是否包含'npm'二进制文件的路径? – CrazyCoder