From a8c0aee2a1e76c06490568ebe4b8d6ba7dad7161 Mon Sep 17 00:00:00 2001 From: Georgios Andrianakis Date: Fri, 23 Sep 2022 09:39:17 +0300 Subject: [PATCH] Take quarkus.package.output-directory into account when launching native tests Fixes: #28131 --- .../common/DefaultNativeImageLauncher.java | 48 +++++++++++-------- .../test/common/NativeImageLauncher.java | 2 + .../test/junit/NativeTestExtension.java | 1 + .../launcher/NativeImageLauncherProvider.java | 10 +++- 4 files changed, 40 insertions(+), 21 deletions(-) diff --git a/test-framework/common/src/main/java/io/quarkus/test/common/DefaultNativeImageLauncher.java b/test-framework/common/src/main/java/io/quarkus/test/common/DefaultNativeImageLauncher.java index 33345980da115..2680369cdbe12 100644 --- a/test-framework/common/src/main/java/io/quarkus/test/common/DefaultNativeImageLauncher.java +++ b/test-framework/common/src/main/java/io/quarkus/test/common/DefaultNativeImageLauncher.java @@ -34,6 +34,7 @@ public class DefaultNativeImageLauncher implements NativeImageLauncher { private String testProfile; private List argLine; private String nativeImagePath; + private String configuredOutputDirectory; private Class testClass; private Process quarkusProcess; @@ -48,6 +49,7 @@ public void init(NativeImageInitContext initContext) { this.waitTimeSeconds = initContext.waitTime().getSeconds(); this.testProfile = initContext.testProfile(); this.nativeImagePath = initContext.nativeImagePath(); + this.configuredOutputDirectory = initContext.getConfiguredOutputDirectory(); this.argLine = initContext.argLine(); this.testClass = initContext.testClass(); } @@ -173,7 +175,7 @@ private void waitForStartedSupplier(Supplier startedSupplier, Process q } } - private static String guessPath(Class testClass) { + private String guessPath(Class testClass) { //ok, lets make a guess //this is a horrible hack, but it is intended to make this work in IDE's @@ -203,41 +205,47 @@ private static String guessPath(Class testClass) { "Unable to automatically find native image, please set the native.image.path to the native executable you wish to test"); } - private static String guessPath(final URL url) { + private String guessPath(final URL url) { if (url == null) { return null; } + String file = null; if (url.getProtocol().equals("file") && url.getPath().endsWith("test-classes/")) { //we have the maven test classes dir File testClasses = new File(url.getPath()); - for (File file : testClasses.getParentFile().listFiles()) { - if (isNativeExecutable(file)) { - logGuessedPath(file.getAbsolutePath()); - return file.getAbsolutePath(); - } - } + file = guessPathFromDir(testClasses.getParentFile()); } else if (url.getProtocol().equals("file") && url.getPath().endsWith("test/")) { //we have the gradle test classes dir, build/classes/java/test File testClasses = new File(url.getPath()); - for (File file : testClasses.getParentFile().getParentFile().getParentFile().listFiles()) { - if (isNativeExecutable(file)) { - logGuessedPath(file.getAbsolutePath()); - return file.getAbsolutePath(); - } - } + file = guessPathFromDir(testClasses.getParentFile().getParentFile().getParentFile()); } else if (url.getProtocol().equals("file") && url.getPath().contains("/target/surefire/")) { //this will make mvn failsafe:integration-test work String path = url.getPath(); int index = path.lastIndexOf("/target/"); File targetDir = new File(path.substring(0, index) + "/target/"); - for (File file : targetDir.listFiles()) { - if (isNativeExecutable(file)) { - logGuessedPath(file.getAbsolutePath()); - return file.getAbsolutePath(); - } - } + file = guessPathFromDir(targetDir); } + return file; + } + + private String guessPathFromDir(File dir) { + if (dir == null) { + return null; + } + if (configuredOutputDirectory != null) { + dir = dir.toPath().resolve(configuredOutputDirectory).toFile(); + } + File[] files = dir.listFiles(); + if (files == null) { + return null; + } + for (File file : files) { + if (isNativeExecutable(file)) { + logGuessedPath(file.getAbsolutePath()); + return file.getAbsolutePath(); + } + } return null; } diff --git a/test-framework/common/src/main/java/io/quarkus/test/common/NativeImageLauncher.java b/test-framework/common/src/main/java/io/quarkus/test/common/NativeImageLauncher.java index 5121ceebd9545..3ade1d9704460 100644 --- a/test-framework/common/src/main/java/io/quarkus/test/common/NativeImageLauncher.java +++ b/test-framework/common/src/main/java/io/quarkus/test/common/NativeImageLauncher.java @@ -6,6 +6,8 @@ interface NativeImageInitContext extends InitContext { String nativeImagePath(); + String getConfiguredOutputDirectory(); + Class testClass(); } } diff --git a/test-framework/junit5/src/main/java/io/quarkus/test/junit/NativeTestExtension.java b/test-framework/junit5/src/main/java/io/quarkus/test/junit/NativeTestExtension.java index c3a10dae9c048..218d5eed831f5 100644 --- a/test-framework/junit5/src/main/java/io/quarkus/test/junit/NativeTestExtension.java +++ b/test-framework/junit5/src/main/java/io/quarkus/test/junit/NativeTestExtension.java @@ -217,6 +217,7 @@ public void close() { } }, System.getProperty("native.image.path"), + config.getOptionalValue("quarkus.package.output-directory", String.class).orElse(null), requiredTestClass)); return launcher; } diff --git a/test-framework/junit5/src/main/java/io/quarkus/test/junit/launcher/NativeImageLauncherProvider.java b/test-framework/junit5/src/main/java/io/quarkus/test/junit/launcher/NativeImageLauncherProvider.java index 5a829c7f3c07a..ec9d9f56039e8 100644 --- a/test-framework/junit5/src/main/java/io/quarkus/test/junit/launcher/NativeImageLauncherProvider.java +++ b/test-framework/junit5/src/main/java/io/quarkus/test/junit/launcher/NativeImageLauncherProvider.java @@ -45,6 +45,7 @@ public NativeImageLauncher create(CreateContext context) { ConfigUtil.argLineValue(config), context.devServicesLaunchResult(), System.getProperty("native.image.path"), + config.getOptionalValue("quarkus.package.output-directory", String.class).orElse(null), context.testClass())); return launcher; } else { @@ -57,12 +58,14 @@ public static class DefaultNativeImageInitContext extends DefaultInitContextBase private final String nativeImagePath; private final Class testClass; + private final String configuredOutputDirectory; public DefaultNativeImageInitContext(int httpPort, int httpsPort, Duration waitTime, String testProfile, List argLine, ArtifactLauncher.InitContext.DevServicesLaunchResult devServicesLaunchResult, - String nativeImagePath, Class testClass) { + String nativeImagePath, String configuredOutputDirectory, Class testClass) { super(httpPort, httpsPort, waitTime, testProfile, argLine, devServicesLaunchResult); this.nativeImagePath = nativeImagePath; + this.configuredOutputDirectory = configuredOutputDirectory; this.testClass = testClass; } @@ -71,6 +74,11 @@ public String nativeImagePath() { return nativeImagePath; } + @Override + public String getConfiguredOutputDirectory() { + return configuredOutputDirectory; + } + @Override public Class testClass() { return testClass;