Fix NPE in CB Config Resolution

This commit is contained in:
Atri Sharma 2020-08-27 20:52:12 +05:30
parent 6a7da3cd50
commit b381595f55
1 changed files with 14 additions and 8 deletions

View File

@ -137,7 +137,8 @@ public class CircuitBreakerManager implements PluginInfoInitialized {
*/ */
@SuppressWarnings({"rawtypes"}) @SuppressWarnings({"rawtypes"})
public static CircuitBreakerManager build(PluginInfo pluginInfo) { public static CircuitBreakerManager build(PluginInfo pluginInfo) {
CircuitBreakerManager circuitBreakerManager = new CircuitBreakerManager(Boolean.parseBoolean(pluginInfo.attributes.get("enabled"))); boolean enabled = pluginInfo == null ? false : Boolean.parseBoolean(pluginInfo.attributes.getOrDefault("enabled", "false"));
CircuitBreakerManager circuitBreakerManager = new CircuitBreakerManager(enabled);
circuitBreakerManager.init(pluginInfo); circuitBreakerManager.init(pluginInfo);
@ -147,19 +148,24 @@ public class CircuitBreakerManager implements PluginInfoInitialized {
@VisibleForTesting @VisibleForTesting
@SuppressWarnings({"rawtypes"}) @SuppressWarnings({"rawtypes"})
public static CircuitBreaker.CircuitBreakerConfig buildCBConfig(PluginInfo pluginInfo) { public static CircuitBreaker.CircuitBreakerConfig buildCBConfig(PluginInfo pluginInfo) {
boolean enabled = Boolean.parseBoolean(pluginInfo.attributes.get("enabled")); boolean enabled = false;
boolean cpuCBEnabled = false; boolean cpuCBEnabled = false;
boolean memCBEnabled = false; boolean memCBEnabled = false;
int memCBThreshold = 100; int memCBThreshold = 100;
int cpuCBThreshold = 100; int cpuCBThreshold = 100;
if (pluginInfo != null) {
NamedList args = pluginInfo.initArgs; NamedList args = pluginInfo.initArgs;
enabled = Boolean.parseBoolean(pluginInfo.attributes.getOrDefault("enabled", "false"));
if (args != null) { if (args != null) {
cpuCBEnabled = args.getBooleanArg("cpuEnabled"); cpuCBEnabled = Boolean.parseBoolean(args._getStr("cpuEnabled", "false"));
memCBEnabled = args.getBooleanArg("memEnabled"); memCBEnabled = Boolean.parseBoolean(args._getStr("memEnabled", "false"));
memCBThreshold = Integer.parseInt((String) args.get("memThreshold")); memCBThreshold = Integer.parseInt(args._getStr("memThreshold", "100"));
cpuCBThreshold = Integer.parseInt((String) args.get("cpuThreshold")); cpuCBThreshold = Integer.parseInt(args._getStr("cpuThreshold", "100"));
}
} }
return new CircuitBreaker.CircuitBreakerConfig(enabled, memCBEnabled, memCBThreshold, cpuCBEnabled, cpuCBThreshold); return new CircuitBreaker.CircuitBreakerConfig(enabled, memCBEnabled, memCBThreshold, cpuCBEnabled, cpuCBThreshold);