Skip to content

Commit

Permalink
[MNG-8012] Warn if in-reactor BOM import happens (#1434)
Browse files Browse the repository at this point in the history
This should be in fact prevented IMHO. Also, model builder missed File uses are corrected.

---

https://issues.apache.org/jira/browse/MNG-8012
  • Loading branch information
cstamas authored Mar 1, 2024
1 parent 9780ca1 commit 5029cc2
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,17 @@
import java.io.File;
import java.io.IOException;
import java.lang.reflect.Field;
import java.util.*;
import java.nio.file.Path;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import java.util.Properties;
import java.util.concurrent.Callable;
import java.util.function.Supplier;
import java.util.stream.Collectors;
Expand Down Expand Up @@ -1032,14 +1042,27 @@ private DefaultModelBuildingResult asDefaultModelBuildingResult(ModelBuildingRes
}
}

@Deprecated
@Override
public Result<? extends Model> buildRawModel(File pomFile, int validationLevel, boolean locationTracking) {
return buildRawModel(pomFile.toPath(), validationLevel, locationTracking, null);
}

@Override
public Result<? extends Model> buildRawModel(Path pomFile, int validationLevel, boolean locationTracking) {
return buildRawModel(pomFile, validationLevel, locationTracking, null);
}

@Deprecated
@Override
public Result<? extends Model> buildRawModel(
File pomFile, int validationLevel, boolean locationTracking, TransformerContext context) {
return buildRawModel(pomFile.toPath(), validationLevel, locationTracking, context);
}

@Override
public Result<? extends Model> buildRawModel(
Path pomFile, int validationLevel, boolean locationTracking, TransformerContext context) {
final ModelBuildingRequest request = new DefaultModelBuildingRequest()
.setValidationLevel(validationLevel)
.setLocationTracking(locationTracking)
Expand All @@ -1050,7 +1073,7 @@ public Result<? extends Model> buildRawModel(

try {
if (transformer != null && context != null) {
transformer.transform(pomFile.toPath(), context, model);
transformer.transform(pomFile, context, model);
}
} catch (TransformerException e) {
problems.add(
Expand Down Expand Up @@ -1830,6 +1853,15 @@ private org.apache.maven.api.model.DependencyManagement doLoadDependencyManageme
return null;
}

if (importSource instanceof FileModelSource && request.getRootDirectory() != null) {
Path sourcePath = ((FileModelSource) importSource).getPath();
if (sourcePath.startsWith(request.getRootDirectory())) {
problems.add(new ModelProblemCollectorRequest(Severity.WARNING, ModelProblem.Version.BASE)
.setMessage("BOM imports from within reactor should be avoided")
.setLocation(dependency.getLocation("")));
}
}

final ModelBuildingResult importResult;
try {
ModelBuildingRequest importRequest = new DefaultModelBuildingRequest();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
package org.apache.maven.model.building;

import java.io.File;
import java.nio.file.Path;

import org.apache.maven.model.Model;

Expand Down Expand Up @@ -52,11 +53,31 @@ public interface ModelBuilder {

/**
* Performs only the part of {@link ModelBuilder#build(ModelBuildingRequest)} that loads the raw model
*
* @deprecated Use {@link #buildRawModel(Path, int, boolean)} instead.
*/
@Deprecated
Result<? extends Model> buildRawModel(File pomFile, int validationLevel, boolean locationTracking);

/**
* Performs only the part of {@link ModelBuilder#build(ModelBuildingRequest)} that loads the raw model
*
* @since 4.0.0
*/
Result<? extends Model> buildRawModel(Path pomFile, int validationLevel, boolean locationTracking);

/**
* @deprecated Use {@link #buildRawModel(Path, int, boolean, TransformerContext)} instead.
*/
@Deprecated
Result<? extends Model> buildRawModel(
File pomFile, int validationLevel, boolean locationTracking, TransformerContext context);

/**
* @since 4.0.0
*/
Result<? extends Model> buildRawModel(
Path pomFile, int validationLevel, boolean locationTracking, TransformerContext context);

TransformerContextBuilder newTransformerContextBuilder();
}

0 comments on commit 5029cc2

Please sign in to comment.