私のメインクラスはSettings.java
クラスを参照し、新しいプロパティを参照せずにmavenを実行すると、うまく動作します:
mvn assembly:assembly
新しいプロパティを参照すると、次のエラーが発生します。
[ERROR] /Users/.../service.java:[41,58] cannot find symbol
[ERROR] symbol : method getDefaultScore()
これはマルチ Maven プロジェクトです。依存関係は、別の Maven モジュールであるローカル依存関係であるため、この新しいプロパティを取得しない理由がわかりません。
mvn clean
キャッシュされた場合に備えて、ルートで実行しました。
注: このアプリケーションは、IntelliJ 経由でビルドして実行すると正常に動作しますが、maven を使用すると、この新しいプロパティが気に入らないようです (これは単に、割り当てた値を返す文字列プロパティではなく、そうではありません)。プロパティファイルなどからの読み取り)。
デバッグで実行する場合:
mvn assembly:assembly -X
同じ「シンボルが見つかりません」というメッセージが表示され、場所は他のmavenモジュールのクラスであり、次のようになります。
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:2.3.2:compile (default-compile) on project myapp-jobs: Compilation failure
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:213)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.MojoExecutor.executeForkedExecutions(MojoExecutor.java:365)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:199)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:84)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:59)
at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.java:183)
at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:161)
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:319)
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:156)
at org.apache.maven.cli.MavenCli.execute(MavenCli.java:537)
at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:196)
at org.apache.maven.cli.MavenCli.main(MavenCli.java:141)
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.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:290)
at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:230)
at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409)
at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:352)
Caused by: org.apache.maven.plugin.CompilationFailureException: Compilation failure
at org.apache.maven.plugin.AbstractCompilerMojo.execute(AbstractCompilerMojo.java:656)
at org.apache.maven.plugin.CompilerMojo.execute(CompilerMojo.java:128)
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:101)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:209)
... 23 more
念のため、新しいプロパティの参照を古いプロパティに置き換えたところ、mvn コマンドは問題なく実行されたので、def です。新しいプロパティに問題があります。これは単に次のとおりです。
public class Settings {
..
..
private String defaultScore = "100";
public String getDefaultScore() {
return defaultScore;
}
}
私のコンピューター/Mavenのバージョンなど:
- Apache Maven 3.0.3 (r1075438; 2011-02-28 12:31:09-0500)
- Maven ホーム: /Users/../java/apache-maven-3.0.3
- Java バージョン: 1.6.0_31、ベンダー: Apple Inc.
- Java ホーム: /System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Home
- デフォルトのロケール: en_US、プラットフォームのエンコード: MacRoman
- OS 名:「mac os x」、バージョン:「10.7.4」、アーキテクチャ:「x86_64」、ファミリ:「mac」