Включить git-revision из зависимостей - PullRequest
0 голосов
/ 09 октября 2018

Короткая версия: я хочу сохранить последний номер ревизии (, относящийся к отдельному модулю ) как из текущего модуля, так и из его зависимостей в манифесте фляги.

У меня естьмультимодульный проект Maven.Модули встроены в затененные банки (которые включают в себя все зависимости), чтобы их можно было независимо развертывать.Некоторые из модулей зависят от других модулей (пара модулей, которые создаются в первую очередь, является «общими» для других модулей).При построении этих модулей я хочу включить последнюю коммит-ревизию модуля И зависимости последней коммит-ревизии.Все мои модули хранятся в одном git-repo (без "sub-gits").

Пример:

<module>common</module> 
<module>data</module>
<module>application1</module>

Первые два модуля - это общие модули, которые являются зависимостями в application1.

Допустим, последний коммит был 864ccc, где я внес изменения как в Data, так и в application1.Common однако последний раз был изменен в коммите 889a01.При сборке этих модулей я ожидаю следующий вывод в манифесте:

Revision-App: 864ccc
Revision-Common: 889a01
Revision-Data: 864ccc

Ранее я использовал buildnumber-maven-plugin от MojoHaus с SVN.С помощью этой настройки я смог сделать это с помощью следующего в pom.xml:

    <build>
        <sourceDirectory>src</sourceDirectory>
        <testSourceDirectory>test</testSourceDirectory>
        <finalName>${project.artifactId}</finalName>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>${maven-compiler-plugin.version}</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <archive>
                        <index>true</index>
                        <manifest>
                            <addClasspath>true</addClasspath>
                        </manifest>
                        <manifestEntries>
                            <URL>${project.url}</URL>
                            <Application-Build-Time>${timeStamp}</Application-Build-Time>
                            <Revision-Appl>${app.rev}</Revision-Application>
                            <Revision-Data>${data.rev}</Revision-Data>
                            <Revision-Common>${common.rev}</Revision-Common>
                        </manifestEntries>
                    </archive>
                    <outputDirectory>../target</outputDirectory>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.codehaus.mojo</groupId>
                <artifactId>buildnumber-maven-plugin</artifactId>
                <version>${buildnumber-maven-plugin.version}</version>
                <dependencies>
                    <dependency>
                        <groupId>org.tmatesoft.svnkit</groupId>
                        <artifactId>svnkit</artifactId>
                        <version>1.8.5</version>
                    </dependency>
                </dependencies>
                <configuration>
                    <providerImplementations>
                        <svn>javasvn</svn>
                    </providerImplementations>
                </configuration>
                <executions>
                    <execution>
                        <id>timeStamp</id>
                        <phase>validate</phase>
                        <goals>
                            <goal>create</goal>
                        </goals>
                        <configuration>
                            <doCheck>false</doCheck>
                            <doUpdate>false</doUpdate>
                            <buildNumberPropertyName>timeStamp</buildNumberPropertyName>
                            <format>{0,date,yyyy-MM-dd HH:mm:ss}</format>
                            <items>
                                <item>timestamp</item>
                            </items>
                            <revisionOnScmFailure>SVN_FAILURE</revisionOnScmFailure>
                        </configuration>
                    </execution>
                    <execution>
                        <id>appRev</id>
                        <phase>validate</phase>
                        <goals>
                            <goal>create</goal>
                        </goals>
                        <configuration>
                            <doCheck>false</doCheck>
                            <doUpdate>false</doUpdate>
                            <buildNumberPropertyName>app.rev</buildNumberPropertyName>
                            <useLastCommittedRevision>true</useLastCommittedRevision>
                            <scmDirectory>${project.basedir}</scmDirectory>
                        </configuration>
                    </execution>
                    <execution>
                        <id>commonRev</id>
                        <phase>validate</phase>
                        <goals>
                            <goal>create</goal>
                        </goals>
                        <configuration>
                            <doCheck>false</doCheck>
                            <doUpdate>false</doUpdate>
                            <buildNumberPropertyName>common.rev</buildNumberPropertyName>
                            <useLastCommittedRevision>true</useLastCommittedRevision>
                            <scmDirectory>${project.basedir}/../common</scmDirectory>
                            <getRevisionOnlyOnce>false</getRevisionOnlyOnce>
                            <revisionOnScmFailure>SVN_FAILURE</revisionOnScmFailure>
                        </configuration>
                    </execution>
                    <execution>
                        <id>dataRev</id>
                        <phase>validate</phase>
                        <goals>
                            <goal>create</goal>
                        </goals>
                        <configuration>
                            <doCheck>false</doCheck>
                            <doUpdate>false</doUpdate>
                            <buildNumberPropertyName>data.rev</buildNumberPropertyName>
                            <useLastCommittedRevision>true</useLastCommittedRevision>
                            <scmDirectory>${project.basedir}/../data</scmDirectory>
                            <getRevisionOnlyOnce>false</getRevisionOnlyOnce>
                            <revisionOnScmFailure>SVN_FAILURE</revisionOnScmFailure>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>2.4.1</version>
                <configuration>
                    <artifactSet>
                        <includes>
                            <include>com.company.package:*</include>
                        </includes>
                    </artifactSet>
                    <createDependencyReducedPom>true</createDependencyReducedPom>
                </configuration>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

Но я не могу понять, как сделать то же самое с git.Я могу получить только версию HEAD супер-помпа (содержащую модули).

Не могли бы вы помочь мне получить такой же результат с помощью git?

Запуск mvn build дает мне следующий вывод:

[INFO] --- buildnumber-maven-plugin:1.4:create (appRev) @ common ---
[INFO] Executing: /bin/sh -c cd '/home/user/java/application1' && 'git' 'rev-parse' '--verify' 'HEAD'
[INFO] Working directory: /home/user/java/application1
[INFO] Storing buildNumber: 864cccf9056d273313eb9fb690b58674f72d4a6b at timestamp: 1539006765309
[INFO] Storing buildScmBranch: mvn-revision
[INFO] 
[INFO] --- buildnumber-maven-plugin:1.4:create (commonRev) @ common ---
[INFO] Executing: /bin/sh -c cd '/home/user/java/common/../common' && 'git' 'rev-parse' '--verify' 'HEAD'
[INFO] Working directory: /home/user/java/common/../common
[INFO] Storing buildNumber: 864cccf9056d273313eb9fb690b58674f72d4a6b at timestamp: 1539006765326
[INFO] Storing buildScmBranch: mvn-revision
[INFO] 
[INFO] --- buildnumber-maven-plugin:1.4:create (dataRev) @ common ---
[INFO] Executing: /bin/sh -c cd '/home/user/java/common/../data' && 'git' 'rev-parse' '--verify' 'HEAD'
[INFO] Working directory: /home/user/java/common/../data
[INFO] Storing buildNumber: 864cccf9056d273313eb9fb690b58674f72d4a6b at timestamp: 1539006765330
[INFO] Storing buildScmBranch: mvn-revision
[INFO] 

И я получаю, что запуск git rev-parse --verify HEAD даст мне этот вывод.Но я хотел бы, чтобы вывод текущей строки с git rev-list --verify HEAD -- . выводился в текущем рабочем каталоге.

У вас есть идеи?

Мне не нужно придерживаться этого плагина, я просто хочу описать результат.

...