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 */