This module serves as an invocation point for tests of kogito-examples repository.
Project pom defines profiles that can invoke tests for a particular delivery option. Download of artifacts is provided by means described in Module structure.
mvn clean verify \
-Dtest.type=project-sources \
-Dproject.sources.artifact=kogito-examples \
-Ddownload.sources.version=<VERSION>
mvn clean verify \
-Dtest.type=sources-zip \
-Ddownload.sources.url=http://link.to/source.zip
mvn clean verify \
-Dtest.type=quickstarts-zip \
-Ddownload.sources.url=http://link.to/quickstarts.zip
mvn clean verify \
-Dtest.type=scm-checkout \
-Drepository.url=https://github.com/kiegroup/kogito-examples \
-Dsources.revision=1.11.x
mvn clean verify \
-Dtest.type=local-repo \
-Dsources.directory.local.repo=/path/to/cloned/repo
Any system properties that needs to be passed to particular invoked project, and are known
in advance, they can be configured to invoker-maven-plugin directly in its configuration. An
example is using the -Dproductized
property by default in the configuration:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-invoker-plugin</artifactId>
<configuration>
<properties>
<productized>true</productized>
</properties>
</configuration>
</plugin>
If more variability is needed in terms of setting system properties for invoked build - there's an
optional step that can be added to the *-test
maven module build section.
The following step will make sure that system properties are passed to invoked project
using invoker-maven-plugin
's configuration option <testPropertiesFile>
.
<plugin>
<groupId>org.codehaus.gmavenplus</groupId>
<artifactId>gmavenplus-plugin</artifactId>
<executions>
<execution>
<id>write-test-properties-file-for-invoker</id>
<phase>generate-resources</phase>
<goals>
<goal>execute</goal>
</goals>
</execution>
</executions>
</plugin>
By default, all properties passed to run-tests-with-build are passed - this can be changed by
the configuration property invoker.test.properties.list
, which is a comma-separated list
of system properties that are passed (but only if they are actally passed to overall run-tests-with-build maven build).
This will help you to filter out run-tests-with-build internally used properties (e.g. -Dtest.type
).
<properties>
<invoker.test.properties.list>quarkus.platform.group-id</invoker.test.properties.list>
</properties>
Each of sub-modules contains configuration for Maven Invoker related settings.
Download configuration of particular deliverable is provided by modules
- run-tests-with-build-sources-zip-download
- Used for downloads from arbitrary url.
- run-tests-with-build-project-sources-dependency-get
- Used for tar.gz archives with the classifier project-sources from nexus repository.
- run-tests-with-build-scm-checkout
- Used for git repo checkout using repository URL and revision.