mirror of https://github.com/hyperledger/besu
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.
109 lines
3.5 KiB
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; |