我有一个问题,maven 在测试结束时被卡住了。
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 4.235 sec
Results :
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0
但是BUILD SUCCESSFUL
消息没有出现。为什么?
我发现我们正在使用
Process proc = new ProcessBuilder("cmd", "/C", "start", "/B", "notepad").start();
启动外部应用程序。该应用程序与 java 进程相关联。在外部应用程序也终止之前,java 进程不会终止。即使有所有这些 cmd/start 魔法,Windows 和 Java 也不会分离进程。在阅读了大量的博客和网站后,他们都提出了同样的建议。刷新输出缓冲区,并读入所有 STD ERR 和 STD OUT 流。不过,这并没有奏效。Java 仍然说:“还有一个应用程序在运行!”
答案是确保 java 不知道应用程序正在运行。我这样做了,通过使用
Process proc = new ProcessBuilder("rundll32", "SHELL32.DLL,ShellExec_RunDLL", "notepad").start();
在此方法中,java 调用 rundll32 并使用 SHELL32 DLL 函数 ShellExec_RunDLL 来启动应用程序。Java 没有检测到这个新的“记事本”进程,并且RunDLL32几乎立即退出。我还遵循了所有正确的方法来刷新输出并获取rundll32的 STD OUT 和 STD ERR 。
后台应用程序记事本能够正常运行,并且 maven 按预期完成。
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 3.935 sec
Results :
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 7 seconds
[INFO] Finished at: Mon Mar 18 11:28:54 PDT 2013
[INFO] Final Memory: 27M/72M
[INFO] ------------------------------------------------------------------------