バインドされた目標とともにライフサイクルフェーズを一覧表示するMavenコマンド?


104

私はMavenを学習しているだけなので、これは明白かもしれませんが、特定のプロジェクトの各Mavenライフサイクルフェーズに関連付けられている目標を一覧表示する簡単な方法を見つけることができません。

Mavenのデフォルトのライフサイクルフェーズと対応するデフォルトの目標がここに文書化されていることを確認しました。これまでの私の理解は、各pom.xmlが各ライフサイクルフェーズに追加の目標をバインドできることです。

では、特定のプロジェクトの各ライフサイクルフェーズで実行される目標を決定するmvnコマンドはありますか?そうでない場合、私はこれを理解するために、新しいmavenプロジェクトごとにpom.xmlを調べる必要があると思いますか?

回答:


128

mvn help:describe -Dcmd=compile (またはその他の有効なフェーズ)


3
このコマンドの出力でフェーズにバインドされた目標が表示されません。代わりに、プラグイン/フェーズが表示されます。
ドミトリー・ミンコフスキー

Mabye私は質問を間違って理解しましたが、このコマンドは質問の「逆引き」です(この目標が存在するすべてのフェーズをリストします)?リンクは、「Mavenプラグインおよび/または目標(別名Mojo-Mavenプレーンな古いJavaオブジェクト)の属性のリストを表示します。」
user2039709 2016年

131

これbuildplan-maven-pluginは、目標がフェーズにどのようにバインドされているかを示すための優れたツールです。

以下は、実行できるコマンドの例です。プラグインがまだインストールされていない場合、コマンドはプラグインを自動的にダウンロードしてインストールします。

目標を実行順にリストします

> mvn fr.jcgay.maven.plugins:buildplan-maven-plugin:list

PLUGIN                  | PHASE                  | ID                    | GOAL
--------------------------------------------------------------------------------------------
maven-enforcer-plugin   | validate               | default               | enforce
maven-dependency-plugin | process-sources        | default               | copy-dependencies
maven-resources-plugin  | process-resources      | default-resources     | resources
maven-compiler-plugin   | compile                | default-compile       | compile
maven-resources-plugin  | process-test-resources | default-testResources | testResources
maven-compiler-plugin   | test-compile           | default-testCompile   | testCompile
maven-surefire-plugin   | test                   | default-test          | test
maven-jar-plugin        | package                | default-jar           | jar
maven-assembly-plugin   | package                | make-assembly         | single
maven-install-plugin    | install                | default-install       | install
maven-deploy-plugin     | deploy                 | default-deploy        | deploy

フェーズごとのグループ目標

> mvn fr.jcgay.maven.plugins:buildplan-maven-plugin:list-phase

validate -----------------------------------------------------------------
    + maven-enforcer-plugin   | default               | enforce
process-sources ----------------------------------------------------------
    + maven-dependency-plugin | default               | copy-dependencies
process-resources --------------------------------------------------------
    + maven-resources-plugin  | default-resources     | resources
compile ------------------------------------------------------------------
    + maven-compiler-plugin   | default-compile       | compile
process-test-resources ---------------------------------------------------
    + maven-resources-plugin  | default-testResources | testResources
test-compile -------------------------------------------------------------
    + maven-compiler-plugin   | default-testCompile   | testCompile
test ---------------------------------------------------------------------
    + maven-surefire-plugin   | default-test          | test
package ------------------------------------------------------------------
    + maven-jar-plugin        | default-jar           | jar
    + maven-assembly-plugin   | make-assembly         | single
install ------------------------------------------------------------------
    + maven-install-plugin    | default-install       | install
deploy -------------------------------------------------------------------
    + maven-deploy-plugin     | default-deploy        | deploy

プラグインによるグループ目標

> mvn fr.jcgay.maven.plugins:buildplan-maven-plugin:list-plugin

maven-enforcer-plugin ---------------------------------------------------
    + validate               | default               | enforce
maven-dependency-plugin -------------------------------------------------
    + process-sources        | default               | copy-dependencies
maven-resources-plugin --------------------------------------------------
    + process-resources      | default-resources     | resources
    + process-test-resources | default-testResources | testResources
maven-compiler-plugin ---------------------------------------------------
    + compile                | default-compile       | compile
    + test-compile           | default-testCompile   | testCompile
maven-surefire-plugin ---------------------------------------------------
    + test                   | default-test          | test
maven-jar-plugin --------------------------------------------------------
    + package                | default-jar           | jar
maven-assembly-plugin ---------------------------------------------------
    + package                | make-assembly         | single
maven-install-plugin ----------------------------------------------------
    + install                | default-install       | install
maven-deploy-plugin -----------------------------------------------------
    + deploy                 | default-deploy        | deploy

ノート

デフォルトでは、目標はユーザーがを呼び出した場合に実行されるタスクを検索しますmvn deploy。などのフェーズは含まれcleanません。検索に複数のフェーズを含めるには、buildplan.tasksプロパティを使用します。

> mvn fr.jcgay.maven.plugins:buildplan-maven-plugin:list -Dbuildplan.tasks=clean,deploy

33
これは本当にデフォルトでMavenに組み込まれているはずです。
lanoxx

5
pomを調整しなくても機能します:mvn fr.jcgay.maven.plugins:buildplan-maven-plugin:list -Dbuildplan.tasks=clean,install,deploy
FibreFoX

1
この回答は、FibreFoXのコメントから始めれば完璧です。
UFL1138 2016

この答えは受け入れられた答えよりもはるかに優れていると思います。
Panayotis 2017

これはデフォルトでMavenに追加する必要があるという@Ianoxxに同意します。素晴らしいプラグイン!
ミゲルパルダル

18

役立つ1つのツールはmvn help:effective-pom、すべての変数と展開されたすべての親POMを含むPOMを印刷することです。これは、Mavenが見るものを理解するのに役立ちます。それから、すべての追加の目標(通常はそれほど多くありません)を見つけるのは非常に簡単です。

より大きな問題は、暗黙の目標です(つまり、プラグインがライフサイクルのいくつかのフェーズに自動的にフックする場合)。実際にMavenを実行せずにこれらを確認する簡単な方法はありません。これはMaven 3で改善されるはずです。それまでは、Mavenを実行し-Xて、大量のデバッグ出力と現在のフェーズ、および実行されるプラグインを出力します。


ありがとう、アーロン、これは役に立ちました!
daveのアップグレード、

これはMaven 3でどのように改善されていますか?現在のalpha-6にありますか?
Lars Corneliussen、

2
ジェイソンは私に、新しいMaven 3は実際にそれを開始する前に全体のビルドのモデルをビルドすると言った。これは、コマンドを実行せずにフックを検査(および印刷)できることを意味します。
アーロンディグラ2018年

効果的なpomは、現在それを行っていない各目標の実際の結合フェーズを表示する必要があります...ため息..
Junchen Liu

1

Mavenではなくm2eを使用している場合は、Eclipseプラグインで使用できるコードブロックを使用して実行できます。


final IMavenProjectRegistry projectRegistry = MavenPlugin.getMavenProjectRegistry();
    final IMavenProjectFacade facade = projectRegistry.getProject(project);
    projectRegistry.execute(facade, new ICallable<Void>() {
        public Void call(IMavenExecutionContext context, IProgressMonitor monitor) throws CoreException {
            MavenProject mavenProject = facade.getMavenProject(monitor);
            List<MojoExecution> mojoExecutions = ((MavenProjectFacade) facade).getMojoExecutions(monitor);
            LifecycleMappingResult mappingResult = LifecycleMappingFactory.calculateLifecycleMapping(
                    mavenProject, mojoExecutions, facade.getResolverConfiguration().getLifecycleMappingId(),
                    monitor);
            Map<MojoExecutionKey, List<IPluginExecutionMetadata>> mojoExecutionMapping = mappingResult
                    .getMojoExecutionMapping();

            Map<String, List<MojoExecutionKey>> phases = new LinkedHashMap<String, List<MojoExecutionKey>>();
            for (MojoExecutionKey execution : mojoExecutionMapping.keySet()) {
                List<MojoExecutionKey> executions = phases.get(execution.getLifecyclePhase());
                if (executions == null) {
                    executions = new ArrayList<MojoExecutionKey>();
                    phases.put(execution.getLifecyclePhase(), executions);

                    }
                    executions.add(execution);
                }

完全なソースを見てください。

既に実装されています:

http://marketplace.eclipse.org/content/phases-and-goals

目標とフェーズの関連付けを計算するm2eの機能を利用します。私はまた、mavenレベルでそれを解決しようとしています。


回答のみのリンクを投稿しないでください
ビシュ

1

チャドの答えをスクリプトに入れました(そのため、本当に長いプラグイン名を覚える必要はありません)。〜/ bin /フォルダーに配置して、どこでも使用できるようにします。

#!/usr/bin/env bash
# Created based on https://stackoverflow.com/a/35610377/529256
debug=false

goal='list-phase'
build_plan='clean,deploy'
working_directories=""

for (( i=1; i<=$#; i++ )) do
    case ${!i} in

        -h|--help)
            programName=$( basename ${0} )
            echo "Lists the goals of mvn project(s) by phase in a table";
            echo
            echo "Usage:";
            echo "    ${programName} -d|--debug -g|--goal goal -b|--build_plan build_plan [*directory]";
            echo
            echo "           --goal  The goal for the buildplan-maven-plugin (default: $goal)"
            echo "                   (possible values: list, list-plugin, list-phase)"
            echo
            echo "     --build_plan  The value of the buildplan.tasks parameter (default: $build_plan)"
            echo "                   (examples: 'clean,install', 'deploy', 'install', etc...) "
            echo
            echo "     [*directory]  The directories (with pom.xml files) to run the command in"
            exit 0;
            ;;
        -d|--debug)
            debug=true;
            echo "debug = ${debug}";
            ;;
        -b|--build_plan)
            ((i++))
            build_plan="${!i}"
            ;;
        -g|--goal)
            ((i++))
            goal="${!i}"
            ;;
        *)
            working_directory="${!i}";
            if [ ! -e "${working_directory}" ]; then
                echo "'${working_directory}' doesn't exist";
                exit 1;
            fi;
            if [ -z "${working_directories}" ]; then
                working_directories="$working_directory"
            else
                working_directories="$working_directories ${!i}"
            fi;
            ;;
    esac;
done;

if [ -z "${working_directories}" ]; then
    working_directories="$PWD"
fi

if [ ${debug} = true ]; then
    echo "working_directories=$working_directories"
    echo "goal=$goal"
    echo "build_plan=$build_plan"
fi

for workingDirectory in ${working_directories}; do
    pushd ${workingDirectory} > /dev/null
    echo "cd $workingDirectory"
    echo "mvn fr.jcgay.maven.plugins:buildplan-maven-plugin:${goal} -Dbuildplan.tasks=${build_plan}"
    mvn fr.jcgay.maven.plugins:buildplan-maven-plugin:${goal} -Dbuildplan.tasks=${build_plan}
    popd > /dev/null
done;
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.