io.nosqlbench.adapter.mongodb.dispensers.MongoCommandOpDispenser Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of adapter-mongodb Show documentation
Show all versions of adapter-mongodb Show documentation
An nosqlbench DriverAdapter module for MongoDB
/*
* 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.adapter.mongodb.dispensers;
import com.mongodb.ReadPreference;
import io.nosqlbench.adapter.mongodb.core.MongoSpace;
import io.nosqlbench.adapter.mongodb.ops.MongoDirectCommandOp;
import io.nosqlbench.engine.api.activityimpl.BaseOpDispenser;
import io.nosqlbench.engine.api.activityimpl.uniform.DriverAdapter;
import io.nosqlbench.engine.api.activityimpl.uniform.flowtypes.Op;
import io.nosqlbench.engine.api.templating.ParsedOp;
import org.bson.Document;
import org.bson.conversions.Bson;
import java.util.Map;
import java.util.function.LongFunction;
public class MongoCommandOpDispenser extends BaseOpDispenser {
private final LongFunction opFunc;
private final LongFunction mongoOpF;
public MongoCommandOpDispenser(DriverAdapter adapter, LongFunction ctxFunc, ParsedOp op) {
super(adapter,op);
opFunc = createOpFunc(ctxFunc, op);
this.mongoOpF = createOpFunc(ctxFunc,op);
}
private LongFunction createOpFunc(LongFunction ctxFunc, ParsedOp op) {
LongFunction rpstring = op.getAsOptionalFunction("readPreference")
.orElseGet(() -> op.getAsOptionalFunction("read-preference")
.orElse(l -> "primary"));
LongFunction readPreferenceF = l -> ReadPreference.valueOf(rpstring.apply(l));
LongFunction> payload = op.getAsRequiredFunction("stmt", Object.class);
Object exampleValue = payload.apply(0);
LongFunction bsonFunc;
if (exampleValue instanceof CharSequence cs) {
bsonFunc = l -> Document.parse(payload.apply(l).toString());
} else if ( exampleValue instanceof Map map) {
bsonFunc = l -> new Document((Map)payload.apply(l));
} else {
throw new RuntimeException("You must provide a String or Map for your BSON payload.");
}
LongFunction databaseNamerF = op.getAsRequiredFunction("database", String.class);
return l-> new MongoDirectCommandOp(
ctxFunc.apply(l).getClient(),
databaseNamerF.apply(l),
bsonFunc.apply(l)
);
}
@Override
public Op apply(long cycle) {
return mongoOpF.apply(cycle);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy