An enterprise-grade Java-based, Apache 2.0 licensed Ethereum client https://wiki.hyperledger.org/display/besu
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
besu/benchmark/config/store.js

109 lines
3.5 KiB

/*
* 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.
*/
'use strict';
const { WorkloadModuleBase } = require('@hyperledger/caliper-core');
const Web3 = require('web3');
class StoreWorkload extends WorkloadModuleBase {
/**
* Initializes the parameters of the workload.
*/
constructor() {
super();
this.txIndex = -1;
this.private = false;
this.contract = {};
}
/**
* Generates simple workload.
* @returns {{verb: String, args: Object[]}[]} Array of workload argument objects.
*/
_generateWorkload() {
let web3 = new Web3(this.nodeUrl);
let workload = [];
for(let i= 0; i < this.roundArguments.txnPerBatch; i++) {
this.txIndex++;
let value = i;
let args = {
contract: this.roundArguments.contract,
verb: 'update',
args: [value],
readOnly: false,
}
if (this.isPrivate) {
args.privacy = this.privacyOpts;
args.privacy.sender = web3.eth.accounts.create();
args.privacy.sender.nonce = 0;
}
workload.push(args);
}
return workload;
}
/**
* Initialize the workload module with the given parameters.
* @param {number} workerIndex The 0-based index of the worker instantiating the workload module.
* @param {number} totalWorkers The total number of workers participating in the round.
* @param {number} roundIndex The 0-based index of the currently executing round.
* @param {Object} roundArguments The user-provided arguments for the round from the benchmark configuration file.
* @param {BlockchainConnector} sutAdapter The adapter of the underlying SUT.
* @param {Object} sutContext The custom context object provided by the SUT adapter.
* @async
*/
async initializeWorkloadModule(workerIndex, totalWorkers, roundIndex, roundArguments, sutAdapter, sutContext) {
await super.initializeWorkloadModule(workerIndex, totalWorkers, roundIndex, roundArguments, sutAdapter, sutContext);
if (!this.roundArguments.contract) {
throw new Error('store - argument "contract" missing');
}
this.nodeUrl = sutContext.url;
if(this.roundArguments.private) {
this.isPrivate = true;
this.privacyOpts = sutContext.privacy[this.roundArguments.private];
this.privacyOpts['id'] = this.roundArguments.private;
} else {
this.isPrivate = false;
}
if(!this.roundArguments.txnPerBatch) {
this.roundArguments.txnPerBatch = 1;
}
}
/**
* Assemble TXs for opening new accounts.
*/
async submitTransaction() {
let args = this._generateWorkload();
await this.sutAdapter.sendRequests(args);
}
}
function createWorkloadModule() {
return new StoreWorkload();
}
module.exports.createWorkloadModule = createWorkloadModule;