Revert "Fail fast when finalName is misconfigured"
This reverts commit 263b7c20e4
.
See gh-25590
This commit is contained in:
parent
263b7c20e4
commit
ae2ff7849b
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2021 the original author or authors.
|
* Copyright 2012-2020 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -28,7 +28,6 @@ import org.springframework.util.Assert;
|
||||||
* Utility class that can be used to export a fully packaged archive to an OCI image.
|
* Utility class that can be used to export a fully packaged archive to an OCI image.
|
||||||
*
|
*
|
||||||
* @author Phillip Webb
|
* @author Phillip Webb
|
||||||
* @author Scott Frederick
|
|
||||||
* @since 2.3.0
|
* @since 2.3.0
|
||||||
*/
|
*/
|
||||||
public class ImagePackager extends Packager {
|
public class ImagePackager extends Packager {
|
||||||
|
@ -38,18 +37,11 @@ public class ImagePackager extends Packager {
|
||||||
* @param source the source file to package
|
* @param source the source file to package
|
||||||
*/
|
*/
|
||||||
public ImagePackager(File source) {
|
public ImagePackager(File source) {
|
||||||
Assert.notNull(source, "Source file must not be null");
|
super(source, null);
|
||||||
this.source = source.getAbsoluteFile();
|
|
||||||
if (isAlreadyPackaged()) {
|
|
||||||
this.source = getBackupFile();
|
|
||||||
}
|
|
||||||
Assert.isTrue(this.source.exists() && this.source.isFile(),
|
|
||||||
"Source '" + this.source + "' must refer to an existing file");
|
|
||||||
Assert.state(!isAlreadyPackaged(), () -> "Repackaged archive file " + getSource() + " cannot be exported");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a packaged image.
|
* Create an packaged image.
|
||||||
* @param libraries the contained libraries
|
* @param libraries the contained libraries
|
||||||
* @param exporter the exporter used to write the image
|
* @param exporter the exporter used to write the image
|
||||||
* @throws IOException on IO error
|
* @throws IOException on IO error
|
||||||
|
@ -59,7 +51,10 @@ public class ImagePackager extends Packager {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void packageImage(Libraries libraries, AbstractJarWriter writer) throws IOException {
|
private void packageImage(Libraries libraries, AbstractJarWriter writer) throws IOException {
|
||||||
try (JarFile sourceJar = new JarFile(getSource())) {
|
File source = isAlreadyPackaged() ? getBackupFile() : getSource();
|
||||||
|
Assert.state(source.exists() && source.isFile(), () -> "Unable to read jar file " + source);
|
||||||
|
Assert.state(!isAlreadyPackaged(source), () -> "Repackaged jar file " + source + " cannot be exported");
|
||||||
|
try (JarFile sourceJar = new JarFile(source)) {
|
||||||
write(sourceJar, libraries, writer);
|
write(sourceJar, libraries, writer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,7 +45,6 @@ import org.springframework.util.StringUtils;
|
||||||
* @author Andy Wilkinson
|
* @author Andy Wilkinson
|
||||||
* @author Stephane Nicoll
|
* @author Stephane Nicoll
|
||||||
* @author Madhura Bhave
|
* @author Madhura Bhave
|
||||||
* @author Scott Frederick
|
|
||||||
* @since 2.3.0
|
* @since 2.3.0
|
||||||
*/
|
*/
|
||||||
public abstract class Packager {
|
public abstract class Packager {
|
||||||
|
@ -70,15 +69,15 @@ public abstract class Packager {
|
||||||
|
|
||||||
private static final String SPRING_BOOT_APPLICATION_CLASS_NAME = "org.springframework.boot.autoconfigure.SpringBootApplication";
|
private static final String SPRING_BOOT_APPLICATION_CLASS_NAME = "org.springframework.boot.autoconfigure.SpringBootApplication";
|
||||||
|
|
||||||
private final List<MainClassTimeoutWarningListener> mainClassTimeoutListeners = new ArrayList<>();
|
private List<MainClassTimeoutWarningListener> mainClassTimeoutListeners = new ArrayList<>();
|
||||||
|
|
||||||
private String mainClass;
|
private String mainClass;
|
||||||
|
|
||||||
protected File source;
|
private final File source;
|
||||||
|
|
||||||
private Layout layout;
|
private Layout layout;
|
||||||
|
|
||||||
protected LayoutFactory layoutFactory;
|
private LayoutFactory layoutFactory;
|
||||||
|
|
||||||
private Layers layers;
|
private Layers layers;
|
||||||
|
|
||||||
|
@ -86,6 +85,19 @@ public abstract class Packager {
|
||||||
|
|
||||||
private boolean includeRelevantJarModeJars = true;
|
private boolean includeRelevantJarModeJars = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new {@link Packager} instance.
|
||||||
|
* @param source the source JAR file to package
|
||||||
|
* @param layoutFactory the layout factory to use or {@code null}
|
||||||
|
*/
|
||||||
|
protected Packager(File source, LayoutFactory layoutFactory) {
|
||||||
|
Assert.notNull(source, "Source file must not be null");
|
||||||
|
Assert.isTrue(source.exists() && source.isFile(),
|
||||||
|
"Source must refer to an existing file, got " + source.getAbsolutePath());
|
||||||
|
this.source = source.getAbsoluteFile();
|
||||||
|
this.layoutFactory = layoutFactory;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a listener that will be triggered to display a warning if searching for the
|
* Add a listener that will be triggered to display a warning if searching for the
|
||||||
* main class takes too long.
|
* main class takes too long.
|
||||||
|
@ -141,18 +153,15 @@ public abstract class Packager {
|
||||||
this.includeRelevantJarModeJars = includeRelevantJarModeJars;
|
this.includeRelevantJarModeJars = includeRelevantJarModeJars;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected final boolean isAlreadyPackaged() {
|
protected final boolean isAlreadyPackaged() throws IOException {
|
||||||
return isAlreadyPackaged(this.source);
|
return isAlreadyPackaged(this.source);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected final boolean isAlreadyPackaged(File file) {
|
protected final boolean isAlreadyPackaged(File file) throws IOException {
|
||||||
try (JarFile jarFile = new JarFile(file)) {
|
try (JarFile jarFile = new JarFile(file)) {
|
||||||
Manifest manifest = jarFile.getManifest();
|
Manifest manifest = jarFile.getManifest();
|
||||||
return (manifest != null && manifest.getMainAttributes().getValue(BOOT_VERSION_ATTRIBUTE) != null);
|
return (manifest != null && manifest.getMainAttributes().getValue(BOOT_VERSION_ATTRIBUTE) != null);
|
||||||
}
|
}
|
||||||
catch (IOException ex) {
|
|
||||||
throw new IllegalStateException("Error reading archive file", ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected final void write(JarFile sourceJar, Libraries libraries, AbstractJarWriter writer) throws IOException {
|
protected final void write(JarFile sourceJar, Libraries libraries, AbstractJarWriter writer) throws IOException {
|
||||||
|
@ -276,7 +285,8 @@ public abstract class Packager {
|
||||||
* @return the file to use to backup the original source
|
* @return the file to use to backup the original source
|
||||||
*/
|
*/
|
||||||
public final File getBackupFile() {
|
public final File getBackupFile() {
|
||||||
return new File(this.source.getParentFile(), this.source.getName() + ".original");
|
File source = getSource();
|
||||||
|
return new File(source.getParentFile(), source.getName() + ".original");
|
||||||
}
|
}
|
||||||
|
|
||||||
protected final File getSource() {
|
protected final File getSource() {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2021 the original author or authors.
|
* Copyright 2012-2020 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -32,7 +32,6 @@ import org.springframework.util.Assert;
|
||||||
* @author Andy Wilkinson
|
* @author Andy Wilkinson
|
||||||
* @author Stephane Nicoll
|
* @author Stephane Nicoll
|
||||||
* @author Madhura Bhave
|
* @author Madhura Bhave
|
||||||
* @author Scott Frederick
|
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
public class Repackager extends Packager {
|
public class Repackager extends Packager {
|
||||||
|
@ -43,16 +42,8 @@ public class Repackager extends Packager {
|
||||||
this(source, null);
|
this(source, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a new {@link Repackager} instance.
|
|
||||||
* @param source the source archive file to package
|
|
||||||
* @param layoutFactory the layout factory to use or {@code null}
|
|
||||||
*/
|
|
||||||
public Repackager(File source, LayoutFactory layoutFactory) {
|
public Repackager(File source, LayoutFactory layoutFactory) {
|
||||||
Assert.notNull(source, "Source file must not be null");
|
super(source, layoutFactory);
|
||||||
Assert.isTrue(source.exists() && source.isFile(), "Source '" + source + "' must refer to an existing file");
|
|
||||||
this.source = source.getAbsoluteFile();
|
|
||||||
this.layoutFactory = layoutFactory;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2021 the original author or authors.
|
* Copyright 2012-2020 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -158,13 +158,6 @@ public class BuildImageTests extends AbstractArchiveIntegrationTests {
|
||||||
(project) -> assertThat(buildLog(project)).contains("Executable jar file required for building image"));
|
(project) -> assertThat(buildLog(project)).contains("Executable jar file required for building image"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@TestTemplate
|
|
||||||
void failsWhenFinalNameIsMisconfigured(MavenBuild mavenBuild) {
|
|
||||||
mavenBuild.project("build-image-final-name").goals("package")
|
|
||||||
.executeAndFail((project) -> assertThat(buildLog(project)).contains("final-name.jar.original")
|
|
||||||
.contains("must refer to an existing file"));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void writeLongNameResource(File project) {
|
private void writeLongNameResource(File project) {
|
||||||
StringBuilder name = new StringBuilder();
|
StringBuilder name = new StringBuilder();
|
||||||
new Random().ints('a', 'z' + 1).limit(128).forEach((i) -> name.append((char) i));
|
new Random().ints('a', 'z' + 1).limit(128).forEach((i) -> name.append((char) i));
|
||||||
|
|
|
@ -1,33 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
|
||||||
<groupId>org.springframework.boot.maven.it</groupId>
|
|
||||||
<artifactId>build-image-final-name</artifactId>
|
|
||||||
<version>0.0.1.BUILD-SNAPSHOT</version>
|
|
||||||
<properties>
|
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
|
||||||
<maven.compiler.source>@java.version@</maven.compiler.source>
|
|
||||||
<maven.compiler.target>@java.version@</maven.compiler.target>
|
|
||||||
</properties>
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>@project.groupId@</groupId>
|
|
||||||
<artifactId>@project.artifactId@</artifactId>
|
|
||||||
<version>@project.version@</version>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<goals>
|
|
||||||
<goal>repackage</goal>
|
|
||||||
<goal>build-image</goal>
|
|
||||||
</goals>
|
|
||||||
<configuration>
|
|
||||||
<finalName>final-name</finalName>
|
|
||||||
</configuration>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
</project>
|
|
|
@ -1,28 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright 2012-2020 the original author or authors.
|
|
||||||
*
|
|
||||||
* Licensed 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
|
|
||||||
*
|
|
||||||
* https://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.test;
|
|
||||||
|
|
||||||
public class SampleApplication {
|
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
|
||||||
System.out.println("Launched");
|
|
||||||
synchronized(args) {
|
|
||||||
args.wait(); // Prevent exit"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2021 the original author or authors.
|
* Copyright 2012-2020 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -153,8 +153,7 @@ public class BuildImageMojo extends AbstractPackagerMojo {
|
||||||
}
|
}
|
||||||
|
|
||||||
private BuildRequest getBuildRequest(Libraries libraries) {
|
private BuildRequest getBuildRequest(Libraries libraries) {
|
||||||
ImagePackager imagePackager = new ImagePackager(getJarFile());
|
Function<Owner, TarArchive> content = (owner) -> getApplicationContent(owner, libraries);
|
||||||
Function<Owner, TarArchive> content = (owner) -> getApplicationContent(owner, libraries, imagePackager);
|
|
||||||
Image image = (this.image != null) ? this.image : new Image();
|
Image image = (this.image != null) ? this.image : new Image();
|
||||||
if (image.name == null && this.imageName != null) {
|
if (image.name == null && this.imageName != null) {
|
||||||
image.setName(this.imageName);
|
image.setName(this.imageName);
|
||||||
|
@ -168,8 +167,8 @@ public class BuildImageMojo extends AbstractPackagerMojo {
|
||||||
return customize(image.getBuildRequest(this.project.getArtifact(), content));
|
return customize(image.getBuildRequest(this.project.getArtifact(), content));
|
||||||
}
|
}
|
||||||
|
|
||||||
private TarArchive getApplicationContent(Owner owner, Libraries libraries, ImagePackager imagePackager) {
|
private TarArchive getApplicationContent(Owner owner, Libraries libraries) {
|
||||||
ImagePackager packager = getConfiguredPackager(() -> imagePackager);
|
ImagePackager packager = getConfiguredPackager(() -> new ImagePackager(getJarFile()));
|
||||||
return new PackagedTarArchive(owner, libraries, packager);
|
return new PackagedTarArchive(owner, libraries, packager);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue