Provide various parent pom.xml for contrib extensions.
Extensions are automatically released on http://nexus.xwiki.org and http://jira.xwiki.org if your user have the proper rights.
One version is always published for each LTS branch since that's what contrib extensions are recommended to support.
If you need a specific version there is two possibilities:
- in most cases it's enough to use the closest lower version (8.4-8 for example) and set the following property <commons.version>8.4.2</commons.version>
- in more complex use case (like parent-platform-distribution) you will need the exact same version, don't hesitate to create a TASK issue on https://jira.xwiki.org/browse/CPARENT
Most released versions have a corresponding branch (usually master for latest versions) so you can create a pull request there. If you are not sure how to fix it create an issue on https://jira.xwiki.org/browse/CPARENT.
For extensions having xwiki-platform dependencies:
<parent>
<groupId>org.xwiki.contrib</groupId>
<artifactId>parent-platform</artifactId>
<version>16.10.0</version>
</parent>
For extensions having xwiki-rendering and xwiki-commons dependencies:
<parent>
<groupId>org.xwiki.contrib</groupId>
<artifactId>parent-rendering</artifactId>
<version>16.10.0</version>
</parent>
For extensions having xwiki-commons dependencies only:
<parent>
<groupId>org.xwiki.contrib</groupId>
<artifactId>parent-commons</artifactId>
<version>16.10.0</version>
</parent>
For custom XWiki distributions:
<parent>
<groupId>org.xwiki.contrib</groupId>
<artifactId>parent-platform-distribution</artifactId>
<version>16.10.0</version>
</parent>
Version is <branch>[-<buildnumber>]
as in:
6.4-3
which is the 3rd update of the parent pom to use for contrib extension which support XWiki6.4
version and more14.10.15-2
which is the 2nd update of the parent pom to use for contrib extension which support XWiki14.10.15
version and more
Basically you have to take the minimum XWiki version you want to support, say 14.10.15
, and:
- first time you release a parent for that version you use exactly that version, i.e.
14.10.15
- the second time you add the
-1
suffix, i.e.14.10.15-1
- from then on you increase the number after the dash, i.e
14.10.15-2
You can then use ${commons.version}
, ${rendering.version}
or ${platform.version}
depending on where you dependency come from as in:
<dependency>
<groupId>org.xwiki.commons</groupId>
<artifactId>xwiki-commons-component-api</artifactId>
<version>${commons.version}</version>
</dependency>
<dependency>
<groupId>org.xwiki.rendering</groupId>
<artifactId>xwiki-rendering-api</artifactId>
<version>${rendering.version}</version>
</dependency>
<dependency>
<groupId>org.xwiki.platform</groupId>
<artifactId>xwiki-platform-oldcore</artifactId>
<version>${platform.version}</version>
</dependency>
It's possible to customize a bit the behavior of the parent pom using some properties.
By default revapi plugin is executed to check if you broke any API. It automatically find out the previous version but sometime it's not exacting the one you want to compare with.
You can control the version to use as previous version with the property xwiki.compatibility.previous.version
as in:
<properties>
<xwiki.compatibility.previous.version>15.0</xwiki.compatibility.previous.version>
</properties>
By default the maven artifact are going to be automatically released on http://nexus.xwiki.org. If you want to keep it in two passes (you want to test the deployed artifact before the release or the doing the Maven release is not the same as the one validating the release) you can control the behavior with the properties <xwiki.nexus.skipStaging>
and <xwiki.nexus.autoReleaseAfterClose>
as in:
<properties>
<!-- Completely skip the Nexus plugin -->
<xwiki.nexus.skipStaging>true</xwiki.nexus.skipStaging>
<!-- Disable the automatic release after the clone -->
<xwiki.nexus.autoReleaseAfterClose>false</xwiki.nexus.autoReleaseAfterClose>
</properties>
You can set the http://jira.xwiki.org based issue management system and URL in the properties as follow:
<xwiki.issueManagement.jira.id>LDAP</xwiki.issueManagement.jira.id>
If your project is not hosted on http://jira.xwiki.org you can also do the following:
<xwiki.issueManagement.system>jira</xwiki.issueManagement.system>
<xwiki.issueManagement.url>http://jira.mydomain.com/browse/MYID</xwiki.issueManagement.url>
If you want to automatically create (if it does not already exist) and release the version on Jira when you release on Maven you can enable it using the Maven property xwiki.release.jira.skip
as in:
<properties>
<xwiki.release.jira.skip>false</xwiki.release.jira.skip>
</properties>
You will also need to indicate your credentials in ~/.m2/settings.xml
file:
<server>
<id>jira.xwiki.org</id>
<username>myJiraLogin</username>
<password>myJiraPassword</password>
</server>
You can indicate the minimum test coverage you want to pass the build using the property <xwiki.jacoco.instructionRatio>
Here is an example which requiring that at least 50% of your code is executed during tests:
<xwiki.jacoco.instructionRatio>0.50</xwiki.jacoco.instructionRatio>
If it's not you will see a message like the following:
[WARNING] Rule violated for bundle my-module: instructions covered ratio is 0.40, but expected minimum is 0.50
The Maven Release Plugin cannot be used for these pom.xml
because one of the goal is to make sure release setup is a clean slate when you use them as parent.
- Go to the right branch. Use
master
when releasing a non-LTS version. - Note: you don't need to edit the versions since the new version will asked during the release script execution and the various
pom.xml
files will be updated automatically. - execute
./release.sh