blob: 62fe81c32f379abad128d334a5db1fa0ce93ac38 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.maven.it;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;
import java.util.regex.Pattern;
import org.apache.maven.shared.verifier.Verifier;
import org.apache.maven.shared.verifier.util.ResourceExtractor;
import org.junit.jupiter.api.Test;
/**
* Test for
* <a href="https://issues.apache.org/jira/browse/MNG-5222">MNG-5222</a>
* <a href="https://issues.apache.org/jira/browse/MNG-7457">MNG-7457</a>
*/
public class MavenITmng5222MojoDeprecatedTest extends AbstractMavenIntegrationTestCase {
public MavenITmng5222MojoDeprecatedTest() {
super("[3.9.0,)");
}
/**
* Test that ensures that deprecation is not printed for empty and default value
*
* @throws Exception in case of failure
*/
@Test
public void testEmptyConfiguration() throws Exception {
File testDir = ResourceExtractor.simpleExtractResources(getClass(), "/mng-5222-mojo-deprecated-params");
Verifier verifier = newVerifier(testDir.getAbsolutePath());
verifier.setAutoclean(false);
verifier.deleteDirectory("target");
verifier.setLogFileName("log-empty-configuration.txt");
verifier.addCliArgument("-Dmaven.plugin.validation=verbose");
verifier.addCliArgument("validate");
verifier.execute();
verifier.verifyErrorFreeLog();
List<String> logLines = verifier.loadFile(verifier.getBasedir(), verifier.getLogFileName(), false);
List<String> warnLines = findDeprecationWarning(logLines);
assertTrue(warnLines.stream()
.anyMatch(s -> s.contains("Goal 'deprecated-config' is deprecated: This goal is deprecated")));
Properties configProps = verifier.loadProperties("target/config.properties");
assertEquals("0", configProps.remove("deprecatedArray"));
assertEquals("3", configProps.remove("deprecatedArrayWithDefaults"));
assertEquals("a1 ", configProps.remove("deprecatedArrayWithDefaults.0"));
assertEquals("a2", configProps.remove("deprecatedArrayWithDefaults.1"));
assertEquals(" a3", configProps.remove("deprecatedArrayWithDefaults.2"));
assertEquals("0", configProps.remove("deprecatedList"));
assertEquals("3", configProps.remove("deprecatedListWithDefaults"));
assertEquals("l1", configProps.remove("deprecatedListWithDefaults.0"));
assertEquals("l2", configProps.remove("deprecatedListWithDefaults.1"));
assertEquals("l3", configProps.remove("deprecatedListWithDefaults.2"));
assertEquals("testValue", configProps.remove("deprecatedParamWithDefaultConstant"));
assertEquals("https://www.test.org", configProps.remove("deprecatedParamWithDefaultEvaluate"));
assertTrue("not checked config properties: " + configProps, configProps.isEmpty());
}
/**
* Test that ensures that deprecation is printed for deprecated parameter set by property
*
* @throws Exception in case of failure
*/
@Test
public void testDeprecatedProperty() throws Exception {
File testDir = ResourceExtractor.simpleExtractResources(getClass(), "/mng-5222-mojo-deprecated-params");
Verifier verifier = newVerifier(testDir.getAbsolutePath());
verifier.addCliArgument("-Dconfig.deprecatedParam2=deprecatedValueInProps");
verifier.addCliArgument("-Dconfig.deprecatedArray=3,2,4,deprecated");
verifier.addCliArgument("-Dconfig.deprecatedList=4,5,deprecated");
verifier.setAutoclean(false);
verifier.deleteDirectory("target");
verifier.setLogFileName("log-deprecated-property.txt");
verifier.addCliArgument("-Dmaven.plugin.validation=verbose");
verifier.addCliArgument("validate");
verifier.execute();
verifier.verifyErrorFreeLog();
List<String> logLines = verifier.loadFile(verifier.getBasedir(), verifier.getLogFileName(), false);
List<String> warnLines = findDeprecationWarning(logLines);
assertTrue(warnLines.stream()
.anyMatch(s -> s.contains("Goal 'deprecated-config' is deprecated: This goal is deprecated")));
assertTrue(
warnLines.stream()
.anyMatch(
s -> s.contains(
"Parameter 'deprecatedParam2' (user property 'config.deprecatedParam2') is deprecated: No reason given")));
assertTrue(
warnLines.stream()
.anyMatch(
s -> s.contains(
"Parameter 'deprecatedArray' (user property 'config.deprecatedArray') is deprecated: deprecated array")));
assertTrue(
warnLines.stream()
.anyMatch(
s -> s.contains(
"Parameter 'deprecatedList' (user property 'config.deprecatedList') is deprecated: deprecated list")));
Properties configProps = verifier.loadProperties("target/config.properties");
assertEquals("deprecatedValueInProps", configProps.remove("deprecatedParam2"));
assertEquals("4", configProps.remove("deprecatedArray"));
assertEquals("3", configProps.remove("deprecatedArray.0"));
assertEquals("2", configProps.remove("deprecatedArray.1"));
assertEquals("4", configProps.remove("deprecatedArray.2"));
assertEquals("deprecated", configProps.remove("deprecatedArray.3"));
assertEquals("3", configProps.remove("deprecatedArrayWithDefaults"));
assertEquals("a1 ", configProps.remove("deprecatedArrayWithDefaults.0"));
assertEquals("a2", configProps.remove("deprecatedArrayWithDefaults.1"));
assertEquals(" a3", configProps.remove("deprecatedArrayWithDefaults.2"));
assertEquals("3", configProps.remove("deprecatedList"));
assertEquals("4", configProps.remove("deprecatedList.0"));
assertEquals("5", configProps.remove("deprecatedList.1"));
assertEquals("deprecated", configProps.remove("deprecatedList.2"));
assertEquals("3", configProps.remove("deprecatedListWithDefaults"));
assertEquals("l1", configProps.remove("deprecatedListWithDefaults.0"));
assertEquals("l2", configProps.remove("deprecatedListWithDefaults.1"));
assertEquals("l3", configProps.remove("deprecatedListWithDefaults.2"));
assertEquals("testValue", configProps.remove("deprecatedParamWithDefaultConstant"));
assertEquals("https://www.test.org", configProps.remove("deprecatedParamWithDefaultEvaluate"));
assertTrue("not checked config properties: " + configProps, configProps.isEmpty());
}
/**
* Test that ensures that deprecation is printed for deprecated parameter set by plugin configuration.
*
* @throws Exception in case of failure
*/
@Test
public void testDeprecatedConfig() throws Exception {
File testDir = ResourceExtractor.simpleExtractResources(getClass(), "/mng-5222-mojo-deprecated-params");
Verifier verifier = newVerifier(testDir.getAbsolutePath());
verifier.addCliArgument("-Pconfig-values");
verifier.setAutoclean(false);
verifier.deleteDirectory("target");
verifier.setLogFileName("log-deprecated-config.txt");
verifier.addCliArgument("-Dmaven.plugin.validation=verbose");
verifier.addCliArgument("validate");
verifier.execute();
verifier.verifyErrorFreeLog();
List<String> logLines = verifier.loadFile(verifier.getBasedir(), verifier.getLogFileName(), false);
List<String> warnLines = findDeprecationWarning(logLines);
assertTrue(warnLines.stream()
.anyMatch(s -> s.contains("Goal 'deprecated-config' is deprecated: This goal is deprecated")));
assertTrue(warnLines.stream()
.anyMatch(s -> s.contains("Parameter 'deprecatedParam' is deprecated: I'm deprecated param")));
assertTrue(
warnLines.stream()
.anyMatch(
s -> s.contains(
"Parameter 'deprecatedParam2' (user property 'config.deprecatedParam2') is deprecated: No reason given")));
assertTrue(
warnLines.stream()
.anyMatch(
s -> s.contains(
"Parameter 'deprecatedParamWithDefaultConstant' is deprecated: deprecated with constant value")));
assertTrue(
warnLines.stream()
.anyMatch(
s -> s.contains(
"Parameter 'deprecatedParamWithDefaultEvaluate' is deprecated: deprecated with evaluate value")));
assertTrue(
warnLines.stream()
.anyMatch(
s -> s.contains(
"Parameter 'deprecatedArray' (user property 'config.deprecatedArray') is deprecated: deprecated array")));
assertTrue(warnLines.stream()
.anyMatch(s -> s.contains("Parameter 'deprecatedArrayWithDefaults' is deprecated: deprecated array")));
assertTrue(
warnLines.stream()
.anyMatch(
s -> s.contains(
"Parameter 'deprecatedList' (user property 'config.deprecatedList') is deprecated: deprecated list")));
assertTrue(warnLines.stream()
.anyMatch(s -> s.contains("Parameter 'deprecatedListWithDefaults' is deprecated: deprecated list")));
assertTrue(warnLines.stream()
.anyMatch(s -> s.contains("Parameter 'deprecatedProperties' is deprecated: deprecated properties")));
assertTrue(warnLines.stream()
.anyMatch(s -> s.contains("Parameter 'deprecatedMap' is deprecated: deprecated map")));
Properties configProps = verifier.loadProperties("target/config.properties");
assertEquals("value1", configProps.remove("deprecatedParam"));
assertEquals("value2", configProps.remove("deprecatedParam2"));
assertEquals("value3", configProps.remove("deprecatedParamWithDefaultConstant"));
assertEquals("value4", configProps.remove("deprecatedParamWithDefaultEvaluate"));
assertEquals("2", configProps.remove("deprecatedArray"));
assertEquals("a1", configProps.remove("deprecatedArray.0"));
assertEquals("a2", configProps.remove("deprecatedArray.1"));
assertEquals("2", configProps.remove("deprecatedArrayWithDefaults"));
assertEquals("b1", configProps.remove("deprecatedArrayWithDefaults.0"));
assertEquals("b2", configProps.remove("deprecatedArrayWithDefaults.1"));
assertEquals("2", configProps.remove("deprecatedList"));
assertEquals("c1", configProps.remove("deprecatedList.0"));
assertEquals("c2", configProps.remove("deprecatedList.1"));
assertEquals("2", configProps.remove("deprecatedListWithDefaults"));
assertEquals("d1", configProps.remove("deprecatedListWithDefaults.0"));
assertEquals("d2", configProps.remove("deprecatedListWithDefaults.1"));
assertEquals("2", configProps.remove("deprecatedProperties"));
assertEquals("propertyValue1", configProps.remove("deprecatedProperties.propertyName1"));
assertEquals("propertyValue2", configProps.remove("deprecatedProperties.propertyName2"));
assertEquals("2", configProps.remove("deprecatedMap"));
assertEquals("value1", configProps.remove("deprecatedMap.key1"));
assertEquals("value2", configProps.remove("deprecatedMap.key2"));
assertTrue("not checked config properties: " + configProps, configProps.isEmpty());
}
private List<String> findDeprecationWarning(List<String> logLines) {
Pattern pattern = Pattern.compile(".* (Parameter|Goal) .* is deprecated:.*");
List<String> result = new ArrayList<>();
for (String line : logLines) {
if (pattern.matcher(line).matches()) {
result.add(line);
}
}
return result;
}
}