Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

✨ feat(manifest): Add a manifest file #193

Open
wants to merge 19 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
19 commits
Select commit Hold shift + click to select a range
45958e6
:test_tube: Add test for the manifest
dylanmsql May 9, 2023
7e96c9e
:sparkles: Generate a manifest file
dylanmsql May 9, 2023
6d3534a
:bug: fix(manifest): Fix destination folder of the manifest
dylanmsql May 9, 2023
772a81e
:recycle: refacto(manifest): Change all absolute path to relative path
dylanmsql May 9, 2023
e97d52c
:recycle: refacto(manifest): Move Manifest class in UbiquitousLanguag…
dylanmsql May 9, 2023
2015694
:recycle: refactor(manifest): Change place of the manifest file and p…
dylanmsql May 10, 2023
21fe332
:recycle: refactor(AssertFileContent): Refacto assertion mechanism by…
dylanmsql May 10, 2023
8a9d11a
Revert ":recycle: refactor(AssertFileContent): Refacto assertion mech…
dylanmsql May 10, 2023
f3b846e
:recycle: refacto(manifest): change manifest paths to relative path
dylanmsql May 22, 2023
fb7c419
:recycle: feat(manifest): refacto manifest class
dylanmsql Jun 12, 2023
04afe59
:recycle: feat(manifest): refacto manifest test
dylanmsql Jun 12, 2023
837669f
:recycle: feat(manifest): refacto manifest test
dylanmsql Jun 12, 2023
196f3f4
Merge branch 'main' into feat/manifest
dylanmsql Jun 12, 2023
4a8fe47
feat(manifest): fix manifest test after merging
dylanmsql Jun 12, 2023
a7ec1c8
:recycle: feat(manifest): add static method to build ManifestDto
dylanmsql Jun 14, 2023
97c0613
:recycle: feat(serialization): add classes to handle serialization logic
dylanmsql Jun 14, 2023
7d61256
:recycle: feat(serialization): Add factory to create a json or yml se…
dylanmsql Jun 15, 2023
90a0722
:recycle: feat(serialization): remove useless comment
dylanmsql Jul 11, 2023
91cf1fa
:recycle: feat(serialization): move initDirectory to UbiquitousLangua…
dylanmsql Jul 11, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
♻️ refactor(manifest): Change place of the manifest file and path of …
…the other files, add files properties in the manifest
  • Loading branch information
dylanmsql committed May 10, 2023
commit 2015694d0e0c4ed8606cc6a07cc47e02c7ef5015
19 changes: 19 additions & 0 deletions src/main/java/io/candydoc/plugin/model/ManifestDto.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package io.candydoc.plugin.model;

import java.util.ArrayList;
import java.util.List;
import lombok.Builder;
import lombok.Getter;
import lombok.extern.jackson.Jacksonized;

@Jacksonized
@Builder
@Getter
public final class ManifestDto {

@Builder.Default private List<String> files = new ArrayList<>();

public void add(String filePath) {
files.add(filePath);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,13 @@
import io.candydoc.ddd.extract_domain_vocabulary.UbiquitousLanguageRepository;
import io.candydoc.ddd.extract_domain_vocabulary.UbiquitousLanguageSavingFailed;
import io.candydoc.ddd.model.UbiquitousLanguage;
import io.candydoc.plugin.model.ManifestDto;
import io.candydoc.plugin.model.UbiquitousLanguageDto;
import io.candydoc.plugin.save_ubiquitous_language.file.json.UbiquitousLanguageAsJson;
import io.candydoc.plugin.save_ubiquitous_language.file.yml.UbiquitousLanguageAsYml;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import lombok.Getter;
import lombok.RequiredArgsConstructor;
Expand All @@ -21,7 +20,6 @@
@Accessors(fluent = true)
public abstract class UbiquitousLanguageAsFile implements UbiquitousLanguageRepository {

public static final Path MANIFEST_DESTINATION_FOLDER = Path.of("target/candy-doc");
private final ObjectMapper serializer;
@Getter private final Path destinationFolder;
Yugo-Cartron marked this conversation as resolved.
Show resolved Hide resolved
@Getter private final String extension;
Expand All @@ -33,11 +31,7 @@ public void saveAll(Set<UbiquitousLanguage> ubiquitousLanguages) {
Manifest manifest = new Manifest();

for (UbiquitousLanguage ubiquitousLanguage : ubiquitousLanguages) {
UbiquitousLanguageDto dto = UbiquitousLanguageDto.from(ubiquitousLanguage);
String fileName = dto.getName().toLowerCase().replace(" ", "_");
serializer.writeValue(destinationFolder.resolve(fileName + "." + extension).toFile(), dto);

manifest.addFile(destinationFolder.resolve(fileName + "." + extension).toString());
manifest.addFile(writeToFile(ubiquitousLanguage).toString());
}

manifest.save();
Expand Down Expand Up @@ -65,21 +59,32 @@ public static UbiquitousLanguageAsFile forFormat(String outputFormat, String out
throw new IllegalArgumentException("Supported file formats are 'json', 'yml'.");
}

public class Manifest {
private final List<String> jsonPaths;
private Path writeToFile(UbiquitousLanguage ubiquitousLanguage) throws IOException {
UbiquitousLanguageDto dto = UbiquitousLanguageDto.from(ubiquitousLanguage);
String fileName = getFileName(dto.getName());
serializer.writeValue(destinationFolder.resolve(fileName).toFile(), dto);
return Path.of("/", fileName);
}

private String getFileName(String name) {
return name.toLowerCase().replace(" ", "_") + "." + extension;
}

private class Manifest {
private final ManifestDto manifestDto;
dylanmsql marked this conversation as resolved.
Show resolved Hide resolved

public Manifest() {
jsonPaths = new ArrayList<>();
manifestDto = ManifestDto.builder().build();
}

public void addFile(String resolve) {
jsonPaths.add(resolve);
public void addFile(String filePath) {
manifestDto.add(filePath);
}

public void save() throws IOException {
Files.createDirectories(MANIFEST_DESTINATION_FOLDER);
Files.createDirectories(destinationFolder);
serializer.writeValue(
MANIFEST_DESTINATION_FOLDER.resolve("MANIFEST." + extension).toFile(), jsonPaths);
destinationFolder.resolve("MANIFEST." + extension).toFile(), manifestDto);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@
import io.candydoc.ddd.model.UbiquitousLanguage;
import io.candydoc.plugin.fixture.DomainVocabularyFixtures;
import io.candydoc.plugin.save_ubiquitous_language.file.AssertFileContent;
import io.candydoc.plugin.save_ubiquitous_language.file.UbiquitousLanguageAsFile;
import java.io.IOException;
import java.nio.file.Path;
import java.util.Set;
Expand Down Expand Up @@ -48,8 +47,7 @@ public void save_bounded_context_as_json() {
AssertFileContent.assertThatJson(actualFile).isEqualTo(referenceFile);

Path manifestReferenceFile = REFERENCE_FOLDER.resolve("MANIFEST_bounded_context_one.json");
dylanmsql marked this conversation as resolved.
Show resolved Hide resolved
Path manifestActualFile =
UbiquitousLanguageAsFile.MANIFEST_DESTINATION_FOLDER.resolve("MANIFEST.json");
Path manifestActualFile = DESTINATION_FOLDER.resolve("MANIFEST.json");

AssertFileContent.assertThatJson(manifestActualFile).isEqualTo(manifestReferenceFile);
Yugo-Cartron marked this conversation as resolved.
Show resolved Hide resolved
}
Expand All @@ -73,8 +71,7 @@ public void save_shared_kernel_as_json() {
AssertFileContent.assertThatJson(actualFile).isEqualTo(referenceFile);

Path manifestReferenceFile = REFERENCE_FOLDER.resolve("MANIFEST_shared_kernel_one.json");
Path manifestActualFile =
UbiquitousLanguageAsFile.MANIFEST_DESTINATION_FOLDER.resolve("MANIFEST.json");
Path manifestActualFile = DESTINATION_FOLDER.resolve("MANIFEST.json");

AssertFileContent.assertThatJson(manifestActualFile).isEqualTo(manifestReferenceFile);
}
Expand All @@ -98,8 +95,7 @@ public void save_orphan_vocabulary_as_json() {
AssertFileContent.assertThatJson(actualFile).isEqualTo(referenceFile);

Path manifestReferenceFile = REFERENCE_FOLDER.resolve("MANIFEST_orphan_vocabulary.json");
Path manifestActualFile =
UbiquitousLanguageAsFile.MANIFEST_DESTINATION_FOLDER.resolve("MANIFEST.json");
Path manifestActualFile = DESTINATION_FOLDER.resolve("MANIFEST.json");

AssertFileContent.assertThatJson(manifestActualFile).isEqualTo(manifestReferenceFile);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@
import io.candydoc.ddd.model.UbiquitousLanguage;
import io.candydoc.plugin.fixture.DomainVocabularyFixtures;
import io.candydoc.plugin.save_ubiquitous_language.file.AssertFileContent;
import io.candydoc.plugin.save_ubiquitous_language.file.UbiquitousLanguageAsFile;
import java.io.IOException;
import java.nio.file.Path;
import java.util.Set;
Expand Down Expand Up @@ -50,8 +49,7 @@ public void save_bounded_context_as_yml() {
assertThatYml(actualFile).isEqualTo(referenceFile);

Path manifestReferenceFile = REFERENCE_FOLDER.resolve("MANIFEST_bounded_context_one.yml");
Path manifestActualFile =
UbiquitousLanguageAsFile.MANIFEST_DESTINATION_FOLDER.resolve("MANIFEST.yml");
Path manifestActualFile = DESTINATION_FOLDER.resolve("MANIFEST.yml");

AssertFileContent.assertThatYml(manifestActualFile).isEqualTo(manifestReferenceFile);
}
Expand All @@ -75,8 +73,7 @@ public void save_shared_kernel_as_yml() {
assertThatYml(actualFile).isEqualTo(referenceFile);

Path manifestReferenceFile = REFERENCE_FOLDER.resolve("MANIFEST_shared_kernel_one.yml");
Path manifestActualFile =
UbiquitousLanguageAsFile.MANIFEST_DESTINATION_FOLDER.resolve("MANIFEST.yml");
Path manifestActualFile = DESTINATION_FOLDER.resolve("MANIFEST.yml");

AssertFileContent.assertThatYml(manifestActualFile).isEqualTo(manifestReferenceFile);
}
Expand All @@ -100,8 +97,7 @@ public void save_orphan_vocabulary_as_yml() {
assertThatYml(actualFile).isEqualTo(referenceFile);

Path manifestReferenceFile = REFERENCE_FOLDER.resolve("MANIFEST_orphan_vocabulary.yml");
Path manifestActualFile =
UbiquitousLanguageAsFile.MANIFEST_DESTINATION_FOLDER.resolve("MANIFEST.yml");
Path manifestActualFile = DESTINATION_FOLDER.resolve("MANIFEST.yml");

AssertFileContent.assertThatYml(manifestActualFile).isEqualTo(manifestReferenceFile);
}
Expand Down
8 changes: 5 additions & 3 deletions src/test/resources/json/MANIFEST_bounded_context_one.json
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
[
"target/candyDocTmp/bounded_context_one.json"
]
{
"files": [
"/bounded_context_one.json"
]
}
8 changes: 5 additions & 3 deletions src/test/resources/json/MANIFEST_orphan_vocabulary.json
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
[
"target/candyDocTmp/orphan_vocabulary.json"
]
{
"files": [
"/orphan_vocabulary.json"
]
}
8 changes: 5 additions & 3 deletions src/test/resources/json/MANIFEST_shared_kernel_one.json
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
[
"target/candyDocTmp/shared_kernel_one.json"
]
{
"files": [
"/shared_kernel_one.json"
]
}
3 changes: 2 additions & 1 deletion src/test/resources/yml/MANIFEST_bounded_context_one.yml
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
- target/candyDocTmp/bounded_context_one.yml
files:
- /bounded_context_one.yml
3 changes: 2 additions & 1 deletion src/test/resources/yml/MANIFEST_orphan_vocabulary.yml
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
- target/candyDocTmp/orphan_vocabulary.yml
files:
- /orphan_vocabulary.yml
3 changes: 2 additions & 1 deletion src/test/resources/yml/MANIFEST_shared_kernel_one.yml
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
- target/candyDocTmp/shared_kernel_one.yml
files:
- /shared_kernel_one.yml