From 70cf76fd551776359dd57f0f489cfc216c3b67ef Mon Sep 17 00:00:00 2001
From: treilhes
Date: Mon, 9 Sep 2024 16:08:33 +0200
Subject: [PATCH] Handle deferred var @{x} from surefire/failsafe in test
launch-configs
Fixes https://github.com/eclipse-m2e/m2e-core/issues/1824
---
.../deferredVariables/pom.xml | 105 ++++++++++++++++++
...UnitTestLaunchConfigConfigurationTest.java | 26 +++++
.../m2e/jdt/internal/UnitTestSupport.java | 37 +++++-
3 files changed, 166 insertions(+), 2 deletions(-)
create mode 100644 org.eclipse.m2e.jdt.tests/projects/surefireFailsafeToTestLaunchSettings/deferredVariables/pom.xml
diff --git a/org.eclipse.m2e.jdt.tests/projects/surefireFailsafeToTestLaunchSettings/deferredVariables/pom.xml b/org.eclipse.m2e.jdt.tests/projects/surefireFailsafeToTestLaunchSettings/deferredVariables/pom.xml
new file mode 100644
index 000000000..8cb98da5f
--- /dev/null
+++ b/org.eclipse.m2e.jdt.tests/projects/surefireFailsafeToTestLaunchSettings/deferredVariables/pom.xml
@@ -0,0 +1,105 @@
+
+ 4.0.0
+ TMP
+ TMP
+ 0.0.1-SNAPSHOT
+
+
+
+
+ org.apache.maven.plugins
+ maven-surefire-plugin
+ 3.5.0
+
+
+ default-test
+ test
+
+ test
+
+
+
+
+ -Xshare:off
+ -Djdk.net.URLClassPath.disableClassPathURLCheck=true
+ @{jacoco.surefireArgLine} @{titi.tata}
+
+
+
+
+
+
+
+
+ org.jacoco
+ jacoco-maven-plugin
+ 0.8.12
+
+
+ coverage-prepare-agent
+
+ prepare-agent
+
+
+
+ jacoco.surefireArgLine
+
+
+
+
+
+
+
+
+ org.eclipse.m2e
+ lifecycle-mapping
+ 1.0.0
+
+
+
+
+
+ org.jacoco
+ jacoco-maven-plugin
+ [0.0.0,)
+
+ prepare-agent
+
+
+
+
+ true
+
+
+
+
+
+
+
+
+
+
+
+
+
+ org.junit
+ junit-bom
+ 5.11.0
+ pom
+ import
+
+
+
+
+
+
+ org.junit.jupiter
+ junit-jupiter
+ test
+
+
+
\ No newline at end of file
diff --git a/org.eclipse.m2e.jdt.tests/src/org/eclipse/m2e/jdt/tests/UnitTestLaunchConfigConfigurationTest.java b/org.eclipse.m2e.jdt.tests/src/org/eclipse/m2e/jdt/tests/UnitTestLaunchConfigConfigurationTest.java
index e3f24fcc8..dfde32272 100644
--- a/org.eclipse.m2e.jdt.tests/src/org/eclipse/m2e/jdt/tests/UnitTestLaunchConfigConfigurationTest.java
+++ b/org.eclipse.m2e.jdt.tests/src/org/eclipse/m2e/jdt/tests/UnitTestLaunchConfigConfigurationTest.java
@@ -279,6 +279,32 @@ public void test_configuration_must_be_updated_with_failSafe_config_when_created
assertTrue(argLine.contains("-DfailsafeProp1=failsafeProp1Value"));
}
+ @Test
+ public void test_deferred_variable_are_resolved() throws CoreException, IOException, InterruptedException {
+ // Get launch type
+ ILaunchConfigurationType type = LAUNCH_MANAGER.getLaunchConfigurationType(testType);
+
+ assumeTrue(testType + " support not available", type != null);
+
+ File pomFile = getTestFile("deferredVariables/pom.xml");
+
+ IProject project = importProject(pomFile.getAbsolutePath());
+
+ // create basic unit test
+ createDefaultTest(project, type, "test.SomeTest");
+
+ updateProject(project);
+ waitForJobsToComplete();
+
+ ILaunchConfiguration[] updatedConfigurations = LAUNCH_MANAGER.getLaunchConfigurations(type);
+ assertTrue(updatedConfigurations.length == 1);
+
+ ILaunchConfiguration config = updatedConfigurations[0];
+ String argLine = config.getAttribute(UnitTestSupport.LAUNCH_CONFIG_VM_ARGUMENTS, "");
+ assertTrue(argLine.contains("-javaagent")); // resolved jacoco agent
+ assertTrue(argLine.contains("@{titi.tata}")); // unresolved property is unchanged as in CLI
+ }
+
private void updateProject(IProject project) throws CoreException, InterruptedException {
MavenPlugin.getProjectConfigurationManager().updateProjectConfiguration(project, monitor);
waitForJobsToComplete();
diff --git a/org.eclipse.m2e.jdt/src/org/eclipse/m2e/jdt/internal/UnitTestSupport.java b/org.eclipse.m2e.jdt/src/org/eclipse/m2e/jdt/internal/UnitTestSupport.java
index e57f9e737..fb4ace526 100644
--- a/org.eclipse.m2e.jdt/src/org/eclipse/m2e/jdt/internal/UnitTestSupport.java
+++ b/org.eclipse.m2e.jdt/src/org/eclipse/m2e/jdt/internal/UnitTestSupport.java
@@ -24,8 +24,10 @@
import java.util.List;
import java.util.Map;
import java.util.Optional;
+import java.util.Properties;
import java.util.Set;
import java.util.StringJoiner;
+import java.util.regex.Pattern;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@@ -143,6 +145,11 @@ public class UnitTestSupport {
*/
private static final String FAILSAFE_PLUGIN_ARTIFACT_ID = "maven-failsafe-plugin";
+ /**
+ * deffered variable pattern
+ */
+ private static final Pattern DEFERRED_VAR_PATTERN = Pattern.compile("@\\{(.*?)\\}");
+
/**
* maven group id for the maven plugins
*/
@@ -398,8 +405,11 @@ private TestLaunchArguments getTestLaunchArguments(MavenProject mavenProject, Mo
IProgressMonitor monitor) {
try {
IMaven maven = MavenPlugin.getMaven();
- return new TestLaunchArguments(
- maven.getMojoParameterValue(mavenProject, execution, PLUGIN_ARGLINE, String.class, monitor),
+
+ String argLine = maven.getMojoParameterValue(mavenProject, execution, PLUGIN_ARGLINE, String.class, monitor);
+ argLine = resolveDeferredVariables(mavenProject, argLine);
+
+ return new TestLaunchArguments(argLine,
maven.getMojoParameterValue(mavenProject, execution, PLUGIN_SYSPROP_VARIABLES, Map.class, monitor),
maven.getMojoParameterValue(mavenProject, execution, PLUGIN_ENVIRONMENT_VARIABLES, Map.class, monitor),
maven.getMojoParameterValue(mavenProject, execution, PLUGIN_WORKING_DIRECTORY, File.class, monitor),
@@ -412,6 +422,29 @@ private TestLaunchArguments getTestLaunchArguments(MavenProject mavenProject, Mo
}
+ /**
+ * This method is used to resolve deferred variables introduced by failsafe/surefire plugins in a given string value.
+ * Deferred variables are placeholders in the string that are replaced with actual values from the Maven project's
+ * properties. The placeholders are in the format @{...}, where ... is the key of the property. If a placeholder's
+ * corresponding property does not exist, the placeholder is left as is.
+ *
+ * @param mavenProject the Maven project from which to retrieve the properties
+ * @param value the string containing the placeholders to be replaced
+ * @return the string with all resolvable placeholders replaced with their corresponding property values
+ */
+ private static String resolveDeferredVariables(MavenProject mavenProject, String value) {
+ Properties properties = mavenProject.getProperties();
+ if(properties.isEmpty() || value == null) {
+ return value;
+ }
+ return DEFERRED_VAR_PATTERN.matcher(value).replaceAll(match -> {
+ String placeholder = match.group();
+ String key = match.group(1);
+ String replacement = properties.getProperty(key);
+ return replacement != null ? replacement : placeholder;
+ });
+ }
+
/**
* Holder for the surefire/failsafe launch arguments
*/