Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSusan Franklin2010-04-22 22:51:29 +0000
committerSusan Franklin2010-04-22 22:51:29 +0000
commitb3748ee2e855e58ac1d07ad02a207af6cca35a92 (patch)
treea5ea7d92b23b2a1ad034f428d3940cde004a5c16 /bundles/org.eclipse.equinox.p2.tests.ui/src/org/eclipse/equinox/p2/tests/ui/operations/InstallOperationTests.java
parent08b71bdfc31827113ada7f5f2530cf6e9320a2e9 (diff)
downloadrt.equinox.p2-b3748ee2e855e58ac1d07ad02a207af6cca35a92.tar.gz
rt.equinox.p2-b3748ee2e855e58ac1d07ad02a207af6cca35a92.tar.xz
rt.equinox.p2-b3748ee2e855e58ac1d07ad02a207af6cca35a92.zip
Bug 310206 - [ui] how and when does UI make use of ProvisioningContext repo referencing?
Diffstat (limited to 'bundles/org.eclipse.equinox.p2.tests.ui/src/org/eclipse/equinox/p2/tests/ui/operations/InstallOperationTests.java')
-rw-r--r--bundles/org.eclipse.equinox.p2.tests.ui/src/org/eclipse/equinox/p2/tests/ui/operations/InstallOperationTests.java94
1 files changed, 94 insertions, 0 deletions
diff --git a/bundles/org.eclipse.equinox.p2.tests.ui/src/org/eclipse/equinox/p2/tests/ui/operations/InstallOperationTests.java b/bundles/org.eclipse.equinox.p2.tests.ui/src/org/eclipse/equinox/p2/tests/ui/operations/InstallOperationTests.java
new file mode 100644
index 000000000..fc0c29ee5
--- /dev/null
+++ b/bundles/org.eclipse.equinox.p2.tests.ui/src/org/eclipse/equinox/p2/tests/ui/operations/InstallOperationTests.java
@@ -0,0 +1,94 @@
+/*******************************************************************************
+ * Copyright (c) 2010 IBM Corporation and others.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * IBM Corporation - initial API and implementation
+ *******************************************************************************/
+package org.eclipse.equinox.p2.tests.ui.operations;
+
+import java.net.URI;
+import java.util.Collections;
+import java.util.Set;
+import org.eclipse.core.runtime.OperationCanceledException;
+import org.eclipse.equinox.p2.core.ProvisionException;
+import org.eclipse.equinox.p2.engine.ProvisioningContext;
+import org.eclipse.equinox.p2.metadata.IInstallableUnit;
+import org.eclipse.equinox.p2.operations.InstallOperation;
+import org.eclipse.equinox.p2.query.QueryUtil;
+import org.eclipse.equinox.p2.repository.IRepository;
+import org.eclipse.equinox.p2.repository.metadata.IMetadataRepository;
+import org.eclipse.equinox.p2.repository.spi.RepositoryReference;
+import org.eclipse.equinox.p2.tests.ui.AbstractProvisioningUITest;
+
+/**
+ * Tests various aspects of install operations
+ */
+public class InstallOperationTests extends AbstractProvisioningUITest {
+ public void testInstallerPlan() throws ProvisionException {
+ URI uri = getTestData("InstallHandler", "testData/installPlan").toURI();
+ Set<IInstallableUnit> ius = getMetadataRepositoryManager().loadRepository(uri, getMonitor()).query(QueryUtil.createIUQuery("A"), getMonitor()).toSet();
+ assertTrue("One IU", ius.size() == 1);
+ InstallOperation op = new InstallOperation(getSession(), ius);
+ op.setProfileId(TESTPROFILE);
+ ProvisioningContext pc = new ProvisioningContext(getAgent());
+ pc.setArtifactRepositories(new URI[] {uri});
+ pc.setMetadataRepositories(new URI[] {uri});
+ op.setProvisioningContext(pc);
+ assertTrue("Should resolve", op.resolveModal(getMonitor()).isOK());
+ assertTrue("Should install", op.getProvisioningJob(null).runModal(getMonitor()).isOK());
+ assertFalse("Action1 should have been installed", getProfile(TESTPROFILE).query(QueryUtil.createIUQuery("Action1"), getMonitor()).isEmpty());
+ }
+
+ public void testDetectMissingRequirement() throws ProvisionException, OperationCanceledException {
+ URI uriA, uriB, uriC;
+ IMetadataRepository repoA, repoB, repoC;
+ String testDataFileLocation = "testData/provisioningContextTests/";
+ uriA = getTestData("A", testDataFileLocation + "A").toURI();
+ uriB = getTestData("B", testDataFileLocation + "B").toURI();
+ uriC = getTestData("C", testDataFileLocation + "C").toURI();
+
+ repoA = getMetadataRepositoryManager().loadRepository(uriA, getMonitor());
+ // see https://bugs.eclipse.org/bugs/show_bug.cgi?id=305565
+ repoA.addReferences(Collections.singletonList(new RepositoryReference(uriA, null, IRepository.TYPE_ARTIFACT, IRepository.ENABLED)));
+
+ // now create a second set of repos and refer from the first
+ repoB = getMetadataRepositoryManager().loadRepository(uriB, getMonitor());
+ repoB.addReferences(Collections.singletonList(new RepositoryReference(uriB, null, IRepository.TYPE_ARTIFACT, IRepository.ENABLED)));
+ repoA.addReferences(Collections.singletonList(new RepositoryReference(repoB.getLocation(), null, IRepository.TYPE_METADATA, IRepository.ENABLED)));
+
+ // this repo is referred by the previous one
+ repoC = getMetadataRepositoryManager().loadRepository(uriC, getMonitor());
+ repoC.addReferences(Collections.singletonList(new RepositoryReference(uriC, null, IRepository.TYPE_ARTIFACT, IRepository.ENABLED)));
+ repoB.addReferences(Collections.singletonList(new RepositoryReference(repoC.getLocation(), null, IRepository.TYPE_METADATA, IRepository.ENABLED)));
+
+ String id = "TestProfileIDForMissingRequirement";
+ createProfile(id);
+ ProvisioningContext context = new ProvisioningContext(getAgent());
+ context.setMetadataRepositories(new URI[] {repoA.getLocation()});
+ context.setArtifactRepositories(new URI[0]);
+ IInstallableUnit[] units = repoA.query(QueryUtil.createIUQuery("A"), getMonitor()).toArray(IInstallableUnit.class);
+ assertTrue("should find A in main repo", units.length > 0);
+
+ // NOW WE CAN TEST!
+ assertNull("ProvisioningContext does not follow by default", context.getProperty(ProvisioningContext.FOLLOW_REPOSITORY_REFERENCES));
+
+ InstallOperation op = new InstallOperation(getSession(), Collections.singleton(units[0]));
+ op.setProvisioningContext(context);
+ op.setProfileId(id);
+ assertTrue("Should resolve", op.resolveModal(getMonitor()).isOK());
+
+ assertNotNull("Context was reset to follow", context.getProperty(ProvisioningContext.FOLLOW_REPOSITORY_REFERENCES));
+
+ getArtifactRepositoryManager().removeRepository(uriA);
+ getArtifactRepositoryManager().removeRepository(uriB);
+ getArtifactRepositoryManager().removeRepository(uriC);
+ getMetadataRepositoryManager().removeRepository(uriA);
+ getMetadataRepositoryManager().removeRepository(uriB);
+ getMetadataRepositoryManager().removeRepository(uriC);
+
+ }
+}

Back to the top