mirror of
https://gitee.com/dcren/initializr.git
synced 2025-07-15 23:13:30 +08:00
Refactor support for testing executable files
Previously, hasExecutableFile only checked if the file exists and not if it was executable. This commit ensures that the file exists and is executable using ExecTask as Unzip and Untar do not preserve file permissions. See gh-937
This commit is contained in:
parent
f16971fcd3
commit
292e47e98b
@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package io.spring.initializr.generator.spring.test;
|
package io.spring.initializr.generator.spring.test;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
@ -192,8 +193,14 @@ public class ProjectAssert {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public ProjectAssert hasExecutableFile(String... localPaths) {
|
public ProjectAssert hasExecutableFile(String... localPaths) {
|
||||||
|
if (runningOnWindows()) {
|
||||||
|
for (String localPath : localPaths) {
|
||||||
|
assertFile(localPath, true);
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
for (String localPath : localPaths) {
|
for (String localPath : localPaths) {
|
||||||
assertFile(localPath, true);
|
assertExecutable(localPath, true);
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
@ -210,6 +217,19 @@ public class ProjectAssert {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ProjectAssert assertExecutable(String localPath, boolean exist) {
|
||||||
|
Path candidate = this.projectStructure.resolve(localPath);
|
||||||
|
assertThat(Files.exists(candidate)).describedAs("Invalid presence (%s) exist for %s", exist, localPath)
|
||||||
|
.isEqualTo(exist);
|
||||||
|
assertThat(Files.isExecutable(candidate)).describedAs("File (%s) is not an executable", localPath)
|
||||||
|
.isEqualTo(exist);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean runningOnWindows() {
|
||||||
|
return File.separatorChar == '\\';
|
||||||
|
}
|
||||||
|
|
||||||
private Properties properties(String localPath) {
|
private Properties properties(String localPath) {
|
||||||
Path file = this.projectStructure.resolve(localPath);
|
Path file = this.projectStructure.resolve(localPath);
|
||||||
try {
|
try {
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package io.spring.initializr.web;
|
package io.spring.initializr.web;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
@ -32,6 +33,7 @@ import io.spring.initializr.web.AbstractInitializrIntegrationTests.Config;
|
|||||||
import io.spring.initializr.web.mapper.InitializrMetadataVersion;
|
import io.spring.initializr.web.mapper.InitializrMetadataVersion;
|
||||||
import io.spring.initializr.web.support.InitializrMetadataUpdateStrategy;
|
import io.spring.initializr.web.support.InitializrMetadataUpdateStrategy;
|
||||||
import org.apache.tools.ant.Project;
|
import org.apache.tools.ant.Project;
|
||||||
|
import org.apache.tools.ant.taskdefs.ExecTask;
|
||||||
import org.apache.tools.ant.taskdefs.Expand;
|
import org.apache.tools.ant.taskdefs.Expand;
|
||||||
import org.apache.tools.ant.taskdefs.Untar;
|
import org.apache.tools.ant.taskdefs.Untar;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
@ -211,22 +213,58 @@ public abstract class AbstractInitializrIntegrationTests {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void untar(Path archiveFile, Path project) {
|
private void untar(Path archiveFile, Path project) {
|
||||||
Untar expand = new Untar();
|
if (!runningOnWindows()) {
|
||||||
expand.setProject(new Project());
|
createProjectDir(project);
|
||||||
expand.setDest(project.toFile());
|
ExecTask execTask = new ExecTask();
|
||||||
expand.setSrc(archiveFile.toFile());
|
execTask.setProject(new Project());
|
||||||
Untar.UntarCompressionMethod method = new Untar.UntarCompressionMethod();
|
execTask.setExecutable("tar");
|
||||||
method.setValue("gzip");
|
execTask.createArg().setValue("-C");
|
||||||
expand.setCompression(method);
|
execTask.createArg().setValue(project.toFile().getAbsolutePath());
|
||||||
expand.execute();
|
execTask.createArg().setValue("-xf");
|
||||||
|
execTask.createArg().setValue(archiveFile.toFile().getAbsolutePath());
|
||||||
|
execTask.execute();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Untar expand = new Untar();
|
||||||
|
expand.setProject(new Project());
|
||||||
|
expand.setDest(project.toFile());
|
||||||
|
expand.setSrc(archiveFile.toFile());
|
||||||
|
Untar.UntarCompressionMethod method = new Untar.UntarCompressionMethod();
|
||||||
|
method.setValue("gzip");
|
||||||
|
expand.setCompression(method);
|
||||||
|
expand.execute();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createProjectDir(Path project) {
|
||||||
|
ExecTask execTask = new ExecTask();
|
||||||
|
execTask.setProject(new Project());
|
||||||
|
execTask.setExecutable("mkdir");
|
||||||
|
execTask.createArg().setValue(project.toFile().getAbsolutePath());
|
||||||
|
execTask.execute();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void unzip(Path archiveFile, Path project) {
|
private void unzip(Path archiveFile, Path project) {
|
||||||
Expand expand = new Expand();
|
if (!runningOnWindows()) {
|
||||||
expand.setProject(new Project());
|
ExecTask execTask = new ExecTask();
|
||||||
expand.setDest(project.toFile());
|
execTask.setProject(new Project());
|
||||||
expand.setSrc(archiveFile.toFile());
|
execTask.setExecutable("unzip");
|
||||||
expand.execute();
|
execTask.createArg().setValue(archiveFile.toFile().getAbsolutePath());
|
||||||
|
execTask.createArg().setValue("-d");
|
||||||
|
execTask.createArg().setValue(project.toFile().getAbsolutePath());
|
||||||
|
execTask.execute();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Expand expand = new Expand();
|
||||||
|
expand.setProject(new Project());
|
||||||
|
expand.setDest(project.toFile());
|
||||||
|
expand.setSrc(archiveFile.toFile());
|
||||||
|
expand.execute();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean runningOnWindows() {
|
||||||
|
return File.separatorChar == '\\';
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Path writeArchive(byte[] body) throws IOException {
|
protected Path writeArchive(byte[] body) throws IOException {
|
||||||
|
Loading…
Reference in New Issue
Block a user