Skip to content

Nuxify/caliper-benchmarks

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Hyperledger Caliper Benchmarks

This repository contains sample benchmarks that may be used by Caliper, a blockchain performance benchmark framework. For more information on Caliper, please see the Caliper main repository

Associated performance reports, based on running these benchmarks, are published to the repository github pages.

Repository Branches

This repository has three branches:

  1. main. Contains sample benchmarks
  2. reports. Contains md files that are built and published to the gh-pages branch
  3. gh-pages. Contains the build output from the reports branch

Main Branch Contents

The benchmarks contained within the master branch are split into three directories:

  1. benchmarks. Comprises the test configuration and callback files. The test configuration files describe the benchmark test parameters and also reference the callback files that are executed by Caliper clients during the benchmark. The Benchmark folder contains the following subfolders:
    • api Tests directed towards the API of a single target blockchain.
    • samples Tests directed towards the native samples provided by target blockchain platforms.
    • scenario Generic scenarios that are valid for all (supported) target blockchain platforms
  2. networks. Comprises sample blockchain networks that may be used as target systems under test (SUT) for benchmarking purposes.
  3. src. Comprises the source smart contract files that are deployed to the SUT and interacted with via the test callbacks located within the benchmarks folder. Each smart contract is held within its own folder, under the blockchain technology that the smart contract corresponds to.

Running a Benchmark

To run any of the benchmarks present in this repository, it is required to have installed Hyperledger Caliper, which is the intended consumer of all the contained files.

In general the steps are:

  1. Install the Caliper CLI - for details please see the Caliper main repository
  2. Clone this repository
  3. Run a Caliper CLI command that targets one of the contained benchmarks.

For detailed information about using this repo with hyperledger fabric see Hyperledger Fabric Networks

Extending the Documented Reports

The documented reports are built automatically from the reports branch of this repository and subsequently hosted on the gh-pages branch; pull requests must be target the reports branch in order for any modifications to be built.

Running a Besu QBFT Benchmark

  1. Install Caliper and bind Besu
npm install --only=prod @hyperledger/caliper-cli@latest
npx caliper bind --caliper-bind-sut besu:latest
  1. Deploy the simple.sol contract
// SPDX-License-Identifier: UNLICENSED
pragma solidity 0.8.18;

contract simple {
    mapping(string => int) private accounts;

    function open(string memory acc_id, int amount) public {
        accounts[acc_id] = amount;
    }

    function query(string memory acc_id) public view returns (int amount) {
        amount = accounts[acc_id];
    }

    function transfer(string memory acc_from, string memory acc_to, int amount) public {
        accounts[acc_from] -= amount;
        accounts[acc_to] += amount;
    }
}
  1. Setup and edit src/ethereum/config-qbft.json and benchmarks/scenario/simple/config-qbft.yaml

  2. Run Caliper launch manager

npx caliper launch manager --caliper-benchconfig ~/caliper-benchmarks/benchmarks/scenario/simple/config-qbft.yaml --caliper-networkconfig ~/caliper-benchmarks/src/ethereum/config-qbft.json --caliper-bind-sut besu:latest --caliper-flow-skip-install

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 60.6%
  • Go 25.9%
  • Java 12.4%
  • Other 1.1%