From 300b1057d46e1060f3689eb07ac0a1af645eeb2f Mon Sep 17 00:00:00 2001 From: Martin D'Aloia Date: Mon, 13 Nov 2023 22:19:28 -0300 Subject: [PATCH] Add a reproducer to show that PR #2978 was a partial fix The fix of PR #2978 was a partial fix for issue #2977. It fixed the case of a single bundled but when the bundle providing/requiring the virtual IU is required by another bundle it fails with the same error as before even with Tycho 4.0.4: ``` [ERROR] Cannot resolve project dependencies: [ERROR] Software being installed: pvumb.bundle2 1.0.0.qualifier [ERROR] Missing requirement: pvumb.bundle1 1.0.0.qualifier requires 'org.eclipse.equinox.p2.iu; configure.pvumb.bundle1 0.0.0' but it could not be found [ERROR] Cannot satisfy dependency: pvumb.bundle2 1.0.0.qualifier depends on: osgi.bundle; pvumb.bundle1 0.0.0 ``` A workaround is to use: ``` requires.0.optional=true requires.0.greedy=true ``` --- .../bundle1/META-INF/MANIFEST.MF | 7 ++ .../bundle1/META-INF/p2.inf | 11 +++ .../bundle1/build.properties | 2 + .../bundle1/pom.xml | 16 ++++ .../bundle2/META-INF/MANIFEST.MF | 8 ++ .../bundle2/build.properties | 2 + .../bundle2/pom.xml | 16 ++++ .../p2Inf.virtualUnit.multiBundle/pom.xml | 40 ++++++++++ .../tycho/test/p2Inf/VirtualUnitTest.java | 73 ++++++++++++++----- 9 files changed, 158 insertions(+), 17 deletions(-) create mode 100644 tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/META-INF/MANIFEST.MF create mode 100644 tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/META-INF/p2.inf create mode 100644 tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/build.properties create mode 100644 tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/pom.xml create mode 100644 tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/META-INF/MANIFEST.MF create mode 100644 tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/build.properties create mode 100644 tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/pom.xml create mode 100644 tycho-its/projects/p2Inf.virtualUnit.multiBundle/pom.xml diff --git a/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/META-INF/MANIFEST.MF b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/META-INF/MANIFEST.MF new file mode 100644 index 0000000000..6d33b22837 --- /dev/null +++ b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/META-INF/MANIFEST.MF @@ -0,0 +1,7 @@ +Manifest-Version: 1.0 +Bundle-ManifestVersion: 2 +Bundle-Name: pvumb.bundle1 +Bundle-SymbolicName: pvumb.bundle1;singleton:=true +Bundle-Version: 1.0.0.qualifier +Bundle-Vendor: TEST +Bundle-RequiredExecutionEnvironment: JavaSE-17 diff --git a/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/META-INF/p2.inf b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/META-INF/p2.inf new file mode 100644 index 0000000000..cd4d646153 --- /dev/null +++ b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/META-INF/p2.inf @@ -0,0 +1,11 @@ +# Create the virtual IU +units.0.id=configure.pvumb.bundle1 +units.0.version=1.0.0 +units.0.provides.1.namespace=org.eclipse.equinox.p2.iu +units.0.provides.1.name=configure.pvumb.bundle1 +units.0.provides.1.version=1.0.0 + +# Require in this bundle the created virtual IU +requires.0.namespace=org.eclipse.equinox.p2.iu +requires.0.name=configure.pvumb.bundle1 +requires.0.range=0.0.0 diff --git a/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/build.properties b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/build.properties new file mode 100644 index 0000000000..7594fab8d5 --- /dev/null +++ b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/build.properties @@ -0,0 +1,2 @@ +bin.includes = META-INF/,\ + . diff --git a/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/pom.xml b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/pom.xml new file mode 100644 index 0000000000..7987cbc641 --- /dev/null +++ b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle1/pom.xml @@ -0,0 +1,16 @@ + + + 4.0.0 + + + tycho-its-project.p2Inf.virtualUnit.multiBundle + parent + 1.0.0-SNAPSHOT + + + pvumb.bundle1 + eclipse-plugin + + diff --git a/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/META-INF/MANIFEST.MF b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/META-INF/MANIFEST.MF new file mode 100644 index 0000000000..7fa4a43de0 --- /dev/null +++ b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/META-INF/MANIFEST.MF @@ -0,0 +1,8 @@ +Manifest-Version: 1.0 +Bundle-ManifestVersion: 2 +Bundle-Name: pvumb.bundle2 +Bundle-SymbolicName: pvumb.bundle2;singleton:=true +Bundle-Version: 1.0.0.qualifier +Bundle-Vendor: TEST +Bundle-RequiredExecutionEnvironment: JavaSE-17 +Require-Bundle: pvumb.bundle1 diff --git a/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/build.properties b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/build.properties new file mode 100644 index 0000000000..7594fab8d5 --- /dev/null +++ b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/build.properties @@ -0,0 +1,2 @@ +bin.includes = META-INF/,\ + . diff --git a/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/pom.xml b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/pom.xml new file mode 100644 index 0000000000..771c3be042 --- /dev/null +++ b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/bundle2/pom.xml @@ -0,0 +1,16 @@ + + + 4.0.0 + + + tycho-its-project.p2Inf.virtualUnit.multiBundle + parent + 1.0.0-SNAPSHOT + + + pvumb.bundle2 + eclipse-plugin + + diff --git a/tycho-its/projects/p2Inf.virtualUnit.multiBundle/pom.xml b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/pom.xml new file mode 100644 index 0000000000..db8bcab7fb --- /dev/null +++ b/tycho-its/projects/p2Inf.virtualUnit.multiBundle/pom.xml @@ -0,0 +1,40 @@ + + + 4.0.0 + + tycho-its-project.p2Inf.virtualUnit.multiBundle + parent + 1.0.0-SNAPSHOT + pom + + + 4.0.4 + + + + bundle1 + bundle2 + + + + + + org.eclipse.tycho + tycho-maven-plugin + ${tycho-version} + true + + + org.eclipse.tycho + target-platform-configuration + ${tycho-version} + + consider + + + + + + diff --git a/tycho-its/src/test/java/org/eclipse/tycho/test/p2Inf/VirtualUnitTest.java b/tycho-its/src/test/java/org/eclipse/tycho/test/p2Inf/VirtualUnitTest.java index 9bb5c1078b..e6038c313d 100644 --- a/tycho-its/src/test/java/org/eclipse/tycho/test/p2Inf/VirtualUnitTest.java +++ b/tycho-its/src/test/java/org/eclipse/tycho/test/p2Inf/VirtualUnitTest.java @@ -10,9 +10,14 @@ package org.eclipse.tycho.test.p2Inf; import static java.util.Arrays.asList; -import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; +import java.io.File; +import java.io.IOException; +import java.util.List; +import java.util.Optional; +import java.util.stream.Stream; + import org.apache.maven.it.Verifier; import org.eclipse.tycho.test.AbstractTychoIntegrationTest; import org.junit.Test; @@ -21,24 +26,22 @@ import de.pdark.decentxml.Element; import de.pdark.decentxml.XMLParser; -import java.io.File; -import java.util.List; -import java.util.Optional; -import java.util.stream.Stream; - /** - * Test that a virtual IU created just with metadata in a p2.inf file can be required - * in the same p2.inf file. + * Test that a virtual IU created just with metadata in a p2.inf file can be + * required in the same p2.inf file. *

- * It used to work until 3.0.5 (using consider) - * but since 4.0.0 failed with: + * It used to work until 3.0.5 (using + * consider) but since 4.0.0 + * failed with: + * *

  * Cannot resolve project dependencies:
  *   Software being installed: pvu.bundle 1.0.0.qualifier
  *   Missing requirement: pvu.bundle 1.0.0.qualifier requires 'org.eclipse.equinox.p2.iu; configure.pvu.bundle 0.0.0' but it could not be found
  * 
* - * See https://github.com/eclipse-tycho/tycho/blob/master/RELEASE_NOTES.md#mixed-reactor-setups-require-the-new-resolver-now + * See + * https://github.com/eclipse-tycho/tycho/blob/master/RELEASE_NOTES.md#mixed-reactor-setups-require-the-new-resolver-now * and https://github.com/eclipse-tycho/tycho/issues/2977 */ public class VirtualUnitTest extends AbstractTychoIntegrationTest { @@ -52,10 +55,29 @@ public void testVirtualUnitRequirementDoesNotFailBuild() throws Exception { String hostUnitId = "pvu.bundle"; String configureUnitId = "configure.pvu.bundle"; - File p2Content = new File(verifier.getBasedir(), "bundle/target/p2content.xml"); - Document doc = XMLParser.parse(p2Content); + List units = getUnits(verifier.getBasedir(), "bundle/target/p2content.xml"); + Optional hostUnit = findUnit(units, hostUnitId); + Optional configureUnit = findUnit(units, configureUnitId); + + Stream hostUnitRequirements = findRequirements(hostUnit); + + assertTrue("Host IU " + hostUnitId + " not found", hostUnit.isPresent()); + assertTrue("Configure IU " + configureUnitId + " not found", configureUnit.isPresent()); + assertTrue("Requirement of IU " + configureUnitId + " not found in IU " + hostUnitId, + hostUnitRequirements.anyMatch(elem -> configureUnitId.equals(elem.getAttributeValue("name")))); + } + + @Test + public void testVirtualUnitMultiBundleWithRequirementDoesNotFailBuild() throws Exception { + Verifier verifier = getVerifier("/p2Inf.virtualUnit.multiBundle", false); + verifier.executeGoals(asList("verify")); + verifier.verifyErrorFreeLog(); + + // Host bundle and virtual IU assertions + String hostUnitId = "pvumb.bundle1"; + String configureUnitId = "configure.pvumb.bundle1"; - List units = doc.getChild("units").getChildren("unit"); + List units = getUnits(verifier.getBasedir(), "bundle1/target/p2content.xml"); Optional hostUnit = findUnit(units, hostUnitId); Optional configureUnit = findUnit(units, configureUnitId); @@ -65,12 +87,29 @@ public void testVirtualUnitRequirementDoesNotFailBuild() throws Exception { assertTrue("Configure IU " + configureUnitId + " not found", configureUnit.isPresent()); assertTrue("Requirement of IU " + configureUnitId + " not found in IU " + hostUnitId, hostUnitRequirements.anyMatch(elem -> configureUnitId.equals(elem.getAttributeValue("name")))); + + // Client bundle assertions + String clientUnitId = "pvumb.bundle2"; + + units = getUnits(verifier.getBasedir(), "bundle2/target/p2content.xml"); + Optional clientUnit = findUnit(units, clientUnitId); + + Stream clientUnitRequirements = findRequirements(clientUnit); + + assertTrue("Client IU " + clientUnitId + " not found", clientUnit.isPresent()); + assertTrue("Requirement of IU " + hostUnitId + " not found in IU " + clientUnitId, + clientUnitRequirements.anyMatch(elem -> hostUnitId.equals(elem.getAttributeValue("name")))); + } + + private static List getUnits(String baseDir, String filePath) throws IOException { + File p2Content = new File(baseDir, filePath); + Document doc = XMLParser.parse(p2Content); + + return doc.getChild("units").getChildren("unit"); } private static Optional findUnit(List units, String hostUnitId) { - return units.stream() - .filter(elem -> hostUnitId.equals(elem.getAttributeValue("id"))) - .findFirst(); + return units.stream().filter(elem -> hostUnitId.equals(elem.getAttributeValue("id"))).findFirst(); } private static Stream findRequirements(Optional hostUnit) {