Skip to content

Commit

Permalink
fix parentChildEmptyNullConfig
Browse files Browse the repository at this point in the history
fix
add test

fix
  • Loading branch information
Yingjian Wu committed Oct 30, 2024
1 parent 1aada77 commit 9756bf4
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -58,9 +58,6 @@ public ParentChildRelationshipProperties(@Nullable final Environment env) {
* @param configStr configString
*/
public void setMaxAllowPerTablePerRelType(@Nullable final String configStr) {
if (configStr == null || configStr.isEmpty()) {
return;
}
try {
this.maxAllowPerTablePerRelType = parseNestedConfigString(configStr);
} catch (Exception e) {
Expand All @@ -74,9 +71,6 @@ public void setMaxAllowPerTablePerRelType(@Nullable final String configStr) {
* @param configStr configString
*/
public void setMaxAllowPerDBPerRelType(@Nullable final String configStr) {
if (configStr == null || configStr.isEmpty()) {
return;
}
try {
this.maxAllowPerDBPerRelType = parseNestedConfigString(configStr);
} catch (Exception e) {
Expand All @@ -89,12 +83,10 @@ public void setMaxAllowPerDBPerRelType(@Nullable final String configStr) {
* @param configStr configString
*/
public void setDefaultMaxAllowPerRelType(@Nullable final String configStr) {
if (configStr == null || configStr.isEmpty()) {
return;
}
try {
this.defaultMaxAllowPerRelType =
Arrays.stream(configStr.split(";"))
this.defaultMaxAllowPerRelType = configStr == null || configStr.isEmpty()
? new HashMap<>()
: Arrays.stream(configStr.split(";"))
.map(entry -> entry.split(","))
.collect(Collectors.toMap(
parts -> parts[0],
Expand All @@ -105,7 +97,10 @@ public void setDefaultMaxAllowPerRelType(@Nullable final String configStr) {
}
}

private Map<String, Map<String, Integer>> parseNestedConfigString(final String configStr) {
private Map<String, Map<String, Integer>> parseNestedConfigString(@Nullable final String configStr) {
if (configStr == null || configStr.isEmpty()) {
return new HashMap<>();
}
return Arrays.stream(configStr.split(";"))
.map(entry -> entry.split(","))
.collect(Collectors.groupingBy(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -618,4 +618,38 @@ class ParentChildRelMetadataServiceSpec extends Specification{
1 | "CLONE,5" | "CLONE,test,3;OTHER,other,2"| "CLONE,testhive/test/parent,2" | 2
1 | "CLONE,5;Other,3" | "CLONE,test,3;CLONE,other,2"| "CLONE,testhive/test/parent,2;CLONE,testhive/test/other,2" | 2
}

def "test empty/null input string for config"() {
given:
def parentChildProps = new ParentChildRelationshipProperties(null)

when: "Setting properties to non empty string"
parentChildProps.setDefaultMaxAllowPerRelType("CLONE,5;Other,3")
parentChildProps.setMaxAllowPerDBPerRelType("CLONE,test,3;CLONE,other,2")
parentChildProps.setMaxAllowPerTablePerRelType("CLONE,testhive/test/parent,2;CLONE,testhive/test/other,2")

then:
assert parentChildProps.getDefaultMaxAllowPerRelType().size() == 2
assert parentChildProps.getMaxAllowPerDBPerRelType().size() == 2
assert parentChildProps.getMaxAllowPerTablePerRelType().size() == 2

when: "Setting properties to empty or null based on the isEmpty flag"
if (isEmpty) {
parentChildProps.setDefaultMaxAllowPerRelType("")
parentChildProps.setMaxAllowPerDBPerRelType("")
parentChildProps.setMaxAllowPerTablePerRelType("")
} else {
parentChildProps.setDefaultMaxAllowPerRelType(null)
parentChildProps.setMaxAllowPerDBPerRelType(null)
parentChildProps.setMaxAllowPerTablePerRelType(null)
}

then: "The properties should be empty"
assert parentChildProps.getDefaultMaxAllowPerRelType().isEmpty()
assert parentChildProps.getMaxAllowPerDBPerRelType().isEmpty()
assert parentChildProps.getMaxAllowPerTablePerRelType().isEmpty()

where:
isEmpty << [true, false]
}
}

0 comments on commit 9756bf4

Please sign in to comment.