From d93ba67cf4fdcc397b6edfe37472a3817dd8abae Mon Sep 17 00:00:00 2001 From: Tobias Hahnen Date: Wed, 27 Nov 2024 16:48:35 +0100 Subject: [PATCH] Add IT for a P2 repository hosting server with a redirection loop # Co-authored-by should list all the other authors of this commit Co-authored-by: NAME # Reviewed-by should list all the reviewers of this commit (NOT the PR!) Reviewed-by: NAME --- tycho-its/projects/P2RedirectLoop/pom.xml | 50 ++++++++++++++ .../P2RedirectLoop/targetplatform.target | 10 +++ .../P2RedirectLoop/P2RedirectLoopTest.java | 65 +++++++++++++++++++ 3 files changed, 125 insertions(+) create mode 100644 tycho-its/projects/P2RedirectLoop/pom.xml create mode 100644 tycho-its/projects/P2RedirectLoop/targetplatform.target create mode 100644 tycho-its/src/test/java/org/eclipse/tycho/test/P2RedirectLoop/P2RedirectLoopTest.java diff --git a/tycho-its/projects/P2RedirectLoop/pom.xml b/tycho-its/projects/P2RedirectLoop/pom.xml new file mode 100644 index 0000000000..727f1c1d86 --- /dev/null +++ b/tycho-its/projects/P2RedirectLoop/pom.xml @@ -0,0 +1,50 @@ + + 4.0.0 + + tycho-its-project.P2RedirectionLoop + aggregator + 1.0.0 + eclipse-plugin + + + UTF-8 + + + + + + org.eclipse.tycho + tycho-maven-plugin + ${tycho-version} + true + + + + org.eclipse.tycho + target-platform-configuration + ${tycho-version} + + p2 + JavaSE-11 + + targetplatform.target + + + + win32 + win32 + x86_64 + + + linux + gtk + x86_64 + + + + + + + diff --git a/tycho-its/projects/P2RedirectLoop/targetplatform.target b/tycho-its/projects/P2RedirectLoop/targetplatform.target new file mode 100644 index 0000000000..932d9c82a6 --- /dev/null +++ b/tycho-its/projects/P2RedirectLoop/targetplatform.target @@ -0,0 +1,10 @@ + + + + + + + + + + diff --git a/tycho-its/src/test/java/org/eclipse/tycho/test/P2RedirectLoop/P2RedirectLoopTest.java b/tycho-its/src/test/java/org/eclipse/tycho/test/P2RedirectLoop/P2RedirectLoopTest.java new file mode 100644 index 0000000000..f5bde5d30e --- /dev/null +++ b/tycho-its/src/test/java/org/eclipse/tycho/test/P2RedirectLoop/P2RedirectLoopTest.java @@ -0,0 +1,65 @@ +/******************************************************************************* + * Copyright (c) 2024 Tobias Hahnen and others. + * This program and the accompanying materials + * are made available under the terms of the Eclipse Public License 2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Tobias Hahnen - initial API and implementation + *******************************************************************************/ +package org.eclipse.tycho.test.P2RedirectLoop; + +import java.io.File; +import java.io.IOException; + +import javax.xml.parsers.ParserConfigurationException; + +import org.apache.maven.it.Verifier; +import org.eclipse.tycho.p2maven.transport.RedirectionLoopException; +import org.eclipse.tycho.test.AbstractTychoIntegrationTest; +import org.eclipse.tycho.test.util.HttpServer; +import org.eclipse.tycho.test.util.TargetDefinitionUtil; +import org.junit.After; +import org.junit.Assert; +import org.junit.Before; +import org.junit.Rule; +import org.junit.Test; +import org.junit.rules.TemporaryFolder; +import org.xml.sax.SAXException; + +public class P2RedirectLoopTest extends AbstractTychoIntegrationTest { + private HttpServer server; + @Rule + public final TemporaryFolder temporaryFolder = new TemporaryFolder(); + private Verifier verifier; + + @Before + public void startServer() throws Exception { + server = HttpServer.startServer(); + server.addServer("loop", temporaryFolder.getRoot()); + verifier = getVerifier("P2RedirectLoop", false); + } + + @After + public void stopServer() throws Exception { + if (server != null) { + server.stop(); + } + } + + @Test + public void test_redirection_loop_warning() throws Exception { + var redirectedUrl = server.addRedirect("loop", originalPath -> originalPath); + configureRepositoryInTargetDefinition(redirectedUrl); + Assert.assertThrows(RedirectionLoopException.class, () -> verifier.executeGoal("package")); + } + + private void configureRepositoryInTargetDefinition(String url) + throws IOException, ParserConfigurationException, SAXException { + File platformFile = new File(verifier.getBasedir(), "targetplatform.target"); + TargetDefinitionUtil.setRepositoryURLs(platformFile, "loop", url); + } +}