@SuppressWarnings("unchecked") private void putBranch( final String key, final Map<String, Object> schemaBranch, final Object val ) throws InvalidValuePathException, InvalidValueTypeException { final Config branch; if(val instanceof Config) { branch = new BasicConfig((Config) val); } else if(val instanceof Map) { branch = new BasicConfig(pathSep, schemaBranch, (Map<String, Object>) val); } else { throw new InvalidValuePathException(key); } node.put(key, branch); }
static Config merge(final String pathSep, final List<Config> configs) { final Map<String, Object> schema = configs.stream() .map(Config::schema) .reduce(TreeUtil::addBranches) .orElseGet(Collections::emptyMap); final Map<String, Object> configTree = configs.stream() .map(Config::deepToMap) .reduce(TreeUtil::addBranches) .orElseGet(Collections::emptyMap); return new BasicConfig(pathSep, schema, configTree); }
protected LoadStepBase( final Config config, final List<Extension> extensions, final List<Config> ctxConfigs, final MetricsManager metricsMgr) { this.config = new BasicConfig(config); this.extensions = extensions; this.ctxConfigs = ctxConfigs; this.metricsMgr = metricsMgr; Loggers.CONFIG.info(ConfigUtil.toString(config)); }
static Config initSlice(final Config config) { final Config configSlice = new BasicConfig(config); // disable the distributed mode on the slave nodes configSlice.val("load-step-node-addrs", Collections.EMPTY_LIST); return configSlice; }
static Config resolveAndReduce( final String id, final ClassLoader clsLoader, final String pathSep, final Map<String, Object> schema ) throws Exception { final List<Config> resolvedConfigs = resolve(id, clsLoader, pathSep, schema); if(resolvedConfigs == null || resolvedConfigs.size() == 0) { return null; } final List<Map<String, Object>> configForest = resolvedConfigs .stream() .map(c -> c.mapVal(Config.ROOT_PATH)) .collect(Collectors.toList()); final Map<String, Object> configTree = reduceForest(configForest); return new BasicConfig(pathSep, schema, configTree); } }
@Override public final <T extends LoadStepClient> T append(final Map<String, Object> context) throws InterruptRunException { final List<Config> ctxConfigsCopy; if (ctxConfigs == null) { ctxConfigsCopy = new ArrayList<>(1); } else { ctxConfigsCopy = ctxConfigs.stream().map(BasicConfig::new).collect(Collectors.toList()); } final Map<String, String> argValPairs = new HashMap<>(); flatten(context, argValPairs, config.pathSep(), null); final List<Map<String, Object>> aliasingConfig = config.listVal("aliasing"); final Config ctxConfig = new BasicConfig(config); try { final Map<String, String> aliasedArgs = AliasingUtil.apply(argValPairs, aliasingConfig); aliasedArgs.forEach(ctxConfig::val); // merge } catch (final Exception e) { LogUtil.exception(Level.FATAL, e, "Scenario syntax error"); throw new InterruptRunException(e); } ctxConfigsCopy.add(ctxConfig); return copyInstance(config, ctxConfigsCopy); }
childConfig = (Config) child; } else { childConfig = new BasicConfig(pathSep, (Map<String, Object>) schemaVal); node.put(key, childConfig);
specificConfig = new BasicConfig(config); specificConfig.val("output-metrics-average-persist", false); specificConfig.val("output-metrics-summary-perfDbResultsFile", false); specificConfig = new BasicConfig(config); final String ioTypeName = opType.name().toLowerCase(); specificConfig.val("load-op-type", ioTypeName); specificConfig = new BasicConfig(config); specificConfig.val("load-op-type", OpType.READ.name().toLowerCase()); specificConfig.val("item-data-verify", true); "ReadVerifyLoad", baseLoadStepFactory.createClient(specificConfig, extensions, metricsMgr)); specificConfig = new BasicConfig(config); specificConfig.val("load-op-type", OpType.READ.name().toLowerCase()); specificConfig.val("item-data-ranges-random", 1); baseLoadStepFactory.createClient(specificConfig, extensions, metricsMgr)); specificConfig = new BasicConfig(config); specificConfig.val("load-op-type", OpType.READ.name().toLowerCase()); specificConfig.val("item-data-verify", true); specificConfig = new BasicConfig(config); specificConfig.val("load-op-type", OpType.UPDATE.name().toLowerCase()); specificConfig.val("item-data-ranges-random", 1);
@Override public final <T extends LoadStepClient> T config(final Map<String, Object> configMap) throws InterruptRunException { if (ctxConfigs != null) { throw new IllegalStateException("config(...) should be invoked before any append(...) call"); } final Config configCopy = new BasicConfig(config); final Map<String, String> argValPairs = new HashMap<>(); flatten(configMap, argValPairs, config.pathSep(), null); final List<Map<String, Object>> aliasingConfig = config.listVal("aliasing"); try { final Map<String, String> aliasedArgs = AliasingUtil.apply(argValPairs, aliasingConfig); if (config.boolVal("load-step-idAutoGenerated")) { if (aliasedArgs.get("load-step-id") != null) { configCopy.val("load-step-idAutoGenerated", false); } } aliasedArgs.forEach(configCopy::val); // merge } catch (final Exception e) { LogUtil.exception(Level.FATAL, e, "Scenario syntax error"); throw new InterruptRunException(e); } return copyInstance(configCopy, null); }