org.apache.maven.plugins.invoker.JobExecutor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of maven-invoker-plugin Show documentation
Show all versions of maven-invoker-plugin Show documentation
The Maven Invoker Plugin is used to run a set of Maven projects. The plugin can determine whether each project
execution is successful, and optionally can verify the output generated from a given project execution.
The newest version!
/*
* 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.plugins.invoker;
import java.util.Comparator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.stream.Collectors;
import org.apache.maven.plugins.invoker.model.BuildJob;
/**
* Execute build jobs with parallel.
*
* @author Slawomir Jaranowski
*/
class JobExecutor {
interface ThrowableJobConsumer {
void accept(BuildJob t) throws Throwable;
}
private final List jobs;
private final int threadsCount;
JobExecutor(List jobs, int threadsCount) {
this.jobs = jobs;
this.threadsCount = threadsCount;
}
public void forEach(ThrowableJobConsumer jobConsumer) {
// group and sort jobs by ordinal
Map> groupedJobs = jobs.stream()
.sorted(Comparator.comparing(BuildJob::getOrdinal).reversed())
.collect(Collectors.groupingBy(BuildJob::getOrdinal, LinkedHashMap::new, Collectors.toList()));
ExecutorService executorService = Executors.newFixedThreadPool(threadsCount);
groupedJobs.forEach((key, value) -> {
// prepare list of callable tasks
List> callableJobs = value.stream()
.map(buildJob -> (Callable) () -> {
try {
jobConsumer.accept(buildJob);
} catch (Throwable e) {
buildJob.setResult(BuildJob.Result.ERROR);
buildJob.setFailureMessage(String.valueOf(e));
}
return null;
})
.collect(Collectors.toList());
try {
executorService.invokeAll(callableJobs);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
throw new RuntimeException(e);
}
});
// all task are finished here
executorService.shutdownNow();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy