From 818574c351f3b7ae50e36ee5fa7dadeff7393429 Mon Sep 17 00:00:00 2001 From: George Fraser Date: Tue, 1 Jan 2019 22:33:28 -0800 Subject: Get jar paths directly from maven --- src/main/java/org/javacs/InferConfig.java | 93 ++++++++++++++------------- src/test/java/org/javacs/InferConfigTest.java | 29 ++++++--- 2 files changed, 68 insertions(+), 54 deletions(-) (limited to 'src') diff --git a/src/main/java/org/javacs/InferConfig.java b/src/main/java/org/javacs/InferConfig.java index 8568ffb..7a99328 100644 --- a/src/main/java/org/javacs/InferConfig.java +++ b/src/main/java/org/javacs/InferConfig.java @@ -3,6 +3,7 @@ package org.javacs; import java.io.BufferedReader; import java.io.File; import java.io.IOException; +import java.io.InputStream; import java.io.InputStreamReader; import java.nio.file.FileSystems; import java.nio.file.Files; @@ -77,14 +78,9 @@ class InferConfig { } // Maven - if (Files.exists(workspaceRoot.resolve("pom.xml"))) { - var result = new HashSet(); - for (var a : mvnDependencies()) { - var found = findMavenJar(a, false); - if (found.isPresent()) result.add(found.get()); - else LOG.warning(String.format("Couldn't find jar for %s in %s", a, mavenHome)); - } - return result; + var pomXml = workspaceRoot.resolve("pom.xml"); + if (Files.exists(pomXml)) { + return mvnDependencies(pomXml, "dependency:list"); } // Bazel @@ -220,12 +216,9 @@ class InferConfig { } // Maven - if (Files.exists(workspaceRoot.resolve("pom.xml"))) { - var result = new HashSet(); - for (var a : mvnDependencies()) { - findMavenJar(a, true).ifPresent(result::add); - } - return result; + var pomXml = workspaceRoot.resolve("pom.xml"); + if (Files.exists(pomXml)) { + return mvnDependencies(pomXml, "dependency:sources"); } // TODO Bazel @@ -281,63 +274,75 @@ class InferConfig { return artifact.artifactId + '-' + artifact.version + (source ? "-sources" : "") + ".jar"; } - static List dependencyList(Path pomXml) { + static Set mvnDependencies(Path pomXml, String goal) { Objects.requireNonNull(pomXml, "pom.xml path is null"); try { - // Tell maven to output deps to a temporary file - var outputFile = Files.createTempFile("deps", ".txt"); - - // TODO consider using mvn dependency:copy-dependencies instead + // TODO consider using mvn valide dependency:copy-dependencies -DoutputDirectory=??? instead + // Run maven as a subprocess var command = List.of( getMvnCommand(), "validate", - "dependency:list", + goal, "-DincludeScope=test", - "-DoutputFile=" + outputFile); + "-DoutputAbsoluteArtifactFilename=true"); LOG.info("Running " + String.join(" ", command) + " ..."); var workingDirectory = pomXml.toAbsolutePath().getParent().toFile(); - var log = Files.createTempFile("maven", ".log"); - LOG.info("...sending output to " + log); - var result = + var process = new ProcessBuilder() .command(command) .directory(workingDirectory) .redirectError(ProcessBuilder.Redirect.INHERIT) - .redirectOutput(ProcessBuilder.Redirect.to(log.toFile())) - .start() - .waitFor(); - + .redirectOutput(ProcessBuilder.Redirect.PIPE) + .start(); + + // Read output on a separate thread + var reader = + new Runnable() { + Set dependencies; + + @Override + public void run() { + dependencies = readDependencyList(process.getInputStream()); + } + }; + var thread = new Thread(reader, "ReadMavenOutput"); + thread.start(); + + // Wait for process to exit + var result = process.waitFor(); if (result != 0) throw new RuntimeException("`" + String.join(" ", command) + "` returned " + result); - return readDependencyList(outputFile); + // Wait for thread to finish + thread.join(); + return reader.dependencies; } catch (InterruptedException | IOException e) { throw new RuntimeException(e); } } - private static List readDependencyList(Path outputFile) { - var artifact = Pattern.compile(".*:.*:.*:.*:.*"); - - try (var in = Files.newInputStream(outputFile)) { - return new BufferedReader(new InputStreamReader(in)) - .lines() - .map(String::trim) - .filter(line -> artifact.matcher(line).matches()) - .map(Artifact::parse) - .collect(Collectors.toList()); + private static Set readDependencyList(InputStream stdout) { + try (var in = new BufferedReader(new InputStreamReader(stdout))) { + var paths = new HashSet(); + for (var line = in.readLine(); line != null; line = in.readLine()) { + readDependency(line).ifPresent(paths::add); + } + return paths; } catch (IOException e) { throw new RuntimeException(e); } } - private Collection mvnDependencies() { - var pomXml = workspaceRoot.resolve("pom.xml"); - - if (Files.exists(pomXml)) return dependencyList(pomXml); + private static Pattern DEPENDENCY = Pattern.compile("^\\[INFO\\]\\s+(.*:.*:.*:.*:.*):(/.*)$"); - return Collections.emptyList(); + static Optional readDependency(String line) { + var match = DEPENDENCY.matcher(line); + if (!match.matches()) return Optional.empty(); + var artifact = match.group(1); + var path = match.group(2); + LOG.info(String.format("...artifact %s is at %s", artifact, path)); + return Optional.of(Paths.get(path)); } static String getMvnCommand() { diff --git a/src/test/java/org/javacs/InferConfigTest.java b/src/test/java/org/javacs/InferConfigTest.java index debd6db..d49ebb8 100644 --- a/src/test/java/org/javacs/InferConfigTest.java +++ b/src/test/java/org/javacs/InferConfigTest.java @@ -22,6 +22,7 @@ public class InferConfigTest { Collections.emptySet(), mavenHome, Paths.get("nowhere")); + private InferConfig thisProject = new InferConfig(Paths.get("."), Set.of()); @Test public void mavenClassPath() { @@ -63,24 +64,32 @@ public class InferConfigTest { @Test public void dependencyList() { + assertThat(InferConfig.mvnDependencies(Paths.get("pom.xml"), "dependency:list"), not(empty())); + } + + @Test + public void thisProjectClassPath() { assertThat( - InferConfig.dependencyList(Paths.get("pom.xml")), - hasItem(new Artifact("org.hamcrest", "hamcrest-all", "1.3"))); + thisProject.buildClassPath(), + hasItem(hasToString(endsWith(".m2/repository/junit/junit/4.12/junit-4.12.jar")))); } @Test - public void onlyPomXmlClassPath() { + public void thisProjectDocPath() { assertThat( - onlyPomXml.buildClassPath(), - contains(mavenHome.resolve("repository/com/external/external-library/1.2/external-library-1.2.jar"))); + thisProject.buildDocPath(), + hasItem(hasToString(endsWith(".m2/repository/junit/junit/4.12/junit-4.12-sources.jar")))); } @Test - public void onlyPomXmlDocPath() { + public void parseDependencyLine() { + var line = + "[INFO] org.openjdk.jmh:jmh-generator-annprocess:jar:1.21:provided:/Users/georgefraser/.m2/repository/org/openjdk/jmh/jmh-generator-annprocess/1.21/jmh-generator-annprocess-1.21.jar"; + var path = InferConfig.readDependency(line).get(); assertThat( - onlyPomXml.buildDocPath(), - contains( - mavenHome.resolve( - "repository/com/external/external-library/1.2/external-library-1.2-sources.jar"))); + path, + equalTo( + Paths.get( + "/Users/georgefraser/.m2/repository/org/openjdk/jmh/jmh-generator-annprocess/1.21/jmh-generator-annprocess-1.21.jar"))); } } -- cgit v1.2.3