All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.nosqlbench.engine.api.activityconfig.StatementsLoader Maven / Gradle / Ivy

Go to download

The DriverAdapter API for nosqlbench; Provides the interfaces needed to build drivers that can be loaded by nosqlbench core, using a minimal and direct API for op mapping.

There is a newer version: 5.17.0
Show newest version
/*
 * Copyright (c) 2022 nosqlbench
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package io.nosqlbench.engine.api.activityconfig;

import io.nosqlbench.engine.api.activityconfig.rawyaml.RawStmtsDocList;
import io.nosqlbench.engine.api.activityconfig.rawyaml.RawStmtsLoader;
import io.nosqlbench.engine.api.activityconfig.yaml.StmtsDocList;
import io.nosqlbench.engine.api.templating.StrInterpolator;
import io.nosqlbench.api.content.Content;
import io.nosqlbench.api.content.NBIO;
import io.nosqlbench.api.errors.BasicError;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

import java.util.Map;
import java.util.Optional;

public class StatementsLoader {

    public static String[] YAML_EXTENSIONS = new String[]{"yaml","yml"};

    private final static Logger logger = LogManager.getLogger(StatementsLoader.class);

    public static StmtsDocList loadString(String yamlContent, Map params) {

        StrInterpolator transformer = new StrInterpolator(params);
        RawStmtsLoader loader = new RawStmtsLoader(transformer);
        RawStmtsDocList rawDocList = loader.loadString(logger, yamlContent);
        StmtsDocList layered = new StmtsDocList(rawDocList);
        transformer.checkpointAccesses().forEach((k,v) -> {
            layered.addTemplateVariable(k,v);
            if (params.containsKey(k)) {
                params.remove(k);
            }
        });
        return layered;
    }

    public static StmtsDocList loadStmt(
        Logger logger,
        String statement,
        Map params
    ) {
        StrInterpolator transformer = new StrInterpolator(params);
        statement = transformer.apply(statement);
        RawStmtsDocList rawStmtsDocList = RawStmtsDocList.forSingleStatement(statement);
        StmtsDocList layered = new StmtsDocList(rawStmtsDocList);
        transformer.checkpointAccesses().forEach((k,v) -> {
            layered.addTemplateVariable(k,v);
            if (params.containsKey(k)) {
                params.remove(k);
            }
        });
        return layered;
    }

    public static StmtsDocList loadContent(
        Logger logger,
        Content content,
        Map params
    ) {
        return loadString(content.get().toString(),params);
    }

    public static StmtsDocList loadPath(
        Logger logger,
        String path,
        Map params,
        String... searchPaths) {

        RawStmtsDocList list = null;
        Optional> oyaml = NBIO.all().prefix(searchPaths).name(path).extension(YAML_EXTENSIONS).first();
        String content = oyaml.map(Content::asString).orElseThrow(() -> new BasicError("Unable to load " + path));
        return loadString(content,params);
    }


    public static StmtsDocList loadPath(
            Logger logger,
            String path,
            String... searchPaths) {
        return loadPath(logger, path, Map.of(), searchPaths);
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy