在聚合pom上运行mvn exec:java

3

有人知道是否可以在mvn聚合POM上运行mvn exec:java吗?

目前我得到的是:

2009-09-24 02:24:14.404  :bash: karolrvn@karolrvn-laptop : ~/adfadf/programming/verknowsys/codadris/ide_projects $ mvn exec:java -e -Dexec.mainClass=codadris.coviob2.App_Coviob2
+ Error stacktraces are turned on.
[INFO] Scanning for projects...
[INFO] Reactor build order:
[INFO]   net.jcip.annotations
[INFO]   codadris.utils
[INFO]   codadris.binblocklang
[INFO]   jargs
[INFO]   codadris.dbapp
[INFO]   codadris.dbgui.scala
[INFO]   flexdock_codadris
[INFO]   codadris.gui.utils
[INFO]   codadris.gui
[INFO]   codadris.gui.treetable
[INFO]   codadris.gui.textedit
[INFO]   codadris.gui.screenspace
[INFO]   codadris.gui.suite
[INFO]   codadris.dbgui
[INFO]   All Codadris modules aggregate POM
[INFO] Searching repository for plugin with prefix: 'exec'.
[INFO] ------------------------------------------------------------------------
[INFO] Building net.jcip.annotations
[INFO]    task-segment: [exec:java]
[INFO] ------------------------------------------------------------------------
[INFO] Preparing exec:java
[INFO] No goals needed for project - skipping
[INFO] [exec:java]
[INFO] ------------------------------------------------------------------------
[ERROR] BUILD ERROR
[INFO] ------------------------------------------------------------------------
[INFO] An exception occured while executing the Java class. codadris.coviob2.App_Coviob2

[INFO] ------------------------------------------------------------------------
[INFO] Trace
org.apache.maven.lifecycle.LifecycleExecutionException: An exception occured while executing the Java class. codadris.coviob2.App_Coviob2
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoals(DefaultLifecycleExecutor.java:583)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeStandaloneGoal(DefaultLifecycleExecutor.java:512)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoal(DefaultLifecycleExecutor.java:482)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoalAndHandleFailures(DefaultLifecycleExecutor.java:330)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeTaskSegments(DefaultLifecycleExecutor.java:291)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.execute(DefaultLifecycleExecutor.java:142)
        at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:336)
        at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:129)
        at org.apache.maven.cli.MavenCli.main(MavenCli.java:287)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.codehaus.classworlds.Launcher.launchEnhanced(Launcher.java:315)
        at org.codehaus.classworlds.Launcher.launch(Launcher.java:255)
        at org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:430)
        at org.codehaus.classworlds.Launcher.main(Launcher.java:375)
Caused by: org.apache.maven.plugin.MojoExecutionException: An exception occured while executing the Java class. codadris.coviob2.App_Coviob2
        at org.codehaus.mojo.exec.ExecJavaMojo.execute(ExecJavaMojo.java:345)
        at org.apache.maven.plugin.DefaultPluginManager.executeMojo(DefaultPluginManager.java:451)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoals(DefaultLifecycleExecutor.java:558)
        ... 16 more
Caused by: java.lang.ClassNotFoundException: codadris.coviob2.App_Coviob2
        at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:252)
        at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:283)
        at java.lang.Thread.run(Thread.java:619)
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1 second
[INFO] Finished at: Thu Sep 24 02:24:17 CEST 2009
[INFO] Final Memory: 4M/94M
[INFO] ------------------------------------------------------------------------
2009-09-24 02:24:17.917  :bash: karolrvn@karolrvn-laptop : ~/adfadf/programming/verknowsys/codadris/ide_projects $

POM:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>codadris</groupId>
    <artifactId>codadris</artifactId>
    <packaging>pom</packaging>
    <version>0.0.1-SNAPSHOT</version>
    <name>All Codadris modules aggregate POM</name>
    <url>http://maven.apache.org</url>
    <modules>
        <module>codadris.binblocklang</module>
        <module>codadris.dbapp</module>
        <module>codadris.dbgui</module>
        <!-- <module>codadris.dbgui.scala</module> -->
        <module>codadris.gui</module>
        <!--<module>codadris.gui.scala</module>-->
        <module>codadris.gui.screenspace</module>
        <module>codadris.gui.suite</module>
        <module>codadris.gui.textedit</module>
        <module>codadris.gui.treetable</module>
        <module>codadris.gui.utils</module>
        <module>codadris.utils</module>
<!--        <module>ekit_codadris</module>-->
        <module>flexdock_codadris</module>
        <module>jargs</module>
        <module>net.jcip.annotations</module>
        <module>codadris.dbgui.scala</module>
    </modules>

    <!-- 2009-08-27 06:04:10 ; karolrvn ; https://dev59.com/b3M_5IYBdhLWcg3wrFMt -->
    <reporting>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-surefire-report-plugin</artifactId>
<!--                <version>2.4.2</version> -->
                <configuration>
                    <aggregate>true</aggregate>
                    <!--also set this to link to generated source reports-->
                    <linkXRef>true</linkXRef>
                </configuration>
            </plugin>
        </plugins>
    </reporting>


</project>

我想要执行的类(codadris.coviob2.App_Coviob2)在codadris.dbgui模块中。

有什么想法吗?
谢谢提前帮助。
对于可能不太正确的格式化表示抱歉,我遇到了一些换行问题。

2个回答

5
根据 Exec Maven Plugin Documentation 中关于 exec:java 的说明:

使用当前 VM 在附带项目依赖项的类路径下执行提供的 Java 类。

在这里,您展示的聚合 pom 不包含对 codadris.dbgui 模块的任何依赖项(这实际上是件好事,请不要添加它!),因此会出现 java.lang.ClassNotFoundException
为了避免这个 java.lang.ClassNotFoundException,第一种选择是从包含 Java 类的模块中运行 exec:java 目标,正如另一个答案所指出的那样。但这不是您所要求的。
幸运的是,还有另一种选择 - 使用插件依赖项 - 这在 使用插件依赖项而不是项目依赖项 中有文档记录:

有时希望执行一个 Java 类而不影响项目的依赖项。例如,如果您正在使用 Maven csharp 插件,则向项目添加 Java 依赖项将使 C# 编译器出错。因此,Exec Maven Plugin 允许您将可执行类的依赖项指定为插件依赖项。由于 Maven 在确定多模块项目的构建顺序时考虑插件依赖项,因此您的构建顺序应自动适当调整(我想)。

[...]

这应该可以解决问题。请参考上面给出的链接以获取有关 exec-maven-plugin 配置和使用插件依赖项的示例 POM 配置的更多详细信息。 附注:我有点困惑,因为 exec:java 抱怨找不到 pom.xml(“Cannot execute mojo: java. It requires a project with an existing pom.xml, but the build is not using one.”)。也许只是跟踪不准确,但这使我对父 pom 的位置产生了怀疑。 附注:PS 不再适用,OP 已更新问题并提供正确的跟踪信息。

对不起,我粘贴了错误的控制台转储,这是在错误的目录中执行的结果。真正的错误是java.lang.ClassNotFoundException: codadris.coviob2.App_Coviob2。 - KarolDepka
好的,这看起来更准确和合乎逻辑。 - Pascal Thivent
我曾尝试过用这种方法解决类似的问题,但每当我添加一个插件依赖时,它都会向依赖图中添加一个循环。 - wds

1

我建议您cd到包含所需类的模块中,并在那里运行exec:java文档中的exec:java说明它“使用当前VM执行提供的Java类,并将封闭项目的依赖项作为类路径。”,因此即使您没有上面列出的错误,它仍将失败,因为它将使用父POM的依赖项(没有任何依赖项)而不是子项的依赖项进行执行。错误堆栈跟踪有点奇怪,但这通常是典型的(不幸的是),当插件以其设计不适合的方式使用时。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接