Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/master' into MNG-8100-4.x
Browse files Browse the repository at this point in the history
  • Loading branch information
gnodet committed Apr 23, 2024
2 parents 69ed18f + 52c5659 commit fc761a0
Show file tree
Hide file tree
Showing 21 changed files with 168 additions and 51 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,6 @@ public AbstractSession(
this.repositorySystem = repositorySystem;
this.repositories = getRepositories(repositories, resolverRepositories);
this.lookup = lookup;
this.session.getData().set(InternalSession.class, this);
}

@Override
Expand Down Expand Up @@ -155,13 +154,13 @@ public List<org.eclipse.aether.graph.Dependency> toDependencies(
return dependencies == null ? null : map(dependencies, d -> toDependency(d, managed));
}

protected List<RemoteRepository> getRepositories(
static List<RemoteRepository> getRepositories(
List<RemoteRepository> repositories,
List<org.eclipse.aether.repository.RemoteRepository> resolverRepositories) {
if (repositories != null) {
return repositories;
} else if (resolverRepositories != null) {
return map(resolverRepositories, this::getRemoteRepository);
return map(resolverRepositories, DefaultRemoteRepository::new);
} else {
throw new IllegalArgumentException("no remote repositories provided");
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,12 @@ static InternalSession from(org.eclipse.aether.RepositorySystemSession session)
return cast(InternalSession.class, session.getData().get(InternalSession.class), "session");
}

static void associate(org.eclipse.aether.RepositorySystemSession rsession, Session session) {
if (!rsession.getData().set(InternalSession.class, null, from(session))) {
throw new IllegalStateException("A maven session is already associated with the repository session");
}
}

RemoteRepository getRemoteRepository(org.eclipse.aether.repository.RemoteRepository repository);

Node getNode(org.eclipse.aether.graph.DependencyNode node);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -414,6 +414,7 @@ static Session newSession(RepositorySystem system, Lookup lookup) {
.map(repositoryFactory::createRemote)
.toList();
InternalSession s = (InternalSession) session.withRemoteRepositories(repositories);
InternalSession.associate(rsession, s);
return s;

// List<RemoteRepository> repositories = repositoryFactory.createRemote();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
import org.apache.maven.execution.MavenExecutionRequest;
import org.apache.maven.execution.MavenSession;
import org.apache.maven.internal.impl.DefaultSession;
import org.apache.maven.internal.impl.InternalSession;
import org.apache.maven.model.Build;
import org.apache.maven.model.Dependency;
import org.apache.maven.model.Exclusion;
Expand Down Expand Up @@ -128,6 +129,7 @@ protected MavenSession createMavenSession(File pom, Properties executionProperti
getContainer(), configuration.getRepositorySession(), request, new DefaultMavenExecutionResult());
DefaultSession iSession =
new DefaultSession(session, mock(org.eclipse.aether.RepositorySystem.class), null, null, null, null);
InternalSession.associate(session.getRepositorySession(), iSession);
session.setSession(iSession);

List<MavenProject> projects = new ArrayList<>();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
import org.apache.maven.execution.MavenSession;
import org.apache.maven.internal.impl.DefaultLookup;
import org.apache.maven.internal.impl.DefaultSession;
import org.apache.maven.internal.impl.InternalSession;
import org.apache.maven.model.building.ModelBuildingException;
import org.apache.maven.model.building.ModelProblem;
import org.apache.maven.repository.RepositorySystem;
Expand Down Expand Up @@ -153,12 +154,13 @@ protected void initRepoSession(ProjectBuildingRequest request) {
DefaultMavenExecutionRequest mavenExecutionRequest = new DefaultMavenExecutionRequest();
MavenSession msession =
new MavenSession(getContainer(), session, mavenExecutionRequest, new DefaultMavenExecutionResult());
new DefaultSession(
DefaultSession iSession = new DefaultSession(
msession,
mock(org.eclipse.aether.RepositorySystem.class),
null,
null,
new DefaultLookup(container),
null);
InternalSession.associate(session, iSession);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,7 @@ void testThatASystemScopedDependencyIsNotResolvedFromRepositories() throws Excep
new MavenSession(container, session, mavenExecutionRequest, new DefaultMavenExecutionResult());
legacySupport.setSession(mavenSession);
InternalSession iSession = new DefaultSession(mavenSession, null, null, null, null, null);
InternalSession.associate(session, iSession);

ArtifactResolutionResult result = repositorySystem.resolve(request);
resolutionErrorHandler.throwErrors(request, result);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,9 @@ public DefaultSession(
}

public MavenSession getMavenSession() {
if (mavenSession == null) {
throw new IllegalArgumentException("Found null mavenSession on session " + this);
}
return mavenSession;
}

Expand All @@ -94,19 +97,19 @@ public List<ArtifactRepository> toArtifactRepositories(List<RemoteRepository> re
@Nonnull
@Override
public Settings getSettings() {
return mavenSession.getSettings().getDelegate();
return getMavenSession().getSettings().getDelegate();
}

@Nonnull
@Override
public Map<String, String> getUserProperties() {
return Collections.unmodifiableMap(new PropertiesAsMap(mavenSession.getUserProperties()));
return Collections.unmodifiableMap(new PropertiesAsMap(getMavenSession().getUserProperties()));
}

@Nonnull
@Override
public Map<String, String> getSystemProperties() {
return Collections.unmodifiableMap(new PropertiesAsMap(mavenSession.getSystemProperties()));
return Collections.unmodifiableMap(new PropertiesAsMap(getMavenSession().getSystemProperties()));
}

@Nonnull
Expand All @@ -128,29 +131,29 @@ public Version getMavenVersion() {

@Override
public int getDegreeOfConcurrency() {
return mavenSession.getRequest().getDegreeOfConcurrency();
return getMavenSession().getRequest().getDegreeOfConcurrency();
}

@Nonnull
@Override
public Instant getStartTime() {
return mavenSession.getRequest().getStartTime().toInstant();
return getMavenSession().getRequest().getStartTime().toInstant();
}

@Override
public Path getRootDirectory() {
return mavenSession.getRequest().getRootDirectory();
return getMavenSession().getRequest().getRootDirectory();
}

@Override
public Path getTopDirectory() {
return mavenSession.getRequest().getTopDirectory();
return getMavenSession().getRequest().getTopDirectory();
}

@Nonnull
@Override
public List<Project> getProjects() {
return getProjects(mavenSession.getProjects());
return getProjects(getMavenSession().getProjects());
}

@Nonnull
Expand All @@ -161,14 +164,14 @@ public Map<String, Object> getPluginContext(Project project) {
MojoExecution mojoExecution = lookup.lookup(MojoExecution.class);
MojoDescriptor mojoDescriptor = mojoExecution.getMojoDescriptor();
PluginDescriptor pluginDescriptor = mojoDescriptor.getPluginDescriptor();
return mavenSession.getPluginContext(pluginDescriptor, ((DefaultProject) project).getProject());
return getMavenSession().getPluginContext(pluginDescriptor, ((DefaultProject) project).getProject());
} catch (LookupException e) {
throw new MavenException("The PluginContext is only available during a mojo execution", e);
}
}

protected Session newSession(RepositorySystemSession repoSession, List<RemoteRepository> repositories) {
final MavenSession ms = nonNull(mavenSession);
final MavenSession ms = nonNull(getMavenSession());
final MavenSession mss;
if (repoSession != ms.getRepositorySession()) {
mss = new MavenSession(repoSession, ms.getRequest(), ms.getResult());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,9 @@ public DefaultSessionFactory(
}

public InternalSession newSession(MavenSession mavenSession) {
return new DefaultSession(
InternalSession session = new DefaultSession(
mavenSession, repositorySystem, null, mavenRepositorySystem, lookup, runtimeInformation);
InternalSession.associate(mavenSession.getRepositorySession(), session);
return session;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.ForkJoinTask;
import java.util.concurrent.Future;
import java.util.concurrent.atomic.AtomicReference;

import org.apache.maven.api.model.Dependency;
Expand Down Expand Up @@ -85,7 +86,7 @@ public class ProjectModelResolver implements ModelResolver {

private final ProjectBuildingRequest.RepositoryMerging repositoryMerging;

private final Map<String, ForkJoinTask<Result>> parentCache;
private final Map<String, Future<Result>> parentCache;

public ProjectModelResolver(
RepositorySystemSession session,
Expand Down Expand Up @@ -189,38 +190,39 @@ public ModelSource resolveModel(final Parent parent, AtomicReference<Parent> mod
throws UnresolvableModelException {
Result result;
try {
ForkJoinTask<Result> future = parentCache.computeIfAbsent(parent.getId(), id -> new ForkJoinTask<>() {
Result result;

@Override
public Result getRawResult() {
return result;
}
Future<Result> future = parentCache.computeIfAbsent(parent.getId(), id -> {
ForkJoinPool pool = new ForkJoinPool(MAX_CAP);
ForkJoinTask<Result> task = new ForkJoinTask<>() {
Result result;

@Override
public Result getRawResult() {
return result;
}

@Override
protected void setRawResult(Result result) {
this.result = result;
}
@Override
protected void setRawResult(Result result) {
this.result = result;
}

@Override
protected boolean exec() {
try {
AtomicReference<Parent> modified = new AtomicReference<>();
ModelSource source = doResolveModel(parent, modified);
result = new Result(source, modified.get(), null);
} catch (Exception e) {
result = new Result(null, null, e);
@Override
protected boolean exec() {
try {
AtomicReference<Parent> modified = new AtomicReference<>();
ModelSource source = doResolveModel(parent, modified);
result = new Result(source, modified.get(), null);
} catch (Exception e) {
result = new Result(null, null, e);
} finally {
pool.shutdown();
}
return true;
}
return true;
}
};
pool.submit(task);
return task;
});
ForkJoinPool pool = new ForkJoinPool(MAX_CAP);
try {
pool.execute(future);
result = future.get();
} finally {
pool.shutdownNow();
}
result = future.get();
} catch (Exception e) {
throw new UnresolvableModelException(e, parent.getGroupId(), parent.getArtifactId(), parent.getVersion());
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,11 @@ public <T> Provider<T> scope(final Key<T> key, final Provider<T> unscoped) {
private <T> T createProxy(Key<T> key, Provider<T> unscoped) {
InvocationHandler dispatcher = (proxy, method, args) -> {
method.setAccessible(true);
return method.invoke(getScopeState().scope(key, unscoped).get(), args);
try {
return method.invoke(getScopeState().scope(key, unscoped).get(), args);
} catch (InvocationTargetException e) {
throw e.getCause();
}
};
Class<T> superType = (Class<T>) key.getTypeLiteral().getRawType();
Class<?>[] interfaces = getInterfaces(superType);
Expand Down
12 changes: 7 additions & 5 deletions maven-core/src/site/apt/artifact-handlers.apt
Original file line number Diff line number Diff line change
Expand Up @@ -16,21 +16,23 @@
~~ under the License.

---
Default Artifact Handlers Reference
Legacy Artifact Handlers Reference
---
Hervé Boutemy
---
2013-08-02
---

Default Artifact Handlers Reference
Legacy Artifact Handlers Reference

Artifact handlers (see {{{../maven-artifact/apidocs/org/apache/maven/artifact/handler/ArtifactHandler.html} API}})
Maven 3 artifact handlers (see {{{../maven-artifact/apidocs/org/apache/maven/artifact/handler/ArtifactHandler.html} API}})
define for each {{{../maven-model/maven.html#class_dependency}dependency type}} information on the artifact
(classifier, extension, language) and how to manage it as dependency (add to classpath, include dependencies).

Some artifact handlers
are configured by default in {{{./apidocs/org/apache/maven/artifact/handler/providers/package-summary.html}<<<org.apache.maven.artifact.handler.providers>>>}} package:
They are replaced in Maven 4 with Maven 4 API Core's {{{../api/maven-api-core/apidocs/org/apache/maven/api/Type.html}Dependency Types}},
with default values defined in {{{../maven-resolver-provider/apidocs/org/apache/maven/repository/internal/type/DefaultTypeProvider.html}DefaultTypeProvider}}.

For compatibility, legacy Maven 3 artifact handlers are still provided:

*--------------------+---------------+------------+------------+-----------+---------------------+-----------------------+
|| type || classifier || extension || packaging || language || added to classpath || includesDependencies ||
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import org.apache.maven.execution.DefaultMavenExecutionResult;
import org.apache.maven.execution.MavenSession;
import org.apache.maven.internal.impl.DefaultSession;
import org.apache.maven.internal.impl.InternalSession;
import org.eclipse.aether.DefaultRepositorySystemSession;

public class MavenTestHelper {
Expand All @@ -31,6 +32,7 @@ public static DefaultRepositorySystemSession createSession(MavenRepositorySystem
DefaultMavenExecutionRequest request = new DefaultMavenExecutionRequest();
MavenSession mavenSession = new MavenSession(repoSession, request, new DefaultMavenExecutionResult());
DefaultSession session = new DefaultSession(mavenSession, null, null, repositorySystem, null, null);
InternalSession.associate(repoSession, session);
return repoSession;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,7 @@ void setup() {
new RemoteRepository.Builder("mirror", "default", "file:target/test-classes/repo").build());
this.session = session.withLocalRepository(localRepository)
.withRemoteRepositories(Collections.singletonList(remoteRepository));
InternalSession.associate(rss, this.session);
sessionScope.enter();
sessionScope.seed(InternalMavenSession.class, InternalMavenSession.from(this.session));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
import org.apache.maven.execution.DefaultMavenExecutionResult;
import org.apache.maven.execution.MavenSession;
import org.apache.maven.internal.impl.DefaultSession;
import org.apache.maven.internal.impl.InternalSession;
import org.codehaus.plexus.PlexusContainer;
import org.codehaus.plexus.testing.PlexusTest;
import org.eclipse.aether.DefaultRepositorySystemSession;
Expand Down Expand Up @@ -71,6 +72,7 @@ public static RepositorySystemSession newMavenRepositorySystemSession(Repository
DefaultMavenExecutionRequest request = new DefaultMavenExecutionRequest();
MavenSession mavenSession = new MavenSession(rsession, request, new DefaultMavenExecutionResult());
DefaultSession session = new DefaultSession(mavenSession, null, null, null, null, null);
InternalSession.associate(rsession, session);

return rsession;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ void testModelBuilder() throws Exception {
MavenSession msession = new MavenSession(rsession, mavenRequest, new DefaultMavenExecutionResult());
InternalSession session =
new DefaultSession(msession, repositorySystem, null, mavenRepositorySystem, null, null);
InternalSession.associate(rsession, session);

List<ProjectBuildingResult> results = projectBuilder.build(
Collections.singletonList(new File("src/test/resources/projects/tree/pom.xml")), true, request);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ void testProxiedSessionScopedBean() throws ComponentLookupException {
assertNotNull(bean.myBean.getSession());
assertNotNull(bean.myBean.getAnotherBean());
assertSame(bean.myBean.getAnotherBean().getClass(), AnotherBean.class);
assertThrows(TestException.class, () -> bean.myBean.throwException());
}

@Named
Expand Down Expand Up @@ -102,6 +103,8 @@ interface BeanItf {
Session getSession();

BeanItf2 getAnotherBean();

void throwException() throws TestException;
}

interface BeanItf2 {}
Expand All @@ -127,5 +130,11 @@ public Session getSession() {
public BeanItf2 getAnotherBean() {
return anotherBean;
}

public void throwException() throws TestException {
throw new TestException();
}
}

static class TestException extends Exception {}
}
Loading

0 comments on commit fc761a0

Please sign in to comment.