Ensure core plugins are bundled by Maven
Require the core plugins whenever a Gerrit build is run. These are pulled into the Maven Reactor by being inside of git submodules. Plugins can be omitted by passing a -Dgerrit.plugins.skip=true flag on the command line. Change-Id: I7246389bcae9e98d5f1d46208ff515855eb7c474
This commit is contained in:
parent
ed95865d00
commit
bf8ebbe90a
11
.gitmodules
vendored
Normal file
11
.gitmodules
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
[submodule "plugins/replication"]
|
||||||
|
path = plugins/replication
|
||||||
|
url = ../plugins/replication
|
||||||
|
|
||||||
|
[submodule "plugins/reviewnotes"]
|
||||||
|
path = plugins/reviewnotes
|
||||||
|
url = ../plugins/reviewnotes
|
||||||
|
|
||||||
|
[submodule "plugins/commit-message-length-validator"]
|
||||||
|
path = plugins/commit-message-length-validator
|
||||||
|
url = ../plugins/commit-message-length-validator
|
@ -131,45 +131,14 @@ the subproject.
|
|||||||
to the released version
|
to the released version
|
||||||
|
|
||||||
|
|
||||||
[[prepare-gerrit]]
|
[[build-gerrit]]
|
||||||
Prepare Gerrit
|
Build Gerrit
|
||||||
~~~~~~~~~~~~~~
|
~~~~~~~~~~~~
|
||||||
|
|
||||||
In all example commands it is assumed that the last release was `2.4`
|
* Build the Gerrit WAR
|
||||||
and that now the `2.5` release is prepared.
|
|
||||||
|
|
||||||
|
|
||||||
[[prepare-war-and-plugin-api]]
|
|
||||||
Prepare the Gerrit WAR and the Plugin API Jar
|
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
||||||
|
|
||||||
* link:dev-readme.html#run-acceptance-tests[Run the acceptance tests]
|
|
||||||
|
|
||||||
* Create locally a `stable-2.5` branch for making the new release
|
|
||||||
|
|
||||||
* Check in the Gerrit parent `pom.xml` that no `SNAPSHOT` version of a
|
|
||||||
Subproject is referenced
|
|
||||||
+
|
|
||||||
If there is a dependency to a `SNAPSHOT` version,
|
|
||||||
link:#subproject[release the subproject] first.
|
|
||||||
|
|
||||||
* Create a tag for the Gerrit release
|
|
||||||
+
|
|
||||||
For an `RC` release:
|
|
||||||
+
|
|
||||||
====
|
|
||||||
git tag -a -m "gerrit 2.5-rc0" v2.5-rc0
|
|
||||||
====
|
|
||||||
+
|
|
||||||
For a final `stable` release:
|
|
||||||
+
|
|
||||||
====
|
|
||||||
git tag -a -m "gerrit 2.5" v2.5
|
|
||||||
====
|
|
||||||
|
|
||||||
* Build the Gerrit WAR (without plugins) and the Plugin API Jar
|
|
||||||
+
|
+
|
||||||
====
|
====
|
||||||
|
rm -f ~/.m2/settings.xml
|
||||||
./tools/release.sh
|
./tools/release.sh
|
||||||
====
|
====
|
||||||
+
|
+
|
||||||
@ -181,57 +150,6 @@ limits the compilation to a certain browser.
|
|||||||
========================================================================
|
========================================================================
|
||||||
|
|
||||||
* Sanity check WAR
|
* Sanity check WAR
|
||||||
|
|
||||||
|
|
||||||
[[prepare-core-plugins]]
|
|
||||||
Prepare Core Plugins
|
|
||||||
^^^^^^^^^^^^^^^^^^^^
|
|
||||||
The core plugins to be prepared are:
|
|
||||||
|
|
||||||
* `plugins/replication`
|
|
||||||
|
|
||||||
For each core plugin do:
|
|
||||||
|
|
||||||
* link:dev-release-subproject.html#make-snapshot[Make a snapshot and test it]
|
|
||||||
* link:dev-release-subproject.html#prepare-release[Prepare the Release]
|
|
||||||
|
|
||||||
* Update the version of the Core Plugin in
|
|
||||||
`gerrit-package-plugins/pom.xml` to the released version
|
|
||||||
|
|
||||||
[WARNING]
|
|
||||||
========================================================================
|
|
||||||
Updating the plugin versions in `gerrit-package-plugins/pom.xml`
|
|
||||||
invalidates the Gerrit Release Tag which was created before.
|
|
||||||
|
|
||||||
If needed delete the tag and recreate it!
|
|
||||||
========================================================================
|
|
||||||
|
|
||||||
|
|
||||||
[[prepare-war-with-plugins]]
|
|
||||||
Prepare Gerrit WAR with Core Plugins
|
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
||||||
|
|
||||||
* Ensure that the Core Plugins listed in `gerrit-package-plugins/pom.xml`
|
|
||||||
point to the latest release version (no dependency to `SNAPSHOT` versions)
|
|
||||||
|
|
||||||
* Ensure that the release tag points to the `HEAD` commit
|
|
||||||
|
|
||||||
* Include core plugins into WAR
|
|
||||||
+
|
|
||||||
====
|
|
||||||
$ ./tools/version.sh --release && mvn clean package -f gerrit-package-plugins/pom.xml
|
|
||||||
$ ./tools/version.sh --reset
|
|
||||||
====
|
|
||||||
|
|
||||||
* Find WAR that includes the core plugins at
|
|
||||||
`gerrit-package-plugins\target\gerrit-full-v2.5.war`
|
|
||||||
|
|
||||||
* Compare `gerrit-package-plugins\target\gerrit-full-v2.5.war` with
|
|
||||||
`gerrit-war\target\gerrit-v2.5.war`
|
|
||||||
+
|
|
||||||
The only difference should be the core plugins jars under
|
|
||||||
`WEB-INF\plugins`.
|
|
||||||
|
|
||||||
* Test the new Gerrit version
|
* Test the new Gerrit version
|
||||||
|
|
||||||
[[publish-gerrit]]
|
[[publish-gerrit]]
|
||||||
|
6
gerrit-package-plugins/.gitignore
vendored
6
gerrit-package-plugins/.gitignore
vendored
@ -1,6 +0,0 @@
|
|||||||
/target
|
|
||||||
/.classpath
|
|
||||||
/.project
|
|
||||||
/.settings/org.maven.ide.eclipse.prefs
|
|
||||||
/.settings/org.eclipse.m2e.core.prefs
|
|
||||||
/gerrit-package-plugins.iml
|
|
@ -1,108 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!--
|
|
||||||
Copyright (C) 2012 The Android Open Source Project
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
-->
|
|
||||||
<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>com.google.gerrit</groupId>
|
|
||||||
<artifactId>gerrit-package-plugins</artifactId>
|
|
||||||
<packaging>war</packaging>
|
|
||||||
<version>2.7-SNAPSHOT</version>
|
|
||||||
|
|
||||||
<name>Gerrit Code Review - Package Plugins</name>
|
|
||||||
<url>http://code.google.com/p/gerrit/</url>
|
|
||||||
|
|
||||||
<properties>
|
|
||||||
<project.build.sourceEncoding>
|
|
||||||
UTF-8
|
|
||||||
</project.build.sourceEncoding>
|
|
||||||
</properties>
|
|
||||||
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.google.gerrit</groupId>
|
|
||||||
<artifactId>gerrit-war</artifactId>
|
|
||||||
<version>${project.version}</version>
|
|
||||||
<type>war</type>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.googlesource.gerrit.plugins.replication</groupId>
|
|
||||||
<artifactId>replication</artifactId>
|
|
||||||
<version>1.1-rc0</version>
|
|
||||||
<scope>provided</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.googlesource.gerrit.plugins.reviewnotes</groupId>
|
|
||||||
<artifactId>reviewnotes</artifactId>
|
|
||||||
<version>1.0-rc1</version>
|
|
||||||
<scope>provided</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.googlesource.gerrit.plugins.validators</groupId>
|
|
||||||
<artifactId>commit-message-length-validator</artifactId>
|
|
||||||
<version>1.0-rc1</version>
|
|
||||||
<scope>provided</scope>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-dependency-plugin</artifactId>
|
|
||||||
<version>2.1</version>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<phase>process-resources</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>copy-dependencies</goal>
|
|
||||||
</goals>
|
|
||||||
<configuration>
|
|
||||||
<includeTypes>jar</includeTypes>
|
|
||||||
<stripVersion>true</stripVersion>
|
|
||||||
<outputDirectory>${project.build.directory}/${project.build.finalName}/WEB-INF/plugins</outputDirectory>
|
|
||||||
</configuration>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-war-plugin</artifactId>
|
|
||||||
<version>2.1.1</version>
|
|
||||||
<configuration>
|
|
||||||
<warName>gerrit-full-${project.version}</warName>
|
|
||||||
<archive>
|
|
||||||
<addMavenDescriptor>false</addMavenDescriptor>
|
|
||||||
<manifestEntries>
|
|
||||||
<Main-Class>Main</Main-Class>
|
|
||||||
<Implementation-Title>Gerrit Code Review</Implementation-Title>
|
|
||||||
<Implementation-Version>${project.version}</Implementation-Version>
|
|
||||||
</manifestEntries>
|
|
||||||
</archive>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
<repositories>
|
|
||||||
<repository>
|
|
||||||
<id>gerrit-plugins</id>
|
|
||||||
<url>https://gerrit-plugins.commondatastorage.googleapis.com</url>
|
|
||||||
</repository>
|
|
||||||
</repositories>
|
|
||||||
</project>
|
|
@ -120,6 +120,38 @@ limitations under the License.
|
|||||||
</dependency>
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
|
<profiles>
|
||||||
|
<profile>
|
||||||
|
<id>plugins</id>
|
||||||
|
<activation>
|
||||||
|
<property>
|
||||||
|
<name>!gerrit.plugins.skip</name>
|
||||||
|
</property>
|
||||||
|
</activation>
|
||||||
|
<dependencies>
|
||||||
|
<!-- CORE PLUGIN LIST -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.googlesource.gerrit.plugins.replication</groupId>
|
||||||
|
<artifactId>replication</artifactId>
|
||||||
|
<version>${project.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.googlesource.gerrit.plugins.reviewnotes</groupId>
|
||||||
|
<artifactId>reviewnotes</artifactId>
|
||||||
|
<version>${project.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.googlesource.gerrit.plugins.validators</groupId>
|
||||||
|
<artifactId>commit-message-length-validator</artifactId>
|
||||||
|
<version>${project.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
</profile>
|
||||||
|
</profiles>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
<pluginManagement>
|
<pluginManagement>
|
||||||
<plugins>
|
<plugins>
|
||||||
@ -194,6 +226,19 @@ limitations under the License.
|
|||||||
<goal>copy-dependencies</goal>
|
<goal>copy-dependencies</goal>
|
||||||
</goals>
|
</goals>
|
||||||
</execution>
|
</execution>
|
||||||
|
<execution>
|
||||||
|
<id>copy-plugins</id>
|
||||||
|
<configuration>
|
||||||
|
<!-- CORE PLUGIN LIST -->
|
||||||
|
<includeArtifactIds>commit-message-length-validator,replication,reviewnotes</includeArtifactIds>
|
||||||
|
<includeTypes>jar</includeTypes>
|
||||||
|
<stripVersion>true</stripVersion>
|
||||||
|
<outputDirectory>${project.build.directory}/${project.build.finalName}/WEB-INF/plugins</outputDirectory>
|
||||||
|
</configuration>
|
||||||
|
<goals>
|
||||||
|
<goal>copy-dependencies</goal>
|
||||||
|
</goals>
|
||||||
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
|
||||||
|
11
plugins/README
Normal file
11
plugins/README
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
If you are adding a directory here:
|
||||||
|
|
||||||
|
- Search all pom.xml files for "CORE PLUGIN LIST".
|
||||||
|
- Add the new plugin to that location.
|
||||||
|
- (optional) Thank the Maven developers for making this easy.
|
||||||
|
|
||||||
|
- Ensure the plugin's pom.xml <version> is the same as Gerrit's
|
||||||
|
own pom.xml(s). Gerrit will only embed a plugin that has the
|
||||||
|
same version as itself.
|
||||||
|
|
||||||
|
- Register the plugin as a submodule with git submodule.
|
1
plugins/commit-message-length-validator
Submodule
1
plugins/commit-message-length-validator
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 2793491aefda6da23e94f87d910f3f92096cfb63
|
1
plugins/replication
Submodule
1
plugins/replication
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 0812161cf90458fd0a6412ba7fb457a73f769be2
|
1
plugins/reviewnotes
Submodule
1
plugins/reviewnotes
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 2f24a1454eb23437408adfa9ed6cb4f008f3dc84
|
17
pom.xml
17
pom.xml
@ -98,6 +98,23 @@ limitations under the License.
|
|||||||
<module>gerrit-plugin-gwt-archetype</module>
|
<module>gerrit-plugin-gwt-archetype</module>
|
||||||
</modules>
|
</modules>
|
||||||
|
|
||||||
|
<profiles>
|
||||||
|
<profile>
|
||||||
|
<id>plugins</id>
|
||||||
|
<activation>
|
||||||
|
<property>
|
||||||
|
<name>!gerrit.plugins.skip</name>
|
||||||
|
</property>
|
||||||
|
</activation>
|
||||||
|
<modules>
|
||||||
|
<!-- CORE PLUGIN LIST -->
|
||||||
|
<module>plugins/commit-message-length-validator</module>
|
||||||
|
<module>plugins/replication</module>
|
||||||
|
<module>plugins/reviewnotes</module>
|
||||||
|
</modules>
|
||||||
|
</profile>
|
||||||
|
</profiles>
|
||||||
|
|
||||||
<licenses>
|
<licenses>
|
||||||
<license>
|
<license>
|
||||||
<name>Apache License, 2.0</name>
|
<name>Apache License, 2.0</name>
|
||||||
|
@ -9,8 +9,12 @@ do
|
|||||||
flags="$flags -Dgerrit.documentation.skip=true"
|
flags="$flags -Dgerrit.documentation.skip=true"
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
|
--no-plugins|--without-plugins)
|
||||||
|
flags="$flags -Dgerrit.plugins.skip=true"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
echo >&2 "usage: $0 [--without-documentation]"
|
echo >&2 "usage: $0 [--no-documentation] [--no-plugins]"
|
||||||
exit 1
|
exit 1
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
@ -25,7 +29,7 @@ then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
./tools/version.sh --release &&
|
./tools/version.sh --release &&
|
||||||
mvn clean install $flags
|
mvn clean package $flags
|
||||||
rc=$?
|
rc=$?
|
||||||
./tools/version.sh --reset
|
./tools/version.sh --reset
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user