From cb6ded5ce6a600a9374f56ce4b12af7313713259 Mon Sep 17 00:00:00 2001 From: baixinsui Date: Tue, 30 Jul 2024 11:14:32 +0800 Subject: [PATCH] Clean up files have been read in workspace --- .../service/OpenTofuDirectoryService.java | 28 ++++++++++++------- 1 file changed, 18 insertions(+), 10 deletions(-) diff --git a/src/main/java/org/eclipse/xpanse/tofu/maker/opentofu/service/OpenTofuDirectoryService.java b/src/main/java/org/eclipse/xpanse/tofu/maker/opentofu/service/OpenTofuDirectoryService.java index 7804b14..e021579 100644 --- a/src/main/java/org/eclipse/xpanse/tofu/maker/opentofu/service/OpenTofuDirectoryService.java +++ b/src/main/java/org/eclipse/xpanse/tofu/maker/opentofu/service/OpenTofuDirectoryService.java @@ -321,22 +321,30 @@ private Map getImportantFilesContent(String workspace) { if (workPath.isDirectory() && workPath.exists()) { File[] files = workPath.listFiles(); if (Objects.nonNull(files)) { - List importantFiles = Arrays.stream(files) - .filter(file -> file.isFile() && !isExcludedFile(file.getName())).toList(); - for (File importantFile : importantFiles) { - try { - String content = Files.readString(importantFile.toPath()); - fileContentMap.put(importantFile.getName(), content); - } catch (IOException e) { - log.error("Read content of file with name:{} error.", - importantFile.getName(), e); + Arrays.stream(files).forEach(file -> { + if (file.isFile() && !isExcludedFile(file.getName())) { + String content = readFileContentAndDelete(file); + fileContentMap.put(file.getName(), content); } - } + }); } } return fileContentMap; } + private String readFileContentAndDelete(File file) { + String fileContent = ""; + try { + fileContent = Files.readString(file.toPath()); + boolean deleted = Files.deleteIfExists(file.toPath()); + log.info("Read file content with name:{} successfully. Delete result:{}", + file.getName(), deleted); + } catch (IOException e) { + log.error("Read file content with name:{} error.", file.getName(), e); + } + return fileContent; + } + private void deleteWorkspace(String workspace) { Path path = Paths.get(workspace); try (Stream pathStream = Files.walk(path)) {