Thanks for your interest in this project.
To enable SNAPSHOTs, make sure the following Maven plugin-repository is available to your build: https://repo.eclipse.org/content/repositories/tycho-snapshots/ . This can be accomplished by adding the following snippet to your (parent) pom.xml or settings.xml:
<pluginRepositories>
<pluginRepository>
<id>tycho-snapshots</id>
<url>https://repo.eclipse.org/content/repositories/tycho-snapshots/</url>
</pluginRepository>
</pluginRepositories>
Make sure you have set the property for the Tycho version (e.g. tycho-version
) to <version-under-development>-SNAPSHOT
in the project beeing build.
For documentation of the most recent snapshot build, see the Snapshot Tycho Site.
If you identify an issue, please try to reduce the case to the minimal project and steps to reproduce, and then report the bug with details to reproduce and the minimal reproducer project to Tycho's issue tracker.
Java 11 and Maven 3.6.3, or newer.
If your Internet connection uses a proxy, make sure that you have the proxy configured in your Maven settings.xml.
Step by step instructions:
- Download the Eclipse Installer.
- Start the installer using the
eclipse-inst
executable. - On the first page (product selection), click the preference button in the top-right corner and select the Advanced Mode .
- If you are behind a proxy, at this point you might want to double check your network settings by clicking in the Network Proxy Settings at the bottom.
- Select Eclipse IDE for Eclipse Committers . Click Next .
- Under Eclipse.org , double-click on Tycho (single click is not enough!). Make sure that Tycho is shown in the table on the bottom. Click Next.
- You can edit the Installation Folder , but you do not have to select the Target Platform here, this will be set later automatically. By choosing Show all variables at the bottom of the page, you are able to change other values as well but you do not have to. (Unless you have write access to the GitHub repository, make sure you select "HTTPS read-only" in the dropdown "Tycho Github repository"). Click Next.
- Press Finished on the Confirmation page will start the installation process.
- The installer will download the selected Eclipse version, starts Eclipse and will perform all the additional steps (cloning the git repos, etc...). When the downloaded Eclipse started, the progress bar in the status bar shows the progress of the overall setup.
- Once the Executing startup task job is finished you should have all the Tycho and Tycho Extras projects imported into 2 working sets called Tycho and Tycho Extras .
- Some Projects might sill have errors. Select them (or all) and choose Maven > Update Project.. from the context menu. De-select Clean projects in the shown dialog and press OK to update the projects. After that, no more error should be there.
Preferred and easier way is to follow the instructions above, but you could also setup your environment manually:
- Get an Eclipse IDE with a recent version of the Maven integration for Eclipse (m2eclipse) and Eclipse PDE installed. m2eclipse is included in various Eclipse packages, e.g. the Eclipse IDE for Eclipse Committers package. To add m2eclipse to your existing Eclipse installation, install it from the Eclipse Marketplace.
- Clone this repository (via CLI or EGit)
- In Eclipse, use ''File > Import > Existing Maven Projects'', select the root directory of the sources, and import all projects. If prompted by m2eclipse, install the proposed project configurators and restart Eclipse.
- For Tycho only: Configure the target platform: Open the file
tycho-bundles-target/tycho-bundles-target.target
and click on Set as Target Platform in the upper right corner of the target definition editor.
The result should be an Eclipse workspace without build errors. m2eclipse may take some time to download required libraries from Maven central.
- If there are compile errors in the projects
org.eclipse.tycho.surefire.junit<
,org.eclipse.tycho.surefire.junit4
,org.eclipse.tycho.surefire.junit47
, ororg.eclipse.tycho.surefire.osgibooter
, just select these projects and manually trigger an update via Maven > Update project... from the context menu.
Tycho has two types of tests: unit tests (locally in each module) and a global integration test suite in module tycho-its.
Unit tests are preferred if possible because they are in general much faster and better targeted at the functionality under test. Integration tests generally invoke a forked Maven build on a sample project (stored under projects/) and then do some assertions on the build results.
The Tycho integration tests are located in the project tycho-its
. To run all Tycho integration tests, execute mvn clean install -f tycho-its/pom.xml
. To run a single integration test, select the test class in Eclipse and run it as ''JUnit Test''.
Background information on the Tycho integration tests
The integration tests trigger sample builds that use Tycho. These builds expect that Tycho has been installed to the local Maven repository. This is why you need to build Tycho through a mvn install
before you can run the integration tests.
Alternatively, e.g. if you are only interested in modifying an integration test and do not want to patch Tycho itself, you can configure the integration tests to download the current Tycho snapshot produced by the [http://hudson.eclipse.org/tycho/view/CI Tycho CI builds]. To do this, you need to edit the Maven settings stored in tycho-its/settings.xml
and add the tycho-snapshots repository as described in [[Getting Tycho]]. (Advanced note: The integration tests can also be pointed to a different settings.xml with the system property tycho.testSettings
.)
The tycho integration tests are located in the tycho-its subfolder of the repository. Creating a new integration test usually includes the following steps:
- create a new folder in the the projects directory (see below for a good naming, but this could be improved as part of the review so don't mind to choose an intermediate name first), usually you would like to use
${tycho-version}
as a placeholder in your pom so the execution picks up the current tycho version - Check if there is already a suitable test-class available or simply create your own (again the name could be improved later on if required), the usual pattern for a self-contained test-case that fails the build is:
@Test
public void test() throws Exception {
Verifier verifier = getVerifier("your-project-folder-name", false);
verifier.executeGoals(asList("verify"));
verifier.verifyErrorFreeLog();
}
- You might want to check for additional constraints, see the Verifier for available options.
- If you don't want to run the full integration build you can the simply go to the project directory and run
mvn clean verify -Dtycho-version=<version of tycho where you see the issue>
to see the outcome of your created test.
The hardest part for writing Tycho integration tests is the naming. While names are mostly important for readability, there were also cases where the ID "feature" was used multiple times and hence a test used the build result of a different integration test.
Therefore, here are a few tips for writing good integration tests:
- Test project name: Although many existing test have a bug number in the name, this is '''not''' the recommended naming scheme. Since integration test can take some time to execute, it may be a good idea to test related things in one test.
So name the test projects in a way that they can be found, and that related tests are sorted next to each other, e.g. in the form <component>.<aspect>. - Package: Should be org.eclipse.tycho.test.<component> (without the aspect so that we don't get an excessive number of packages)
- Test project groupIds: Should be tycho-its-project.<component>.<aspect> plus a segment for the reactor in case of multi-reactor tests. The groupId is particularly important if the test project is installed to the local Maven repository. (Avoid install; use verify if possible.)
- Test project artifactIds: Have to be the same as the ID of the feature/bundle; need to start with something unique, e.g. the first letters of each segment of the project name.
Each Tycho Extras project does have its own integration tests located in the subdirectory it
within the project (e.g. tycho-eclipserun-plugin/src/it
).
To run the tests use the maven profile its
, run mvn integration-test -Pits
either within the Tycho Extras source folder to run all Tycho Extras integration tests or within a Tycho Extras plugin directory to run only the integration tests of that project.
Background information on the Tycho Extras integration tests
Tycho Extras and Tycho are developed and released in parallel and will use the snapshot version of Tycho from the repository https://repo.eclipse.org/content/repositories/tycho-snapshots/
.
If you want to run the tests with a specific version of Tycho use the tycho-version
system property, e.g. mvn integration-test -Pits -Dtycho-version=0.22.0
.
To use a different Tycho snapshot repository use the system property tycho-snapshots-url
, e.g. mvn integration-test -Pits -Dtycho-snapshots-url=file:/path/to/repo
Tycho makes heavy use of p2 functionality. Therefore it may be useful to try out patches to p2 without waiting for a new p2 release, or even just the next nightly build. With the following steps it is possible to build Tycho against a locally built version of p2.
- Get the p2 sources (see p2 project information)
- Make changes in the p2 sources, (!) don't forget to increase the version of that bundle otherwhise your changes will be overwritten with the current release version (!)
- Build the changed p2 bundles individually with mvn clean install -Pbuild-individual-bundles (see Equinox/p2/Build for more information)
- Build at least the Tycho module tycho-bundles-external with mvn clean install - you should see a warning that the locally built p2 bundles have been used. Then the locally built Tycho SNAPSHOT includes the patched p2 version.
Note: Tycho always allows references to locally built artifacts, even if they are not part of the target platform. Therefore you may want to clear the list of locally built artifacts (in the local Maven repository in .meta/p2-local-metadata.properties) after you have finished your trials with the patched p2 version.
Tycho has Maven dependencies to Equinox and JDT, so these artifact are used from Maven Central repository.
From the root directory of your local Tycho git-repository clone run the following Maven commands...
- to check if compilation and all tests succeed:
mvn clean verify -Pits
- to install your version of Tycho into your local Maven repository (skips all tests for faster installation):
mvn clean install -DSkipTests
In order to test your changes of Tycho locally in a project-build, install your modified Tycho locally as described above and use the corresponding Tycho (probably snapshot) version in the project being build. You can also debug that build with the steps below (from here you can jump to step 3 immediately).
In order to debug Tycho plugins inside Eclipse:
- Get the Tycho sources in Eclipse
- Create/get a project that highlights the bug
Inside the Eclipse IDE:
- Create a Maven Run-Configuration in your Tycho Eclipse-workspace to build the project and specify goals, profiles and properties as required
- Launch the Maven-configuration from your Eclipse in Debug-mode
Or on the command-line interface:
- Run the project-build using
mvnDebug
(instead ofmvn
) and specify goals, profiles and properties as required - Go into your Eclipse, use
Debug > Remote Java Application
, selectport 8000
to attach the Eclipse Debugger
Before debugging a build, make sure that your local Tycho-sources correspond to the Tycho version used by the project being build. Otherwise the debugger might show unexpected behavior.
Start with Bug: <number>
stating the bug number the change is related to; this will enable the eclipse genie bot to automatically cross-link bug and gerrit proposal
Also in the first line, provide a clear and concise description of the change
Add one blank line, followed by more details about the change. This could include a motivation for the change and/or reasons why things were done in the particular way they are done in the change.
Make small commits, yet self-contained commits. This makes them easy to review.
Do not mix concerns in commits: have a commit do a single thing. This makes them reviewable 'in isolation'. This is particularly important if you need to do refactorings to the existing code: Refactorings tend to lead to large diffs which are difficult to review. Therefore make sure to have separate commits for refactorings and for functional changes.
As GitHub pull request.
Contact the project developers via the project's "dev" list: https://dev.eclipse.org/mailman/listinfo/tycho-dev
This Eclipse Foundation open project is governed by the Eclipse Foundation Development Process and operates under the terms of the Eclipse IP Policy.
Before your contribution can be accepted by the project team contributors must electronically sign the Eclipse Contributor Agreement (ECA): http://www.eclipse.org/legal/ECA.php
For more information, please see the Eclipse Committer Handbook: https://www.eclipse.org/projects/handbook/#resources-commit