Skip to content

Commit

Permalink
[#3216] fix(core): Fix the issue of method checkValue in the Config…
Browse files Browse the repository at this point in the history
…Option (#3217)

### What changes were proposed in this pull request?
Fix the issue of method `checkValue` in the ConfigOption. If we use
`checkValue` in the wrong position, it won't work.

### Why are the changes needed?

Fix: #3216

### Does this PR introduce _any_ user-facing change?
No.

### How was this patch tested?
UT.

Co-authored-by: Heng Qin <[email protected]>
  • Loading branch information
qqqttt123 and Heng Qin authored Apr 30, 2024
1 parent cccb3eb commit 5a1b7c2
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -171,8 +171,25 @@ public String seqToStr(List<T> seq, Function<T, String> converter) {
public ConfigEntry<List<T>> toSequence() {
ConfigEntry<List<T>> conf =
new ConfigEntry<>(key, version, doc, alternatives, isPublic, isDeprecated);
conf.setValueConverter((String str) -> strToSeq(str, valueConverter));
conf.setStringConverter((List<T> val) -> seqToStr(val, stringConverter));

Function<String, T> elementConverter;
if (validator == null) {
elementConverter = valueConverter;
} else {
elementConverter =
value -> {
if (value == null) {
validator.accept(null);
}
T convertedValue = valueConverter.apply(value);
validator.accept(convertedValue);
return convertedValue;
};
}

conf.setValueConverter((String str) -> strToSeq(str, elementConverter));
conf.setStringConverter((List<T> val) -> val == null ? null : seqToStr(val, stringConverter));

return conf;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,6 @@ public void testConfWithDefaultValue() {
.doc("test")
.internal()
.stringConf()
.checkValue(value -> value == null, "error")
.toSequence()
.checkValue(valueList -> valueList.stream().allMatch("test-string"::equals), "error")
.createWithDefault(Lists.newArrayList("test-string", "test-string", "test-string"));
Expand Down Expand Up @@ -123,13 +122,27 @@ public void testCheckValue() {
testConfDefault.writeTo(configMap, Lists.newArrayList(-10, 2));
Assertions.assertThrows(
IllegalArgumentException.class, () -> testConfDefault.readFrom(configMap));

ConfigEntry<List<String>> testConfNoDefault =
new ConfigBuilder("gravitino.test.no.default")
.stringConf()
.toSequence()
.checkValue(Objects::nonNull, "error")
.create();
Assertions.assertThrows(
NullPointerException.class, () -> testConfNoDefault.readFrom(configMap));
IllegalArgumentException.class, () -> testConfNoDefault.readFrom(configMap));

// To test checkValue before calling `toSequence`
ConfigEntry<List<String>> testConfWithoutDefault =
new ConfigBuilder("gravitino.test.empty.check")
.doc("test")
.internal()
.stringConf()
.checkValue(value -> !value.isEmpty(), "error")
.toSequence()
.create();
testConfWithoutDefault.writeTo(configMap, Lists.newArrayList(""));
Assertions.assertThrows(
IllegalArgumentException.class, () -> testConfWithoutDefault.readFrom(configMap));
}
}
5 changes: 4 additions & 1 deletion core/src/main/java/com/datastrato/gravitino/Configs.java
Original file line number Diff line number Diff line change
Expand Up @@ -254,8 +254,11 @@ public interface Configs {
.doc("The admins of Gravitino service")
.version(ConfigConstants.VERSION_0_5_0)
.stringConf()
.checkValue(StringUtils::isNotBlank, ConfigConstants.NOT_BLANK_ERROR_MSG)
.toSequence()
.checkValue(
valueList ->
valueList != null && valueList.stream().allMatch(StringUtils::isNotBlank),
ConfigConstants.NOT_BLANK_ERROR_MSG)
.create();

ConfigEntry<Long> ROLE_CACHE_EVICTION_INTERVAL_MS =
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
package com.datastrato.gravitino.authorization;

import com.datastrato.gravitino.Config;
import com.datastrato.gravitino.Configs;
import com.datastrato.gravitino.Entity;
import com.datastrato.gravitino.EntityStore;
import com.datastrato.gravitino.GravitinoEnv;
Expand Down Expand Up @@ -92,6 +93,7 @@ public class TestAccessControlManagerForPermissions {
@BeforeAll
public static void setUp() throws Exception {
config = new Config(false) {};
config.set(Configs.SERVICE_ADMINS, Lists.newArrayList("admin"));

entityStore = new TestMemoryEntityStore.InMemoryEntityStore();
entityStore.initialize(config);
Expand Down

0 comments on commit 5a1b7c2

Please sign in to comment.