diff options
author | Susan Franklin | 2010-04-22 22:51:29 +0000 |
---|---|---|
committer | Susan Franklin | 2010-04-22 22:51:29 +0000 |
commit | b3748ee2e855e58ac1d07ad02a207af6cca35a92 (patch) | |
tree | a5ea7d92b23b2a1ad034f428d3940cde004a5c16 /bundles/org.eclipse.equinox.p2.tests.ui/src/org/eclipse/equinox/p2/tests/ui/operations/InstallOperationTests.java | |
parent | 08b71bdfc31827113ada7f5f2530cf6e9320a2e9 (diff) | |
download | rt.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.java | 94 |
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); + + } +} |