de.dagere.peass.DependencyReadingParallelStarter Maven / Gradle / Ivy
package de.dagere.peass;
import java.io.File;
import java.util.List;
import java.util.concurrent.Callable;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import de.dagere.peass.config.ExecutionConfig;
import de.dagere.peass.config.parameters.DependencyReaderConfigMixin;
import de.dagere.peass.config.parameters.ExecutionConfigMixin;
import de.dagere.peass.config.parameters.KiekerConfigMixin;
import de.dagere.peass.dependency.execution.EnvironmentVariables;
import de.dagere.peass.dependency.parallel.PartialDependenciesMerger;
import de.dagere.peass.dependency.persistence.Dependencies;
import de.dagere.peass.dependency.reader.DependencyParallelReader;
import de.dagere.peass.dependencyprocessors.VersionComparator;
import de.dagere.peass.folders.ResultsFolders;
import de.dagere.peass.vcs.CommitUtil;
import de.dagere.peass.vcs.GitCommit;
import picocli.CommandLine;
import picocli.CommandLine.Command;
import picocli.CommandLine.Mixin;
@Command(description = "Reads the dependencies using parallel threads", name = "readDependencies")
public class DependencyReadingParallelStarter implements Callable {
private static final Logger LOG = LogManager.getLogger(DependencyReadingParallelStarter.class);
@Mixin
private DependencyReaderConfigMixin config;
@Mixin
private KiekerConfigMixin kiekerConfigMixin;
@Mixin
private ExecutionConfigMixin executionConfigMixin;
public static void main(final String[] args) {
try {
final CommandLine commandLine = new CommandLine(new DependencyReadingParallelStarter());
commandLine.execute(args);
} catch (final Throwable t) {
t.printStackTrace();
}
}
@Override
public Void call() throws Exception {
final List commits = CommitUtil.getGitCommits(executionConfigMixin.getStartversion(), executionConfigMixin.getEndversion(), config.getProjectFolder());
VersionComparator.setVersions(commits);
ExecutionConfig executionConfig = new ExecutionConfig(executionConfigMixin);
final DependencyParallelReader reader = new DependencyParallelReader(config.getProjectFolder(), config.getResultBaseFolder(), config.getProjectFolder().getName(), commits,
config.getDependencyConfig(), executionConfig, kiekerConfigMixin.getKiekerConfig(), new EnvironmentVariables());
final ResultsFolders[] outFiles = reader.readDependencies();
LOG.debug("Files: {}", outFiles);
final File out = new File(config.getResultBaseFolder(), "deps_" + config.getProjectFolder().getName() + ".json");
final Dependencies all = PartialDependenciesMerger.mergeVersions(out, outFiles);
return null;
}
}