refactor(接口定义): node的jar包去主服务下载
--story=1011108 --user=王孝刚 资源池加载插件直接从MinIO获取 https://www.tapd.cn/55049933/s/1331634
This commit is contained in:
parent
4fa0d70196
commit
f895d3d719
|
@ -18,8 +18,12 @@ import io.metersphere.dto.AttachmentBodyFile;
|
||||||
import io.metersphere.dto.JmeterRunRequestDTO;
|
import io.metersphere.dto.JmeterRunRequestDTO;
|
||||||
import io.metersphere.dto.ProjectJarConfig;
|
import io.metersphere.dto.ProjectJarConfig;
|
||||||
import io.metersphere.environment.service.BaseEnvGroupProjectService;
|
import io.metersphere.environment.service.BaseEnvGroupProjectService;
|
||||||
|
import io.metersphere.metadata.service.FileCenter;
|
||||||
import io.metersphere.metadata.service.FileMetadataService;
|
import io.metersphere.metadata.service.FileMetadataService;
|
||||||
|
import io.metersphere.metadata.vo.FileRequest;
|
||||||
|
import io.metersphere.metadata.vo.RemoteFileAttachInfo;
|
||||||
import io.metersphere.request.BodyFile;
|
import io.metersphere.request.BodyFile;
|
||||||
|
import io.metersphere.utils.JsonUtils;
|
||||||
import io.metersphere.utils.LoggerUtil;
|
import io.metersphere.utils.LoggerUtil;
|
||||||
import io.metersphere.vo.BooleanPool;
|
import io.metersphere.vo.BooleanPool;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
|
@ -151,9 +155,8 @@ public class ApiJMeterFileService {
|
||||||
FileMetadataService fileMetadataService = CommonBeanFactory.getBean(FileMetadataService.class);
|
FileMetadataService fileMetadataService = CommonBeanFactory.getBean(FileMetadataService.class);
|
||||||
map.forEach((key, value) -> {
|
map.forEach((key, value) -> {
|
||||||
//历史数据
|
//历史数据
|
||||||
value.forEach(s -> {
|
value.stream().filter(s -> s.isHasFile()).forEach(s -> {
|
||||||
//获取文件内容;
|
//获取文件内容 兼容历史数据
|
||||||
// 兼容历史数据
|
|
||||||
byte[] bytes = fileMetadataService.getContent(s.getId());
|
byte[] bytes = fileMetadataService.getContent(s.getId());
|
||||||
files.put(StringUtils.join(
|
files.put(StringUtils.join(
|
||||||
key,
|
key,
|
||||||
|
@ -162,6 +165,31 @@ public class ApiJMeterFileService {
|
||||||
File.separator,
|
File.separator,
|
||||||
String.valueOf(s.getUpdateTime()), ".jar"), bytes);
|
String.valueOf(s.getUpdateTime()), ".jar"), bytes);
|
||||||
});
|
});
|
||||||
|
// 获取文件服务器的数据
|
||||||
|
value.stream().filter(s -> !s.isHasFile()).forEach(s -> {
|
||||||
|
//获取文件内容;
|
||||||
|
try {
|
||||||
|
FileRequest fileRequest = new FileRequest();
|
||||||
|
if (StringUtils.isNotBlank(s.getAttachInfo())) {
|
||||||
|
fileRequest.setFileAttachInfo(JsonUtils.parseObject(s.getAttachInfo(), RemoteFileAttachInfo.class));
|
||||||
|
}
|
||||||
|
fileRequest.setProjectId(key);
|
||||||
|
fileRequest.setFileName(s.getName());
|
||||||
|
fileRequest.setStorage(s.getStorage());
|
||||||
|
LoggerUtil.info("开始下载服务器中的Jar包,文件名:" + s.getName());
|
||||||
|
byte[] gitFiles = FileCenter.getRepository(s.getStorage()).getFile(fileRequest);
|
||||||
|
files.put(StringUtils.join(
|
||||||
|
key,
|
||||||
|
File.separator,
|
||||||
|
s.getId(),
|
||||||
|
File.separator,
|
||||||
|
String.valueOf(s.getUpdateTime()), ".jar"), gitFiles);
|
||||||
|
} catch (Exception e) {
|
||||||
|
LoggerUtil.error(e.getMessage(), e);
|
||||||
|
LoggerUtil.error("Jar包下载失败,不存在Git仓库中");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
return listBytesToZip(files);
|
return listBytesToZip(files);
|
||||||
|
|
|
@ -51,10 +51,10 @@ public class JarConfigUtils {
|
||||||
//资源id目录存在,需要判断文件的时间戳与数据记录的时间戳是不是同一个 不是同一个的需要删除jar然后重新下载
|
//资源id目录存在,需要判断文件的时间戳与数据记录的时间戳是不是同一个 不是同一个的需要删除jar然后重新下载
|
||||||
List<String> jarFiles = getFileNames(StringUtils.join(localPath, File.separator, item, File.separator, projectJarConfig.getId()));
|
List<String> jarFiles = getFileNames(StringUtils.join(localPath, File.separator, item, File.separator, projectJarConfig.getId()));
|
||||||
if (CollectionUtils.isNotEmpty(jarFiles)) {
|
if (CollectionUtils.isNotEmpty(jarFiles)) {
|
||||||
jarFiles.forEach(jarfile -> {
|
jarFiles.forEach(jarFile -> {
|
||||||
long updateTime = projectJarConfig.getUpdateTime();
|
long updateTime = projectJarConfig.getUpdateTime();
|
||||||
if (!StringUtils.equals(StringUtils.substringBefore(jarfile, ".jar"), String.valueOf(updateTime))) {
|
if (!StringUtils.equals(StringUtils.substringBefore(jarFile, ".jar"), String.valueOf(updateTime))) {
|
||||||
deleteFile(StringUtils.join(localPath, File.separator, item, File.separator, refId, File.separator, jarfile));
|
deleteFile(StringUtils.join(localPath, File.separator, item, File.separator, refId, File.separator, jarFile));
|
||||||
jarConfigs.add(projectJarConfig);
|
jarConfigs.add(projectJarConfig);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -90,7 +90,7 @@ public class JarConfigUtils {
|
||||||
File fa[] = f.listFiles();
|
File fa[] = f.listFiles();
|
||||||
for (int i = 0; i < fa.length; i++) {
|
for (int i = 0; i < fa.length; i++) {
|
||||||
File fs = fa[i];
|
File fs = fa[i];
|
||||||
if (fs.exists()) {
|
if (fs.exists() && !StringUtils.equals(fs.getName(), ".DS_Store")) {
|
||||||
fileNames.add(fs.getName());
|
fileNames.add(fs.getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue