diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index c74d3b1c4..aceffffcc 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -7,203 +7,4 @@ This guideline intends to make contribtuions to Caliper easier by: If you have further suggestions about improving the guideline, then you can follow the presented workflow to make your contribution. -## Overview - -The project uses GitHub to manage [issues](https://github.com/hyperledger/caliper/issues) (bug reports and feature requests) and [contributions](https://github.com/hyperledger/caliper/pulls) (in the form of pull requests). - -> For general queries and discussion, please use the [#caliper](https://discord.com/channels/905194001349627914/941417677778473031) channel on the Hyperledger Discord Server (Discord Id required) or the Caliper [mailing list](https://lists.hyperledger.org/g/caliper) (LFID recommended). - -The contribution process boils down to two major steps: opening an issue and submitting a pull request (PR). Opening issues before PRs serves the following purposes: - -* Documenting bugs, related error logs, potential fixes, and/or workarounds that users can find using their favorite search engine. -* Providing a forum for discussions where both contributors and users can weigh in about new features and their potential design. -* Enabling easy traceability of contributions through the "Commit → PR → Issue" reference chain. - -Opening issues can be omitted only in the case of trivial and small fixes (e.g., typo fixes, simple documentation enhancements, etc.). - -## Opening Issues - -Before opening an issue, make sure that: - -1. You read the documentation carefully, so the observed error does not stem from incorrect Caliper configuration or usage. -2. You searched older issues (or other forums) for your question, maybe it is already answered/fixed. -3. It is worth to ask around on Discord, maybe other users already encountered your issue/task, and managed to solve it. - -> When opening an issue about a potential bug or feature request, make sure to properly fill and format the issue contents! - -Choose the **issue template** that suits your intent (bug report or feature request), then fill out the form as best as you can. - -If you find the available issue templates too constraining, then you can still use the "blank" issue template for now (it will be deprecated in the future), and also let us know how we can improve the issue templates. - -The details of the blank template should be filled according to the following guideline: - -1. **Issue title**: Should be a concise sentence summarising the details below, including which component or part of the benchmarking process is affected. For example: `Fabric contract deployment silently fails in generator CI test` -2. **Context**: A detailed description of the context of the issue. Should include information about, for example, how you encountered the issue, what were you trying to achieve, why you consider this a bug, and how it affected your work with Caliper? -3. **Expected Behavior**: What was your expected outcome/behavior of the Caliper run? -4. **Actual Behavior**: What was your actually observered outcome/behaviour instead of the expected one? -5. **Possible Fix**: If you have already identified the source of the issue, you can also propose a possible fix for it. It does not necessarily have to be a working code, some general steps/ideas of a fix is also appreciated. -6. **Steps to Reproduce**: This is perhaps the most important part of an issue. Since Caliper is highly configurable and can interact with multiple SUTs, it is crucial for the maintainers to know the exact steps to reproduce an issue. Always try to provide (or just describe) a *minimal working example (MWE)* that can reproduce the issue. Also, please attach the following information to the issues whenever possible (preferably using collapsable code blocks or GitHub gists): - * The benchmark configuration file content. - * The network configuration file content. - * The workload module implementation. - * The exact error logs (and their surroundings). - * Any other information you deem neccessary. -7. **Existing Issues**: You can also provide links to similar (or the same) issues in other forums (GitHub issues, StackOverflow questions or Discord messages). Such cross-linking can help us ensure that we can broadcast the potential fixes to multiple instances of the question. -8. **Your Environment**: Always include your execution environment information, including the used version/commit of Caliper, the operating system, Node.JS version, or any relevant information about your project that uses Caliper. - -## Submitting Pull Requests - -### Basic workflow - -The following workflow should make your contribution process clean and straighforward (some deviations might be neccessary in exceptional cases): - -> The following list assumes that you use the `git` command line tool. IDEs and graphical git tools should also expose the same commands if you prefer those. - -1. Fork the Caliper repository. This needs to be done only once. -2. Clone the fork repository to your local machine (ideally done once): - * Using the `HTTPS` method: `git clone https://github.com//caliper.git` - * or using the `SSH` method: `git clone git@github.com:/caliper.git` -3. Add the upstream/original Caliper repository as a remote, using the name `upstream` (ideally done once). This will allow you to easily sync your fork with the original repository. - * `git remote add upstream https://github.com/hyperledger/caliper.git` - -> The following steps follow the "feature branch" development practice, and should be performed for each of your contribution: - -4. Checkout your `main` branch that will be the starting point/state of your contribution. - * `git checkout main` - * or `git checkout -b main` if the branch does not exist locally (only during your first checkout) -5. Retrieve the new updates from the `upstream` Caliper repository - * `git fetch upstream` (downloads the updates locally) - * then `git rebase upstream/main` ("adds" the updates to your local `main` brach) - > This step is crucial to ensure that you always contribute based on the latest Caliper version, minimizing the chance of version control conflicts! -6. (Optional) Push your updated `main` branch to your remote repository just to keep things in sync - * `git push` -7. Create a new feature branch (named `my-bug-fix`) from the updated `main` branch: - * `git checkout -b my-bug-fix` - * then `git push --set-upstream origin my-bug-fix` to push the new branch to your remote repository -8. Implement and test your contribution - * The `.build/checks-and-unit-tests.sh` script runs the basic tests for the repository - * The `BENCHMARK= .build/benchmark-integration-test-direct.sh` script can run one of the CI integration tests, depending on the value of ``: - * `BESU` - * `ETHEREUM` - * `FABRIC` - * `GENERATOR` - > Make sure that the tests pass locally before pushing your changes and opening a PR! -9. Commit your changes to your local feature branch, **adding the DCO sign-off**: - * `git commit -s -m "Commit message"` - * or `git commit -s` (without the `-m` parameter) to make git open up the configured text editor where you can write a detailed, multi-line commit message: - * The first line is a concise description of the commit (its purpose, what does it fix, etc). - * After a blank line, you can go into details about the changes of the commit. -10. Push your changes to your remote branch: - * `git push` -11. Open a PR using the GitHub webpage. - -### Updating PRs - -It is possible that the maintainers/reviewers request some changes before your PR can be merged. In that case, just add your changes to your feature branch using a new signed commit (based on the above workflow), then push it to your remote branch. The PR will automatically pick up the new commit. - -> The maintainers can/will squash commits before merging to keep a simpler commit history for the project. - -## Caliper Components - -The project is maintained as a Node.js monorepository. Accordingly, it can seem overwhelming at first to navigate its content. The following sections list and introduce the main components of the repository. - -### Root layout - -You can find the following main component types at the root of the repository: - -* Project-related documentation files - * [CHANGELOG.md](CHANGELOG.md) - * [CODE_OF_CONDUCT.md](CODE_OF_CONDUCT.md) - * [CONTRIBUTING.md](CONTRIBUTING.md) - * [ISSUE_TEMPLATE.md](ISSUE_TEMPLATE.md) - * [LICENSE](LICENSE) - * [MAINTAINERS.md](MAINTAINERS.md) - * [PULL_REQUEST_TEMPLATE.md](PULL_REQUEST_TEMPLATE.md) - * [SECURITY.md](SECURITY.md) -* Linting- and formatting-related files - * [.editorconfig](.editorconfig) - * [.eslintignore](.eslintignore) - * [repolint.json](repolint.json) -* Dependency- and build-related files/directories - * [.build/](.build/) - * [scripts/](scripts/) - * [azure-pipelines.yml](azure-pipelines.yml) - * [package.json](package.json) -* Main code-based components of Caliper in the [packages/](packages/) directory - -### Public/published packages - -The [packages/](packages/) directory contains the following public/published packages: - -* [caliper-cli](packages/caliper-cli/): The command line interface (CLI) of Caliper. -* [caliper-core](packages/caliper-core/): The core and common codebase of Caliper, used by the other packages. -* [caliper-ethereum](packages/caliper-ethereum/): The Ethereum and Hyperledger Besu connector implementation. -* [caliper-fabric](packages/caliper-fabric/): The Hyperledger Fabric connector implementation. -* [generator-caliper](packages/generator-caliper/): The Yeaoman generator for Caliper configuration files. - -### Internal packages - -The [packages/](packages/) directory contains the following internal packages: - -* [caliper-publish](packages/caliper-publish/): Utility CLI for publishing Caliper to NPM and DockerHub. -* [caliper-tests-integration](packages/caliper-tests-integration/): Collection of CI integration tests. - -## Testing Methodologies - -This section outlines the testing methodologies that this project follows, including both unit-level and integration-level testing. - -### Unit Level Testing - -Unit testing focuses on testing individual packages in isolation. The tests are typically located within a test folder at the same level as the corresponding lib folder, mirroring the structure of the lib folder for easy navigation. This setup ensures that each component of the code is verified independently, confirming that it behaves as expected without interference from other parts of the system. - -#### Unit Testing Dependencies and Their Use - -The following are the recommended testing modules for this project. While these tools are commonly used in the current codebase, other appropriate tools may be used as long as they facilitate effective testing. - -* [mockery](https://www.npmjs.com/package/mockery): Mockery is a simple module for mocking Node.js modules during testing. It allows you to replace real modules with mocks or stubs. - -* [mocha](https://mochajs.org/): Mocha is a feature-rich JavaScript test framework that runs on Node.js and in the browser. It facilitates asynchronous testing, making it easy to write simple and flexible tests. - -* [chai](https://www.npmjs.com/package/chai): Chai is a BDD/TDD assertion library for Node.js and the browser. It can be paired with any JavaScript testing framework. We use it to create readable and expressive assertions. - -* [sinon](https://sinonjs.org/releases/v18/): Sinon is a standalone test spies, stubs, and mocks for JavaScript. It works with any test framework and integrates well with Mocha and Chai. We utilize Sinon for checking how functions are called during testing. - -* [sinon-chai](https://www.npmjs.com/package/sinon-chai): This library provides a set of custom assertions for using Sinon with Chai. It allows you to write more readable assertions for Sinon spies, stubs, and mocks. - -* [nyc](https://www.npmjs.com/package/nyc): NYC is a command-line utility for generating code coverage reports. It is often used with Mocha to ensure that tests cover as much code as possible. - -#### Mandatory Tools in the Testing Pipeline - -In addition to the testing frameworks, the following tools are mandatory for all testing pipelines: - -* [eslint](https://eslint.org/): ESLint is a static code analysis tool for identifying problematic patterns in JavaScript code. It is essential for maintaining code quality. -* [license-check-and-add](https://www.npmjs.com/package/license-check-and-add): This tool ensures that all files in the codebase contain the required license headers. It is mandatory for all code submissions. - -#### Points to Note for Adding a Conforming Unit Test - -When writing unit tests, the following structure and practices are mandatory: - -1. **License Header**: All test files must include the project's license header. -2. **'use strict' Directive**: Ensure strict mode is enabled in all test files. -3. **Test Organization**: - * Use `describe` blocks to group related test cases. - * Use `it` statements for individual test cases. - * Nested `describe` blocks are encouraged for organizing complex test scenarios. -4. **Consistent Test Naming**: Test descriptions should flow naturally, making it clear what behavior is being tested (e.g., 'should return the correct value when input is valid'). -5. **Mocking Guidance**: Be cautious with mocks that persist across tests. Always clean up after each test to avoid unexpected behavior. -6. **Test Patterns**: Refer to the Fabric Unit tests for examples of recommended patterns and best practices. -7. **Final Checks**: Always run all unit tests before submitting a PR and ensure no `.only` is left in the code, which would skip other tests. - -### Integration Level Testing - -Integration testing ensures that Caliper integrates correctly with various packages, effectively testing the functionality of the package itself. These tests are organized within the caliper-tests-integration folder, with each test suite dedicated to a specific package or module. - -## Creating New SUT Connectors - -Connectors are relatively heavy components in Caliper. Before you attempt to create a new connector for a new SUT type, consult with the Caliper maintainers (on Discord, or in the form of a feature request). - -> More importantly, make sure that you are overly familiar with the documentation page about [implementing new connectors](https://hyperledger.github.io/caliper/vNext/writing-connectors/). - -## License - -Hyperledger Project source code files are made available under the Apache License, Version 2.0 (Apache-2.0), located in the [LICENSE](LICENSE) file. Hyperledger Project documentation files are made available under the Creative Commons Attribution 4.0 International License (CC-BY-4.0), available at . +Jump to [Contributing documentation](https://hyperledger.github.io/caliper/v0.6.0/getting-started/contributing.md) to get started on your journey. \ No newline at end of file diff --git a/docs/source/concepts/bench-config.md b/docs/source/concepts/bench-config.md index 56a72a2fc..c1c7754bb 100644 --- a/docs/source/concepts/bench-config.md +++ b/docs/source/concepts/bench-config.md @@ -1,7 +1,7 @@ # Benchmark Configuration ## Overview -The `benchmark configuration file` is one of the [required configuration](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/) files necessary to run a Caliper benchmark. In contrast to the runtime configurations, used for tweaking the internal behavior of Caliper, the benchmark configuration pertains only to the execution of the benchmark workload and collection of the results. +The `benchmark configuration file` is one of the [required configuration](runtime-config.md) files necessary to run a Caliper benchmark. In contrast to the runtime configurations, used for tweaking the internal behavior of Caliper, the benchmark configuration pertains only to the execution of the benchmark workload and collection of the results. !!! note @@ -9,14 +9,13 @@ The `benchmark configuration file` is one of the [required configuration](https: The benchmark configuration consists of three main parts: -- [Table of contents](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/#table-of-contents) -- [Overview](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/#overview) -- [Benchmark test settings](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/#benchmark-test-settings) -- [Monitoring settings](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/#monitoring-settings) -- [Example](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/#example) -- [License](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/#license) +- [Overview](#overview) +- [Benchmark test settings](#benchmark-test-settings) +- [Monitoring settings](#monitoring-settings) +- [Example](#example) +- [License](#license) -For a complete benchmark configuration example, refer to the [last section](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/#example). +For a complete benchmark configuration example, refer to the [last section](#example). !!! note @@ -36,16 +35,16 @@ The settings related to the benchmark workload all reside under the root `test` | test.rounds[i].label | A short name of the rounds, usually corresponding to the types of submitted TXs. | | test.rounds[i].txNumber | The number of TXs Caliper should submit during the round. | | test.rounds[i].txDuration | The length of the round in seconds during which Caliper will submit TXs. | -| test.rounds[i].rateControl | The object describing the [rate controller](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/) to use for the round. | -| test.rounds[i].workload | The object describing the [workload module](https://hyperledger.github.io/caliper/v0.6.0/overview/workload-module/) used for the round. | +| test.rounds[i].rateControl | The object describing the [rate controller](rate-controllers.md) to use for the round. | +| test.rounds[i].workload | The object describing the [workload module](workload-module.md) used for the round. | | test.rounds[i].workload.module | The path to the benchmark workload module implementation that will construct the TXs to submit. | | test.rounds[i].workload.arguments | Arbitrary object that will be passed to the workload module as configuration. | -A benchmark configuration with the above structure will define a benchmark run that consists of multiple rounds. Each round is associated with a [rate controller](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/) that is responsible for the scheduling of TXs, and a [workload module](https://hyperledger.github.io/caliper/v0.6.0/overview/workload-module/) that will generate the actual content of the scheduled TXs. +A benchmark configuration with the above structure will define a benchmark run that consists of multiple rounds. Each round is associated with a [rate controller](rate-controllers.md) that is responsible for the scheduling of TXs, and a [workload module](workload-module.md) that will generate the actual content of the scheduled TXs. ## Monitoring settings -The monitoring configuration determines what kind of metrics the manager process can gather and from where. The configuration resides under the `monitors` attribute. Refer to the [monitors configuration page](https://hyperledger.github.io/caliper/v0.6.0/reference/caliper-monitors/) for the details. +The monitoring configuration determines what kind of metrics the manager process can gather and from where. The configuration resides under the `monitors` attribute. Refer to the [monitors configuration page](caliper-monitors.md) for the details. ## Example @@ -105,4 +104,4 @@ monitors: ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/concepts/benchmark-generators.md b/docs/source/concepts/benchmark-generators.md index 5bd4504cf..f217c6dd8 100644 --- a/docs/source/concepts/benchmark-generators.md +++ b/docs/source/concepts/benchmark-generators.md @@ -64,7 +64,7 @@ Now for the callback file... ### Configuration Prompts -Next, you will be taken through generating the [configuration file](https://hyperledger.github.io/caliper/v0.6.0/benchmark-generator/Architecture#ConfigurationFile) and you will be prompted for: +Next, you will be taken through generating the configuration file and you will be prompted for: - the **name** of the benchmark - a **description** of the benchmark @@ -171,4 +171,4 @@ The generator only generates a single callback file for a single smart contract ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/concepts/caliper-messengers.md b/docs/source/concepts/caliper-messengers.md index 8e5c7b75f..c3c228dea 100644 --- a/docs/source/concepts/caliper-messengers.md +++ b/docs/source/concepts/caliper-messengers.md @@ -31,4 +31,4 @@ If not specifying a `caliper.yaml` configuration file, the above may be specifie ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/concepts/caliper-monitors.md b/docs/source/concepts/caliper-monitors.md index 26a0ae50b..4e9b1f320 100644 --- a/docs/source/concepts/caliper-monitors.md +++ b/docs/source/concepts/caliper-monitors.md @@ -369,4 +369,4 @@ monitors: ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/concepts/logging-control.md b/docs/source/concepts/logging-control.md index 79dc808a1..d5c37d900 100644 --- a/docs/source/concepts/logging-control.md +++ b/docs/source/concepts/logging-control.md @@ -6,7 +6,7 @@ Caliper builds on the [winston](https://github.com/winstonjs/winston) logger mod 2. Configuring logging targets 3. Creating your own loggers -The first two points can be achieved through the [runtime configuration](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/) mechanism of Caliper. So make sure that you are familiar with the different way of overriding runtime settings before reading on. The examples below only set the different options through the command line. Naturally, any other setting source could be used. +The first two points can be achieved through the [runtime configuration](runtime-config.md) mechanism of Caliper. So make sure that you are familiar with the different way of overriding runtime settings before reading on. The examples below only set the different options through the command line. Naturally, any other setting source could be used. The runtime configuration settings corresponding to logging reside under the `caliper-logging` key hierarchy. See the `caliper.logging` section of the [default configuration file](https://github.com/hyperledger/caliper/blob/v0.6.0/packages/caliper-core/lib/config/default.yaml) bundled with Caliper for the general structure of the settings. @@ -54,7 +54,7 @@ You can override this template by changing the caliper-logging-template setting This template if applied after every format has been applied!
  • - Adding spaces and different brackets this way is fine for simple coloring scenarios (or when coloring is disabled). However, when coloring the entire log message (or just parts that should be surrounded with additional characters), the result looks inconsistent when formatted this way. See the Tips & Tricks section for advanced message formatting scenarios. + Adding spaces and different brackets this way is fine for simple coloring scenarios (or when coloring is disabled). However, when coloring the entire log message (or just parts that should be surrounded with additional characters), the result looks inconsistent when formatted this way. See the Tips & Tricks section for advanced message formatting scenarios.
  • @@ -71,7 +71,7 @@ The following formats and their options (sub-properties) are supported. !!! note - *the different formats are applied in the order they are presented, which is important (see the [Tips & Tricks](https://hyperledger.github.io/caliper/v0.6.0/reference/logging/#tips--tricks) section for the reason).* + *the different formats are applied in the order they are presented, which is important (see the [Tips & Tricks](#tips-tricks) section for the reason).* #### Timestamp @@ -103,7 +103,7 @@ For example: `--caliper-logging-formats-json="{space:0}"` Note:
    1. - Enabling this format is easier from a configuration file. See the Tips & Tricks section. + Enabling this format is easier from a configuration file. See the Tips & Tricks section.
    2. Setting space to a non-zero number will effectively format the JSON output with indentations on multiple lines. This could “spam” the console a bit (not a problem for log files, unless you care about the extra newlines). @@ -227,7 +227,7 @@ For example, to disable the `mylogger1` target, the following approaches are ava ### Overriding logger target settings -But what if you would like to modify one of the options of a transport? You can use a [configuration file](https://hyperledger.github.io/caliper/v0.6.0/reference/untime-config/#configuration-files) for that! +But what if you would like to modify one of the options of a transport? You can use a [configuration file](runtime-config.md/#configuration-files) for that! For the next example, we will disable the default file logger, modify the logging level of the console target, and also add a new daily rotating file logger. We can do all of this with a single configuration file. @@ -270,7 +270,7 @@ If you save the above content as `caliper.yaml` in your workspace directory, the 1. We only set the properties we wanted to override. The default configuration file will be merged with the above configuration file, the values in the latter taking precedence. 2. The provided options for a transport are not verified by Caliper. It is simple passed to the specific transport. It is your responsibility to configure the transport the right way. - 3. We could have disabled the file logger also from the command line, or from an environment variable. The reason we did it from a config file is explained in the [Tips & tricks](https://hyperledger.github.io/caliper/v0.6.0/reference/logging/#tips--tricks) section. + 3. We could have disabled the file logger also from the command line, or from an environment variable. The reason we did it from a config file is explained in the [Tips & tricks](#tips-tricks) section. ## Creating your own loggers @@ -477,7 +477,7 @@ To this end, the ability to override the logging style settings from the command The easiest way to do that is with a project-level configuration file. If you name the following file `caliper.yaml` and place it in your workspace root, then Caliper will automatically apply the settings. !!! note - there are other ways to load a configuration file, as discussed in the [runtime configuration page](https://hyperledger.github.io/caliper/v0.6.0/runtime-config/#configuration-files). + there are other ways to load a configuration file, as discussed in the [runtime configuration page](runtime-config.md/#configuration-files). ```sh caliper: @@ -511,4 +511,4 @@ caliper: ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/concepts/rate-controllers.md b/docs/source/concepts/rate-controllers.md index ac91333e7..59f809040 100644 --- a/docs/source/concepts/rate-controllers.md +++ b/docs/source/concepts/rate-controllers.md @@ -1,16 +1,16 @@ The rate at which transactions are input to the blockchain system is a key factor within performance tests. It may be desired to send transactions at a specified rate or follow a specified profile. Caliper permits the specification of custom rate controllers to enable a user to perform testing under a custom loading mechanism. A user may specify their own rate controller or use one of the default options: -- [Fixed rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#fixed-rate) -- [Fixed feedback rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#fixed-feedback-rate) -- [Fixed load](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#fixed-load) -- [Maximum rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#maximum-rate) -- [Linear rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#linear-rate) -- [Composite rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#composite-rate) -- [Zero rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#zero-rate) -- [Record rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#record-rate) -- [Replay rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#replay-rate) - -For implementing your own rate controller, refer to the [Adding Custom Controllers](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#adding-custom-controllers) section. +- [Fixed rate](#fixed-rate) +- [Fixed feedback rate](#fixed-feedback-rate) +- [Fixed load](#fixed-load) +- [Maximum rate](#maximum-rate) +- [Linear rate](#linear-rate) +- [Composite rate](#composite-rate) +- [Zero rate](#zero-rate) +- [Record rate](#record-rate) +- [Replay rate](#replay-rate) + +For implementing your own rate controller, refer to the [Adding Custom Controllers](#adding-custom-controllers) section. ## Fixed rate The fixed rate controller is the most basic controller, and also the default option if no controller is specified. It will send input transactions at a fixed interval that is specified as TPS (transactions per second). @@ -135,7 +135,7 @@ The following example specifies a rate controller that gradually changes the tra ``` !!!note - similarly to the [fixed rate controller](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#fixed-rate), this controller also divides the workload between the available client, so the specified rates in the configuration are cumulative rates, and not the rates of individual clients. Using the above configuration with 5 clients results in clients that start at 5 TPS and finish at 15 TPS. Together they generate a [25-75] TPS load. + similarly to the [fixed rate controller](#fixed-rate), this controller also divides the workload between the available client, so the specified rates in the configuration are cumulative rates, and not the rates of individual clients. Using the above configuration with 5 clients results in clients that start at 5 TPS and finish at 15 TPS. Together they generate a [25-75] TPS load. ## Composite rate A benchmark round in Caliper is associated with a single rate controller. However, a single rate controller is rarely sufficient to model advanced client behaviors. Moreover, implementing new rate controllers for such behaviors can be cumbersome and error-prone. Most of the time a complex client behavior can be split into several, simpler phases. @@ -162,7 +162,7 @@ Note, that technically, composite rate controllers can be nested to form a hiera - `logChange`: a `boolean` value indicating whether the switches between the specified rate controllers should be logged or not. -For example, the definition of a square wave function (with varying amplitude) as the transaction submission rate is as easy as switching between [fixed rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#fixed-rate) controllers with different TPS settings: +For example, the definition of a square wave function (with varying amplitude) as the transaction submission rate is as easy as switching between [fixed rate](#fixed-rate) controllers with different TPS settings: ```sh { @@ -197,7 +197,7 @@ For example, the definition of a square wave function (with varying amplitude) a The results of recently finished transactions are propagated to the sub-controllers as-is, so for the first few call of a newly activated sub-controller it can receive recent results that don’t belong to its virtualized round. -This virtualization does not affect the memoryless controllers, i.e., the controllers whose control logic does not depend on global round properties or past transaction results. However, other controllers might exhibit some strange (but hopefully transient) behavior due to this “virtualized” round approach. For example, the logic of the [PID controller](https://hyperledger.github.io/caliper/v0.6.0/reference/ate-controllers/#pid-rate) for example depends on the transaction backlog. +This virtualization does not affect the memoryless controllers, i.e., the controllers whose control logic does not depend on global round properties or past transaction results. However, other controllers might exhibit some strange (but hopefully transient) behavior due to this “virtualized” round approach. For example, the logic of the PID controller for example depends on the transaction backlog. ## Zero rate @@ -205,7 +205,7 @@ This virtualization does not affect the memoryless controllers, i.e., the contro This controller stops the workload generation for the duration of the round. ### Options and use -Using the controller on its own for a round is meaningless. However, it can be used as a building block inside a [composite rate](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/#composite-rate) controller. **The zero rate controller can be used only in duration-based rounds!** +Using the controller on its own for a round is meaningless. However, it can be used as a building block inside a [composite rate](#composite-rate) controller. **The zero rate controller can be used only in duration-based rounds!** ```sh { @@ -242,7 +242,7 @@ The controller is identified by the `zero-rate` string as the value of the `type ## Record rate This rate controller serves as a decorator around an other (arbitrary) controller. Its purpose is to record the times (relative to the start of the round) when each transaction was submitted, i.e., when the transaction was “enabled” by the “sub-controller.” -The following example records the times when the underlying [fixed rate](https://hyperledger.github.io/caliper/v0.6.0/reference.rate-controllers/#fixed-rate) controller enabled the transactions (for details, see the available options below the example): +The following example records the times when the underlying [fixed rate](#fixed-rate) controller enabled the transactions (for details, see the available options below the example): ```sh { @@ -321,11 +321,11 @@ The replay rate controller can be specified by setting the rate controller type - `pathTemplate`: the template for the file path where the transaction timings will be replayed from. The path can be either an absolute path or relative to the root Caliper directory. -The template can (**and should**) contain special “variables/placeholders” that can refer to special environment properties (see the remarks at the [record rate controller](https://hyperledger.github.io/caliper/v0.6.0/reference.rate-controllers/#record-rate)). The available placeholders are the following: +The template can (**and should**) contain special “variables/placeholders” that can refer to special environment properties (see the remarks at the [record rate controller](#record-rate)). The available placeholders are the following: - ``: placeholder for the 1-based index of the current client that uses this rate controller. - ``: placeholder for the 1-based index of the current round that uses this rate controller. -- `inputFormat`: optional. Determines the format in which the transaction timings are stored (see the details at the [record rate controller](https://hyperledger.github.io/caliper/v0.6.0/reference.rate-controllers/#record-rate)). Defaults to `"TEXT"`. The currently supported formats are the following: +- `inputFormat`: optional. Determines the format in which the transaction timings are stored (see the details at the [record rate controller](#record-rate)). Defaults to `"TEXT"`. The currently supported formats are the following: - `"TEXT"`: each recorded timing is encoded as text on separate lines. - `"BIN_BE"`: binary format with Big Endian encoding. - `"BIN_LE"`: binary format with Little Endian encoding. @@ -340,7 +340,7 @@ The recommended approach is to use transaction number-based round configurations ## Adding Custom Controllers -It is possible to use rate controllers that are not built-in controllers of Caliper. When you specify the rate controller in the test configuration file (see the [architecture documentation](https://hyperledger.github.io/caliper/v0.6.0/overview/architecture/)), you must set the `type` and `opts` attributes. +It is possible to use rate controllers that are not built-in controllers of Caliper. When you specify the rate controller in the test configuration file (see the [architecture documentation](../getting-started/architecture.md)), you must set the `type` and `opts` attributes. You can set the `type` attribute so that it points to your custom JS file that satisfies the following criteria: @@ -438,4 +438,4 @@ rateControl: ``` ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/concepts/runtime-config.md b/docs/source/concepts/runtime-config.md index 21ff67724..6e5be4db5 100644 --- a/docs/source/concepts/runtime-config.md +++ b/docs/source/concepts/runtime-config.md @@ -14,19 +14,19 @@ Every setting used by Caliper is prefixed with the `caliper-` string. The prefix !!! note - *For every available runtime setting, refer to the [last section](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#available-settings).* + *For every available runtime setting, refer to the [last section](#available-settings).* ## Setting sources Caliper supports the following sources/locations where runtime settings can be set/overridden, in priority order, starting with the highest priority: -1. [Memory](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#in-memory-settings) -2. [Command line arguments](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#interface-reference) -3. [Environment variables](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#environment-variables) -4. [Project-level configuration file](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#project-level) -5. [User-level configuration file](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#user-level) -6. [Machine-level configuration file](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#machine-level) -7. [Fallback/default configuration file](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#default-configuration) +1. [Memory](#in-memory-settings) +2. [Command line arguments](#command-line-arguments) +3. [Environment variables](#environment-variables) +4. [Project-level configuration file](#project-level) +5. [User-level configuration file](#user-level) +6. [Machine-level configuration file](#machine-level) +7. [Fallback/default configuration file](#default-configuration) For simplicity, you can think of the above order as the following: the “closer” the setting is set to its point of use, the higher the priority of the set value. @@ -65,7 +65,7 @@ The above code also shows how a plugin module can easily leverage Caliper’s co If we wish to influence the behavior of a third-party code (e.g., Caliper or a user callback module), we usually can’t (or don’t want to) overwrite the setting in the source code. A standard way of modifying the behavior of third-party/pre-packaged applications is to provide the settings as commandline arguments. -Starting Caliper through the [CLI](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/#the-caliper-cli), you can override runtime settings the following way: +Starting Caliper through the [CLI](../getting-started/installing-caliper.md/#the-caliper-cli), you can override runtime settings the following way: ```sh caliper launch manager \ @@ -380,4 +380,4 @@ The default is `msp_round_robin` ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/concepts/workload-module.md b/docs/source/concepts/workload-module.md index 994963b38..8013766d1 100644 --- a/docs/source/concepts/workload-module.md +++ b/docs/source/concepts/workload-module.md @@ -21,7 +21,7 @@ function createWorkloadModule() { module.exports.createWorkloadModule = createWorkloadModule; ``` -The factory function must return an instance that implements the `[WorkloadModuleInterface](https://github.com/hyperledger/caliper/blob/main/packages/caliper-core/lib/worker/workload/workloadModuleInterface.js)` class. See the [example](https://hyperledger.github.io/caliper/v0.6.0/overview/workload-module/#example) for a complete implementation. +The factory function must return an instance that implements the `[WorkloadModuleInterface](https://github.com/hyperledger/caliper/blob/main/packages/caliper-core/lib/worker/workload/workloadModuleInterface.js)` class. See the [example](#example) for a complete implementation. The interface contains the following three **asynchronous** functions: @@ -35,7 +35,7 @@ The `initializeWorkloadModule` function is called by the worker processes before 5. `sutAdapter (BlockchainConnector)`: The connector of the underlying SUT (System Under Test). 6. `sutContext (Object)`: The custom context object provided by the SUT connector. -This function is a good place to validate your workload module arguments provided by the [benchmark configuration file](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/). It’s also a good practice to perform here any preprocessing needed to ensure the fast assembling of TX contents later in the `submitTransaction` function. +This function is a good place to validate your workload module arguments provided by the [benchmark configuration file](bench-config.md). It’s also a good practice to perform here any preprocessing needed to ensure the fast assembling of TX contents later in the `submitTransaction` function. #### submitTransaction The `submitTransaction` function is the backbone of the workload generation. The worker process calls this function every time the rate controller enables the next TX. So it is vital to keep this function implementation as efficient as possible in order to be able to keep up with high frequency scheduling settings. @@ -130,7 +130,7 @@ module.exports.createWorkloadModule = createWorkloadModule; ``` ## Configuring the workload module -To use your workload module for a given round, you only need to reference it in the [benchmark configuration](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/#benchmark-test-settings) file: +To use your workload module for a given round, you only need to reference it in the [benchmark configuration](bench-config.md/#benchmark-test-settings) file: 1. Set the `test.rounds[i].workload.module` attribute to the path of your workload module file. The path can be either an absolute path, or a relative path to the configured workspace path. You can also set the attribute to the package name of your published workload module, but in that case you need to install it beforehand. 2. If your module supports different settings, set the `test.rounds[i].workload.arguments` attribute object accordingly. It will be passed to your module upon initialization. @@ -141,9 +141,9 @@ The following advices might help you to improve your workload module implementat 1. You can use (`require`) any Node.JS module in your code (including the core Caliper module). Modularization is important for keeping your implementation clean and manageable. 2. If you use third-party modules, then it is your responsibility to make them available to your workload module. This usually requires an `npm install` call in your module directory before you start Caliper. -3. Caliper provides some core utilities that might make your life easier, such as [logging](https://hyperledger.github.io/caliper/v0.6.0/reference/logging/) and [runtime configuration](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/). Use them, don’t reinvent the wheel! +3. Caliper provides some core utilities that might make your life easier, such as [logging](logging-control.md) and [runtime configuration](runtime-config.md). Use them, don’t reinvent the wheel! 4. The `submitTransaction` function is on the **hot path** of the worker workload generation loop. Do computation-intensive tasks with care, it might hurt the scheduling precision of TXs! You can perform expensive pre-processing tasks in the `initializeWorkloadModule` function instead. ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/connectors/ethereum-config.md b/docs/source/connectors/ethereum-config.md index 3f2ec1beb..d32221d90 100644 --- a/docs/source/connectors/ethereum-config.md +++ b/docs/source/connectors/ethereum-config.md @@ -16,10 +16,10 @@ This page introduces the Ethereum adapter suitable for all the Ethereum clients The page covers the following aspects of using the Ethereum adapter: -- how to assemble a [connection profile file](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#assembling-the-network-configuration-file), a.k.a., the blockchain network configuration file; -- how to use the [adapter interface](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#using-the-adapter-interface) from the user callback module; -- [transaction data gathered](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#transaction-data-gathered-by-the-adapter) by the adapter; -- and a [complete example](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#connection-profile-example) of a connection profile. +- how to assemble a [connection profile file](../connectors/ethereum-config.md/#assembling-the-network-configuration-file), a.k.a., the blockchain network configuration file; +- how to use the [adapter interface](../connectors/ethereum-config.md/#using-the-adapter-interface) from the user callback module; +- [transaction data gathered](../connectors/ethereum-config.md/#transaction-data-gathered-by-the-adapter) by the adapter; +- and a [complete example]../connectors/ethereum-config.md/#connection-profile-example) of a connection profile. ## Assembling the Network Configuration File @@ -64,17 +64,17 @@ Furthermore, it also contains two optional commands: a `start` command to execut These are the keys to provide inside the configuration file under the `ethereum` one: -- [URL](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#url) of the node to connect to. Only http is currently supported. -- [Deployer address](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#deployer-address) with which to deploy required contracts. -- [Deployer address private key](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#deployer-address-private-key): the private key of the deployer address. -- [Deployer address password](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#deployer-address-password): to unlock the deployer address. -- [Address](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#benchmark-address) from which to invoke methods of the benchmark. -- [Private Key](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#benchmark-address-private-key): the private key of the benchmark address. -- [Password](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#benchmark-address-password): to unlock the benchmark address. -- Number of [confirmation blocks](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#confirmation-blocks) to wait to consider a transaction as successfully accepted in the chain. -- [Contracts configuration](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#contract-configuration). +- [URL](../connectors/ethereum-config.md/#url) of the node to connect to. Only http is currently supported. +- [Deployer address](../connectors/ethereum-config.md/#deployer-address) with which to deploy required contracts. +- [Deployer address private key](../connectors/ethereum-config.md/#deployer-address-private-key): the private key of the deployer address. +- [Deployer address password](../connectors/ethereum-config.md/#deployer-address-password): to unlock the deployer address. +- [Address](../connectors/ethereum-config.md/#benchmark-address) from which to invoke methods of the benchmark. +- [Private Key](../connectors/ethereum-config.md/#benchmark-address-private-key): the private key of the benchmark address. +- [Password](../connectors/ethereum-config.md/#benchmark-address-password): to unlock the benchmark address. +- Number of [confirmation blocks](../connectors/ethereum-config.md/#confirmation-blocks) to wait to consider a transaction as successfully accepted in the chain. +- [Contracts configuration](../connectors/ethereum-config.md/#contract-configuration). -The following sections detail each part separately. For a complete example, please refer to the [example section](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#connection-profile-example) or one of the example files in the `network/ethereum` directories +The following sections detail each part separately. For a complete example, please refer to the [example section](../connectors/ethereum-config.md/#connection-profile-example) or one of the example files in the `network/ethereum` directories #### URL The URL of the node to connect to. Any host and port can be used if it is reachable. Currently only websocket is supported. @@ -90,7 +90,7 @@ Unfortunately, HTTP connections are explicitly disallowed, as #### Deployer Address -The address to use to deploy contracts of the network. Without particular or specific needs it can be set to be equal to the [benchmark address](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#benchmark-address). Its private key must be hold by the node connected with [URL](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#url) and it must be provided in the checksum form (the one with both lowercase and uppercase letters). +The address to use to deploy contracts of the network. Without particular or specific needs it can be set to be equal to the [benchmark address](../connectors/ethereum-config.md/#benchmark-address). Its private key must be hold by the node connected with [URL](../connectors/ethereum-config.md/#url) and it must be provided in the checksum form (the one with both lowercase and uppercase letters). ```sh "contractDeployerAddress": "0xc0A8e4D217eB85b812aeb1226fAb6F588943C2C2" @@ -98,7 +98,7 @@ The address to use to deploy contracts of the network. Without particular or spe #### Deployer Address Private Key -The private key for the [deployer address](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#deployer-address). If present then transactions are signed inside caliper and sent “raw” to the ethereum node. +The private key for the [deployer address](../connectors/ethereum-config.md/#deployer-address). If present then transactions are signed inside caliper and sent “raw” to the ethereum node. ```sh "contractDeployerAddressPrivateKey": "0x45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8" @@ -106,7 +106,7 @@ The private key for the [deployer address](https://hyperledger.github.io/caliper #### Deployer Address Password -The password to use to unlock [deployer address](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#deployer-address). If there isn’t an unlock password, this key must be present as empty string. If the deployer address private key is present this is not used. +The password to use to unlock [deployer address](../connectors/ethereum-config.md/#deployer-address). If there isn’t an unlock password, this key must be present as empty string. If the deployer address private key is present this is not used. ```sh "contractDeployerAddressPassword": "gottacatchemall" @@ -118,7 +118,7 @@ The password to use to unlock [deployer address](https://hyperledger.github.io/c #### Benchmark Address -The address to use while invoking all the methods of the benchmark. Its private key must be hold by the node connected with [URL](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#url) and it must be provided in the checksum form (the one with both lowercase and uppercase letters). +The address to use while invoking all the methods of the benchmark. Its private key must be hold by the node connected with [URL](../connectors/ethereum-config.md/#url) and it must be provided in the checksum form (the one with both lowercase and uppercase letters). ```sh "fromAddress": "0xc0A8e4D217eB85b812aeb1226fAb6F588943C2C2" @@ -140,7 +140,7 @@ This configuration does not override fromAddress, but it takes priority over `fr #### Benchmark Address Private Key -The private key for the [benchmark address](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#benchmark-address). If present then transactions are signed inside caliper and sent “raw” to the ethereum node. +The private key for the [benchmark address](../connectors/ethereum-config.md/#benchmark-address). If present then transactions are signed inside caliper and sent “raw” to the ethereum node. This configuration takes priority over `fromAddressPassword`. @@ -150,7 +150,7 @@ This configuration takes priority over `fromAddressPassword`. #### Benchmark Address Password -The password to use to unlock [benchmark address](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#benchmark-address). If there isn’t an unlock password, this key must be present as empty string. If the benchmark address private key is present this is not used. +The password to use to unlock [benchmark address](../connectors/ethereum-config.md/#benchmark-address). If there isn’t an unlock password, this key must be present as empty string. If the benchmark address private key is present this is not used. ```sh "fromAddressPassword": "gottacatchemall" @@ -200,7 +200,7 @@ To use pre-deployed contracts, you must launch caliper using the `--caliper-flow ``` #### Contracts to Deploy -Contracts to be deployed by Caliper require the specification of a [contract definition file](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#contract-definition-file) for each. In the contract configuration you must include a path field pointing to each contract definition file. It’s in this new file that you will define the contract’s ABI and bytecode, as well as the gas required to deploy it. +Contracts to be deployed by Caliper require the specification of a [contract definition file](../connectors/ethereum-config.md/#contract-definition-file) for each. In the contract configuration you must include a path field pointing to each contract definition file. It’s in this new file that you will define the contract’s ABI and bytecode, as well as the gas required to deploy it. ```sh "contracts": { @@ -225,10 +225,10 @@ Contracts to be deployed by Caliper require the specification of a [contract def Contract definition file is a simple JSON file containing basic information to deploy and use an Ethereum contract. Four keys are required: -- [Name](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#name) -- [ABI](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#abi) -- [Bytecode](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#bytecode) -- [Gas](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#gas) +- [Name](../connectors/ethereum-config.md/#name) +- [ABI](../connectors/ethereum-config.md/#abi) +- [Bytecode](../connectors/ethereum-config.md/#bytecode) +- [Gas](../connectors/ethereum-config.md/#gas) Here is an example: ```sh @@ -253,11 +253,11 @@ It is the gas required to deploy the contract. It can be easily calculated with ### Using the Adapter Interface -The [workload modules](https://hyperledger.github.io/caliper/v0.6.0/overview/workload-module/) interact with the adapter at two phases of the tests: during the initialization of the workload module (the `initializeWorkloadModule` function), and when submitting invoke or query transactions (the `submitTransaction` function). +The [workload modules](../concepts/workload-module.md) interact with the adapter at two phases of the tests: during the initialization of the workload module (the `initializeWorkloadModule` function), and when submitting invoke or query transactions (the `submitTransaction` function). #### The *initializeWorkloadModule* function -See the [corresponding documentation](https://hyperledger.github.io/caliper/v0.6.0/overview/workload-module/#initializeworkloadmodule) of the function for the description of its parameters. +See the [corresponding documentation](../concepts/workload-module.md/#initializeworkloadmodule) of the function for the description of its parameters. The last argument of the function is a `sutContext` object, which is a platform-specific object provided by the backend blockchain’s connector. The context object provided by this connector is the following: @@ -268,7 +268,7 @@ The last argument of the function is a `sutContext` object, which is a platform- } ``` -The `fromAddress` property is the [benchmark address](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#benchmark-address) while web3 is the configured instance of the Web3js client. +The `fromAddress` property is the [benchmark address](../connectors/ethereum-config.md/#benchmark-address) while web3 is the configured instance of the Web3js client. #### The *submitTransaction* function The `sutAdapter` object received (and saved) in the `initializeWorkloadModule` function is of type `[ConnectorInterface](https://github.com/hyperledger/caliper/blob/v0.6.0/packages/caliper-core/lib/common/core/connector-interface.js)`. Its `getType()` function returns the `fabric` string value. @@ -277,7 +277,7 @@ The `sendRequests` method of the connector API allows the workload module to sub The settings object has the following structure: -- `contract`: string. Required. The ID of the contract (that is the key specified [here](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/#contract-configuration)). +- `contract`: string. Required. The ID of the contract (that is the key specified [here](../connectors/ethereum-config.md/#contract-configuration)). - `readOnly`: boolean. Optional. Indicates whether the request is a TX or a query. Defaults to `false`. - `verb`: string. Required. The name of the function to call on the contract. - `value`: number. Optional. The value parameter in Wei to be passed to the payable function of the contract. @@ -320,4 +320,4 @@ The standard information provided by the type are the following: ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/connectors/fabric-config.md b/docs/source/connectors/fabric-config.md index 9ff4c62a0..9f07cc01f 100644 --- a/docs/source/connectors/fabric-config.md +++ b/docs/source/connectors/fabric-config.md @@ -20,7 +20,7 @@ The adapter exposes many SDK features directly to the user callback modules, mak - option to select the identity for submitting a TX/query ## Installing dependencies -You must bind Caliper to a specific Fabric SDK to target the corresponding (or compatible) SUT version. Refer to the [binding documentation](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/#the-bind-command) for details. When you bind to an SUT, you are in fact selecting a specific Fabric SDK to use which could be used with different versions of Fabric SUTs. +You must bind Caliper to a specific Fabric SDK to target the corresponding (or compatible) SUT version. Refer to the [binding documentation](../getting-started/installing-caliper.md#the-bind-command) for details. When you bind to an SUT, you are in fact selecting a specific Fabric SDK to use which could be used with different versions of Fabric SUTs. !!! note @@ -94,7 +94,7 @@ peers: ## Runtime settings ### Common settings -Some runtime properties of the adapter can be set through Caliper’s [runtime configuration mechanism](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/). For the available settings, see the `caliper.fabric` section of the [default configuration file](https://github.com/hyperledger/caliper/blob/v0.6.0/packages/caliper-core/lib/common/config/default.yaml) and its embedded documentation. +Some runtime properties of the adapter can be set through Caliper’s [runtime configuration mechanism](../concepts/runtime-config.md). For the available settings, see the `caliper.fabric` section of the [default configuration file](https://github.com/hyperledger/caliper/blob/v0.6.0/packages/caliper-core/lib/common/config/default.yaml) and its embedded documentation. The above settings are processed when starting Caliper. Modifying them during testing will have no effect. However, you can override the default values *before Caliper* starts from the usual configuration sources. In the following example the `localhost` property applies only when binding with Fabric 2.2 or Fabric 1.4 (and only if the `gateway` option is enabled) @@ -107,7 +107,7 @@ The above settings are processed when starting Caliper. Modifying them during te gateway: localhost: false ``` - *After naming the [project settings](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#project-level) file `caliper.yaml` and placing it in the root of your workspace directory, it will override the following two setting keys with the following values:* + *After naming the [project settings](../concepts/runtime-config.md#project-level) file `caliper.yaml` and placing it in the root of your workspace directory, it will override the following two setting keys with the following values:* - *Setting `caliper-fabric-gateway-localhost` is set to false* @@ -119,11 +119,11 @@ The above settings are processed when starting Caliper. Modifying them during te ## The connector API -The [workload modules](https://hyperledger.github.io/caliper/v0.6.0/overview/workload-module/) interact with the adapter at three phases of the tests: during the initialization of the user module (in the `initializeWorkloadModule` callback), when submitting invoke or query transactions (in the `submitTransaction` callback), and at the optional cleanup of the user module (in the `cleanupWorkloadModule` callback). +The [workload modules](../concepts/workload-module.md) interact with the adapter at three phases of the tests: during the initialization of the user module (in the `initializeWorkloadModule` callback), when submitting invoke or query transactions (in the `submitTransaction` callback), and at the optional cleanup of the user module (in the `cleanupWorkloadModule` callback). ### The `initializeWorkloadModule` function -See the [corresponding documentation](https://hyperledger.github.io/caliper/v0.6.0/overview/workload-module/#initializeworkloadmodule) of the function for the description of its parameters. +See the [corresponding documentation](../concepts/workload-module.md/#initializeworkloadmodule) of the function for the description of its parameters. The last argument of the function is a `sutContext` object, which is a platform-specific object provided by the backend blockchain’s connector. The context object provided by this connector is a `FabricConnectorContext` instance but this doesn’t provide anything of use at this time. @@ -200,7 +200,7 @@ The adapter-specific data keys that only the v1.4 SUT when not enabling the gate | `proposal_error` | string | The error message in case an error occurred during sending/waiting for the proposal responses from the endorsers. | | `proposal_response_error_

      ` | string | The error message in case the endorser peer `

      ` returned an error as endorsement result. | | `endorsement_result_

      ` | Buffer | The encoded contract invocation result returned by the endorser peer `

      `. It is the user callback’s responsibility to decode the result. | -| `endorsement_verify_error_

      ` | string | Has the value of 'INVALID' if the signature and identity of the endorser peer `

      ` couldn’t be verified. This verification step can be switched on/off through the [runtime configuration options](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/fabric-config/#runtime-settings). | +| `endorsement_verify_error_

      ` | string | Has the value of 'INVALID' if the signature and identity of the endorser peer `

      ` couldn’t be verified. This verification step can be switched on/off through the [runtime configuration options](#runtime-settings). | | `endorsement_result_error

      ` | string | If the transaction proposal or query execution at the endorser peer `

      ` results in an error, this field contains the error message. | | `read_write_set_error` | string | Has the value of 'MISMATCH' if the sent transaction proposals resulted in different read/write sets. | | `time_orderer_ack` | number | The Unix epoch when the adapter received the confirmation from the orderer that it successfully received the transaction. Note, that this isn’t the actual ordering time of the transaction. | @@ -239,7 +239,7 @@ The `cleanupWorkloadModule` function is called at the end of the round, and can ## Network configuration file reference The YAML network configuration file of the adapter mainly describes the organizations and the identities associated with those organizations, It also provides explicit information about the channels in your Fabric network and the chaincode (containing 1 or more smart contracts) deployed to those channels. It can reference Common Connection Profiles for each organization (as common connection profiles are specific to a single organization). These are the same connection profiles that would be consumed by the node-sdk. Whoever creates the Fabric network and channels would be able to provide appropriate profiles for each organization. -The following sections detail each part separately. For a complete example, please refer to the [example section](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/fabric-config/#network-configuration-example) or one of the files in the [Caliper repositor](https://github.com/hyperledger/caliper), such as the caliper-fabric test folder. +The following sections detail each part separately. For a complete example, please refer to the [example section](#network-configuration-example) or one of the files in the [Caliper repositor](https://github.com/hyperledger/caliper), such as the caliper-fabric test folder.

      name @@ -1057,4 +1057,4 @@ organizations: ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/connectors/writing-connectors.md b/docs/source/connectors/writing-connectors.md index 5ac6c145e..ae1ceb770 100644 --- a/docs/source/connectors/writing-connectors.md +++ b/docs/source/connectors/writing-connectors.md @@ -4,9 +4,9 @@ Connectors are probably the most important modules in Caliper. They provide an a !!! note - *To get a sense of how a connector fits into the Caliper architecture, see the corresponding architecture documentation sections about [multi-platform support](https://hyperledger.github.io/caliper/v0.6.0/overview/architecture/#multi-platform-support), [the manager process](https://hyperledger.github.io/caliper/v0.6.0/overview/architecture/#the-manager-process) and [the worker processes](https://hyperledger.github.io/caliper/v0.6.0/overview/architecture/#the-worker-process).* + *To get a sense of how a connector fits into the Caliper architecture, see the corresponding architecture documentation sections about [multi-platform support](../getting-started/architecture.md/#multi-platform-support), [the manager process](../getting-started/architecture.md/#the-manager-process) and [the worker processes](../getting-started/architecture.md/#the-worker-process).* -Caliper ships with some [predefined/built-in connectors](https://hyperledger.github.io/caliper/v0.6.0/overview/getting-started/#supported-blockchain-solutions), but in general, connectors are treated as pluggable components (just like resource and TX monitors, workload modules, etc.). So nothing stops you from implementing and using your 3rd party connector! However, we strongly recommend that you absorb every part of this guide before implementing a new connector. +Caliper ships with some [predefined/built-in connectors](../index.md#supported-blockchain-solutions), but in general, connectors are treated as pluggable components (just like resource and TX monitors, workload modules, etc.). So nothing stops you from implementing and using your 3rd party connector! However, we strongly recommend that you absorb every part of this guide before implementing a new connector. ## Requirements for quality connectors @@ -51,7 +51,7 @@ Regardless of the used API technology, there’s probably a mature client librar ## Implementing the connector -You should treat a connector implementation process as a full-fledged Node.js project. Refer to the [Caliper integration](https://hyperledger.github.io/caliper/v0.6.0/reference/writing-connectors/#integration-with-caliper) section for the suggested project structure. Putting the project structure aside, you have four implementation-related tasks: +You should treat a connector implementation process as a full-fledged Node.js project. Refer to the [Caliper integration](#integration-with-caliper) section for the suggested project structure. Putting the project structure aside, you have four implementation-related tasks: 1. Implement the connector interface (optionally using the available utility base class). 2. Implement a factory method for instantiating the connector. @@ -79,7 +79,7 @@ module.exports = ConnectorInterface; The interface is detailed in the next subsection, but for now, keep the following things in mind: -1. The connector is used in two [different environments](https://hyperledger.github.io/caliper/v0.6.0/architecture/#caliper-processes): in the manager and worker processes. The corresponding environment of the methods will be discussed in the interface reference subsection. +1. The connector is used in two [different environments](../getting-started/architecture.md#caliper-processes): in the manager and worker processes. The corresponding environment of the methods will be discussed in the interface reference subsection. 2. The connector must expose certain [events](https://nodejs.org/docs/latest-v10.x/api/events.html) about the requests, otherwise it’s not observable by the Caliper workers, which breaks the scheduling mechanism of Caliper. 3. `sendRequests` is the hot path for the interface, implement it carefully and efficiently! 4. The behavior of the connector (and the methods to really implement) largely depends on the capabilities of the network configuration schema. The more flexibility you allow on the Caliper-side of the network, the more features you will have to provide. A flexible connector makes it easier to setup benchmark scenarios, resulting in happy users. @@ -211,7 +211,7 @@ The following is a possible implementation of a factory method for our `fast-led ### The network configuration file -The [network configuration file](https://hyperledger.github.io/caliper/v0.6.0/overview/architecture/#network-configuration-file) can contain whatever information your connector requires to communicate with the SUT and fulfill the connector [quality requirements](https://hyperledger.github.io/caliper/v0.6.0/reference/writing-connectors/#requirements-for-quality-connectors). The configuration file can be either a JSON or YAML file. YAML is preferred for its readability and comment support. +The [network configuration file](../getting-started/architecture.md#network-configuration-file) can contain whatever information your connector requires to communicate with the SUT and fulfill the connector [quality requirements](#requirements-for-quality-connectors). The configuration file can be either a JSON or YAML file. YAML is preferred for its readability and comment support. The network configuration schema must contain a mandatory top-level field with the following structure: @@ -226,11 +226,11 @@ caliper: end: stopLedger.sh ``` -The `caliper.blockchain` attribute tells Caliper which connector to load for the test. The value of the attribute depends on how you want to [integrate the connector with Caliper](https://hyperledger.github.io/caliper/v0.6.0/reference/writing-connectors/#integration-with-caliper). +The `caliper.blockchain` attribute tells Caliper which connector to load for the test. The value of the attribute depends on how you want to [integrate the connector with Caliper](#integration-with-caliper). ## Binding configuration -The [binding](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/#the-bind-command) command of Caliper allows you to specify major connector dependencies to be installed during runtime (instead of packaged with the connector during development time). SUT SDKs and other client libraries usually fall into this category (i.e., libraries that facilitate interactions with the SUT). If the APIs of such libraries are consistent across different versions, then your single connector implementation can possibly target multiple SUT versions. +The [binding](../getting-started/installing-caliper.md/#the-bind-command) command of Caliper allows you to specify major connector dependencies to be installed during runtime (instead of packaged with the connector during development time). SUT SDKs and other client libraries usually fall into this category (i.e., libraries that facilitate interactions with the SUT). If the APIs of such libraries are consistent across different versions, then your single connector implementation can possibly target multiple SUT versions. In that case, users should be able to select a specific SDK version that will target the corresponding SUT version. You can achieve this by providing a binding configuration file (JSON or YAML) for your connector. @@ -287,7 +287,7 @@ Your connector can use such advanced specification to provide support for a wide ## Documenting the connector -Providing proper user manual for your connector is just as important as a quality implementation. Otherwise, users will have a hard time interacting with your connector. We will take the [Fabric connector documentation](https://hyperledger.github.io/caliper/v0.6.0/reference/writing-connectors/Fabric_Configuration.md) as an example, section by section. +Providing proper user manual for your connector is just as important as a quality implementation. Otherwise, users will have a hard time interacting with your connector. We will take the [Fabric connector documentation](fabric-config.md) as an example, section by section. ### Overview @@ -306,13 +306,13 @@ However, it can happen that not every SUT feature is supported by every binding. ### Runtime settings -The network configuration file only describes the SUT topology and related artifacts. SUT-agnostic design choices can still arise during the development of a connector. Instead of deciding yourself, you should delegate such choices to the end users utilizing the [runtime configuration mechanism](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/) of Caliper where possible/meaningful. +The network configuration file only describes the SUT topology and related artifacts. SUT-agnostic design choices can still arise during the development of a connector. Instead of deciding yourself, you should delegate such choices to the end users utilizing the [runtime configuration mechanism](../concepts/runtime-config.md) of Caliper where possible/meaningful. Such settings typically affect the operating mode of the connector, but don’t change the overall semantics of the SUT interactions. Be sure to document every available runtime setting for your connector! Also, don’t forget to provide sensible defaults to these settings where possible. ### Request API -The main users of your connector will be workload module developers. They will interact with your connector mainly through the `[sendRequests](https://hyperledger.github.io/caliper/v0.6.0/reference/writing-connectors/#interface-reference)` method. The method accepts either a single, or multiple settings object relating to the requests the user wants to send. You have to precisely specify what kind of settings are available for a request. These will typically include: +The main users of your connector will be workload module developers. They will interact with your connector mainly through the `[sendRequests](#interface-reference)` method. The method accepts either a single, or multiple settings object relating to the requests the user wants to send. You have to precisely specify what kind of settings are available for a request. These will typically include: - The operation to execute on the SUT. - The arguments of the operation. @@ -393,4 +393,4 @@ const BuiltinConnectors = new Map([ ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/getting-started/architecture.md b/docs/source/getting-started/architecture.md index 77ab380c6..d787baa95 100644 --- a/docs/source/getting-started/architecture.md +++ b/docs/source/getting-started/architecture.md @@ -20,15 +20,15 @@ You can consider this file as the “flow orchestrator” of the benchmark. For !!! note - *For a more technical introduction to the benchmark configuration file, see the [corresponding page](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/).* + *For a more technical introduction to the benchmark configuration file, see the [corresponding page](../concepts/bench-config.md).* ### Network configuration file The content of the network configuration file is SUT-specific. The file usually describes the topology of the SUT, where its nodes are (their endpoint addresses), what identities/clients are present in the network, and what smart contracts Caliper should deploy or interact with. For the exact structure of the network configuration files, refer to the corresponding SUT connector documentations (we will discuss connectors a bit later on this page): -- [Hyperledger Besu & Ethereum](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/ethereum-config/) -- [Hyperledger Fabric](https://hyperledger.github.io/caliper/v0.6.0/connector-configuration/fabric-config.md) +- [Hyperledger Besu & Ethereum](../connectors/ethereum-config.md) +- [Hyperledger Fabric](../connectors/fabric-config.md) ### Workload modules @@ -38,14 +38,14 @@ Workload modules are simply Node.JS modules that must export a given factory fun !!! note - *For a more technical introduction to the benchmark configuration file, see the [corresponding page](https://hyperledger.github.io/caliper/v0.6.0/overview/workload-module/).* + *For a more technical introduction to the benchmark configuration file, see the [corresponding page](../concepts/workload-module.md).* ### Benchmark artifacts There might be additional artifacts necessary to run a benchmark that can vary between different benchmarks and runs. These usually include the followings: - Crypto materials necessary to interact with the SUT. - Smart contract source code for Caliper to deploy (if the SUT connector supports such operation). -- [Runtime configuration](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/) files. +- [Runtime configuration](../concepts/runtime-config.md) files. - Pre-installed third party packages for your workload modules. Refer to the SUT connector configuration pages for the additional necessary artifacts. @@ -61,7 +61,7 @@ A SUT connector provides a simplified interface towards internal Caliper modules !!! note - *For the technical details of how to implement a connector, refer to the [corresponding page](https://hyperledger.github.io/caliper/v0.6.0/reference/writing-connectors/).* + *For the technical details of how to implement a connector, refer to the [corresponding page](../connectors/writing-connectors.md).* ## Caliper processes Caliper considers scalability one of its most important goals (besides extensibility/flexibility). Workload generation from a single machine can quickly reach the resource limitations of the machine. If we want the workload rate to match the scalability and performance characteristics of the evaluated SUT then we need a distributed approach! @@ -94,9 +94,9 @@ The Caliper manager process is the orchestrator of the entire benchmark run. It 4. In the fourth stage Caliper schedules and executes the configured rounds through the worker processes. This is the stage where the workload generation happens (through the workers!). 5. In the last stage, after executing the rounds and generating the report, Caliper executes the cleanup script (if present) from the network configuration file. This step is mainly useful for local Caliper and SUT deployments as it provides a convenient way to tear down the network and any temporary artifacts. -If your SUT is already deployed an initialized, then you only need Caliper to execute the rounds and nothing else. Luckily, you can configure every stage one-by-one whether it should be executed or not. See the [flow control settings](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#benchmark-phase-settings) for details. +If your SUT is already deployed an initialized, then you only need Caliper to execute the rounds and nothing else. Luckily, you can configure every stage one-by-one whether it should be executed or not. See the [flow control settings](../concepts/runtime-config.md#benchmark-phase-settings) for details. -The above figure only shows the high-level steps of executing a benchmark. Some components are omitted for the sake of simplicity, like the resource and transaction monitor components. To learn more about the purpose and configuration of these components, refer to the [Resource and Transaction Monitors](https://hyperledger.github.io/caliper/v0.6.0/reference/caliper-monitors/) documentation page. +The above figure only shows the high-level steps of executing a benchmark. Some components are omitted for the sake of simplicity, like the resource and transaction monitor components. To learn more about the purpose and configuration of these components, refer to the [Resource and Transaction Monitors](../concepts/caliper-monitors.md) documentation page. ### The worker process The interesting things (from a user perspective) happen inside the worker processes. A worker process starts its noteworthy tasks when the manager process sends a message to it about executing the next round (the 4th step in the previous section). The important components of a worker process are shown in the figure below. @@ -108,14 +108,14 @@ The worker process spends most of its time in the workload generation loop. The 1. Waiting for the rate controller to enable the next TX. Think of the rate controller as a delay circuit. Based on what kind of rate controller is used, it delays/halts the execution of the worker (in an asynchronous manner) before enabling the next TX. For example, if a fixed 50 TXs per second (TPS) rate is configured, the rate controller will halt for 20ms between each TX. !!!note - *The rate controllers of each round can be configured in the [benchmark configuration file](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/). For the available rate controllers, see the [Rate Controllers](https://hyperledger.github.io/caliper/v0.6.0/reference/rate-controllers/) page.* + *The rate controllers of each round can be configured in the [benchmark configuration file](../concepts/bench-config.md). For the available rate controllers, see the [Rate Controllers](../concepts/rate-controllers.md) page.* 2. Once the rate controller enables the next TX, the worker gives control to the workload module. The workload module assembles the parameters of the TX (specific to the SUT and smart contract API) and calls the simple API of the SUT connector that will, in turn, send the TX request to the SUT (probably using the SDK of the SUT). !!!note - *The workload modules of each round can be configured in the [benchmark configuration file](https://hyperledger.github.io/caliper/v0.6.0/overview/bench-config/). For the technical details of workload modules, see the [Workload Modules](https://hyperledger.github.io/caliper/v0.6.0/reference/workload-module/) page.* + *The workload modules of each round can be configured in the [benchmark configuration file](../concepts/bench-config.md). For the technical details of workload modules, see the [Workload Modules](../concepts/workload-module.md) page.* -During the workload loop, the worker process sends progress updates to the manager process. Progress reporting on the manager side can be enabled and configured with the `caliper-progress-reporting-enabled and caliper-progress-reporting-interval` setting keys. For details, see the [Basic Runtime Settings](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/#basic-settings). +During the workload loop, the worker process sends progress updates to the manager process. Progress reporting on the manager side can be enabled and configured with the `caliper-progress-reporting-enabled and caliper-progress-reporting-interval` setting keys. For details, see the [Basic Runtime Settings](../concepts/runtime-config.md/#basic-settings). ## Process distribution models The last part of the architecture discussion is demystifying the worker process management. Based on how worker processes are started and what messaging method is used between the manager and worker processes, we can distinguish the following distribution/deployment models: @@ -150,10 +150,10 @@ The following table summarizes the different models and how to select them: !!! note - *For the technical details on configuration the messaging transport, see the [Messengers](https://hyperledger.github.io/caliper/v0.6.0/reference/caliper-messengers/) page.* + *For the technical details on configuration the messaging transport, see the [Messengers](../concepts//caliper-messengers.md) page.* ### Interprocess communication -The examples on the [Install & Usage](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/) page all use the IPC approach since it is the default behavior. The setup is illustrated in the figure below. +The examples on the [Install & Usage](../getting-started/installing-caliper.md) page all use the IPC approach since it is the default behavior. The setup is illustrated in the figure below. The `caliper launch manager` CLI command starts the manager process, which in turn will automatically spawn the configured number of worker processes (using the `caliper launch worker` CLI command). The communication between the processes is IPC, utilizing the built-in Node.JS method available for the parent-children process relationships. @@ -177,7 +177,7 @@ When you take the management of the worker processes into your own hands, that ![Remote MQTT](../_static/arch_remote_mqtt.png) -The fully distributed deployment enables the horizontal scaling of the worker processes, greatly increasing the achievable workload rate. To ease the management of the many Caliper processes, you will probably utilize some automatic deployment/management solution, like Docker Swarm or Kubernetes. Luckily, the flexibility of the [Caliper Docker image](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/#using-the-docker-image) makes such integration painless. +The fully distributed deployment enables the horizontal scaling of the worker processes, greatly increasing the achievable workload rate. To ease the management of the many Caliper processes, you will probably utilize some automatic deployment/management solution, like Docker Swarm or Kubernetes. Luckily, the flexibility of the [Caliper Docker image](../getting-started/installing-caliper.md#using-the-docker-image) makes such integration painless. However, there are some caveats you have to keep in mind: @@ -187,4 +187,4 @@ However, there are some caveats you have to keep in mind: ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/getting-started/contributing.md b/docs/source/getting-started/contributing.md index a1a7b7798..1f69be87b 100644 --- a/docs/source/getting-started/contributing.md +++ b/docs/source/getting-started/contributing.md @@ -2,6 +2,109 @@ Welcome to Hyperledger Caliper project, we are excited about the prospect of you contributing. +This guideline intends to make contribtuions to Caliper easier by: + +* presenting a simple development workflow for contributors to follow; +* and providing a high-level description of the repository components. + +If you have further suggestions about improving the guideline, then you can follow the presented workflow to make your contribution. + +## Overview + +The project uses GitHub to manage [issues](https://github.com/hyperledger/caliper/issues) (bug reports and feature requests) and [contributions](https://github.com/hyperledger/caliper/pulls) (in the form of pull requests). + +> For general queries and discussion, please use the [#caliper](https://discord.com/channels/905194001349627914/941417677778473031) channel on the Hyperledger Discord Server (Discord Id required) or the Caliper [mailing list](https://lists.hyperledger.org/g/caliper) (LFID recommended). + +The contribution process boils down to two major steps: opening an issue and submitting a pull request (PR). Opening issues before PRs serves the following purposes: + +* Documenting bugs, related error logs, potential fixes, and/or workarounds that users can find using their favorite search engine. +* Providing a forum for discussions where both contributors and users can weigh in about new features and their potential design. +* Enabling easy traceability of contributions through the "Commit → PR → Issue" reference chain. + +Opening issues can be omitted only in the case of trivial and small fixes (e.g., typo fixes, simple documentation enhancements, etc.). + +## Opening Issues + +Before opening an issue, make sure that: + +1. You read the documentation carefully, so the observed error does not stem from incorrect Caliper configuration or usage. +2. You searched older issues (or other forums) for your question, maybe it is already answered/fixed. +3. It is worth to ask around on Discord, maybe other users already encountered your issue/task, and managed to solve it. + +> When opening an issue about a potential bug or feature request, make sure to properly fill and format the issue contents! + +Choose the **issue template** that suits your intent (bug report or feature request), then fill out the form as best as you can. + +If you find the available issue templates too constraining, then you can still use the "blank" issue template for now (it will be deprecated in the future), and also let us know how we can improve the issue templates. + +The details of the blank template should be filled according to the following guideline: + +1. **Issue title**: Should be a concise sentence summarising the details below, including which component or part of the benchmarking process is affected. For example: `Fabric contract deployment silently fails in generator CI test` +2. **Context**: A detailed description of the context of the issue. Should include information about, for example, how you encountered the issue, what were you trying to achieve, why you consider this a bug, and how it affected your work with Caliper? +3. **Expected Behavior**: What was your expected outcome/behavior of the Caliper run? +4. **Actual Behavior**: What was your actually observered outcome/behaviour instead of the expected one? +5. **Possible Fix**: If you have already identified the source of the issue, you can also propose a possible fix for it. It does not necessarily have to be a working code, some general steps/ideas of a fix is also appreciated. +6. **Steps to Reproduce**: This is perhaps the most important part of an issue. Since Caliper is highly configurable and can interact with multiple SUTs, it is crucial for the maintainers to know the exact steps to reproduce an issue. Always try to provide (or just describe) a *minimal working example (MWE)* that can reproduce the issue. Also, please attach the following information to the issues whenever possible (preferably using collapsable code blocks or GitHub gists): + * The benchmark configuration file content. + * The network configuration file content. + * The workload module implementation. + * The exact error logs (and their surroundings). + * Any other information you deem neccessary. +7. **Existing Issues**: You can also provide links to similar (or the same) issues in other forums (GitHub issues, StackOverflow questions or Discord messages). Such cross-linking can help us ensure that we can broadcast the potential fixes to multiple instances of the question. +8. **Your Environment**: Always include your execution environment information, including the used version/commit of Caliper, the operating system, Node.JS version, or any relevant information about your project that uses Caliper. + +## Submitting Pull Requests + +### Basic workflow + +The following workflow should make your contribution process clean and straighforward (some deviations might be neccessary in exceptional cases): + +> The following list assumes that you use the `git` command line tool. IDEs and graphical git tools should also expose the same commands if you prefer those. + +1. Fork the Caliper repository. This needs to be done only once. +2. Clone the fork repository to your local machine (ideally done once): + * Using the `HTTPS` method: `git clone https://github.com//caliper.git` + * or using the `SSH` method: `git clone git@github.com:/caliper.git` +3. Add the upstream/original Caliper repository as a remote, using the name `upstream` (ideally done once). This will allow you to easily sync your fork with the original repository. + * `git remote add upstream https://github.com/hyperledger/caliper.git` + +> The following steps follow the "feature branch" development practice, and should be performed for each of your contribution: + +4. Checkout your `main` branch that will be the starting point/state of your contribution. + * `git checkout main` + * or `git checkout -b main` if the branch does not exist locally (only during your first checkout) +5. Retrieve the new updates from the `upstream` Caliper repository + * `git fetch upstream` (downloads the updates locally) + * then `git rebase upstream/main` ("adds" the updates to your local `main` brach) + > This step is crucial to ensure that you always contribute based on the latest Caliper version, minimizing the chance of version control conflicts! +6. (Optional) Push your updated `main` branch to your remote repository just to keep things in sync + * `git push` +7. Create a new feature branch (named `my-bug-fix`) from the updated `main` branch: + * `git checkout -b my-bug-fix` + * then `git push --set-upstream origin my-bug-fix` to push the new branch to your remote repository +8. Implement and test your contribution + * The `.build/checks-and-unit-tests.sh` script runs the basic tests for the repository + * The `BENCHMARK= .build/benchmark-integration-test-direct.sh` script can run one of the CI integration tests, depending on the value of ``: + * `BESU` + * `ETHEREUM` + * `FABRIC` + * `GENERATOR` + > Make sure that the tests pass locally before pushing your changes and opening a PR! +9. Commit your changes to your local feature branch, **adding the DCO sign-off**: + * `git commit -s -m "Commit message"` + * or `git commit -s` (without the `-m` parameter) to make git open up the configured text editor where you can write a detailed, multi-line commit message: + * The first line is a concise description of the commit (its purpose, what does it fix, etc). + * After a blank line, you can go into details about the changes of the commit. +10. Push your changes to your remote branch: + * `git push` +11. Open a PR using the GitHub webpage. + +### Updating PRs + +It is possible that the maintainers/reviewers request some changes before your PR can be merged. In that case, just add your changes to your feature branch using a new signed commit (based on the above workflow), then push it to your remote branch. The PR will automatically pick up the new commit. + +> The maintainers can/will squash commits before merging to keep a simpler commit history for the project. + ## How to contribute We are using GitHub issues for bug reports and feature requests. @@ -16,10 +119,14 @@ All PRs must be signed before be merged, be sure to use `git commit -s` to commi If a PR is reviewed and changes are requested then please do not force push the changes, push the changes into a new commit, this makes it easier to see the changes between the previously reviewed code and the new changes. -We use Azure pipelines to test the build - please test on your local branch before raising a PR. +We use Github Actions to test the build - please test on your local branch before raising a PR. There is also [Discord](https://discord.com/channels/905194001349627914/941417677778473031) with a Caliper channel for communication, anybody is welcome to join. +## Caliper Components + +The project is maintained as a Node.js monorepository. Accordingly, it can seem overwhelming at first to navigate its content. The following sections list and introduce the main components of the repository. + ## Installing the Caliper code base !!! note @@ -28,10 +135,10 @@ There is also [Discord](https://discord.com/channels/905194001349627914/94141767 The workflow of modifying the Caliper code-base usually consists of the following steps: -1. [Bootstrapping the repository](https://hyperledger.github.io/caliper/v0.6.0/general/contributing/#bootstrapping-the-caliper-repository) -2. [Modifying and testing the code](https://hyperledger.github.io/caliper/v0.6.0/general/contributing/#testing-the-code) -3. [Publishing package changes locally](https://hyperledger.github.io/caliper/v0.6.0/general/contributing/#publishing-to-local-npm-repository) -4. [Building the Docker image](https://hyperledger.github.io/caliper/v0.6.0/general/contributing/#building-the-docker-image) +1. [Bootstrapping the repository](#bootstrapping-the-caliper-repository) +2. [Modifying and testing the code](#testing-the-code) +3. [Publishing package changes locally](#publishing-to-local-npm-repository) +4. [Building the Docker image](#building-the-docker-image) ### Bootstrapping the Caliper repository @@ -50,6 +157,73 @@ user@ubuntu:~/caliper$ ./.build/check-prerequisites.sh && npm ci *do not run any of the above commands with `sudo`, as it will cause the bootstrap process to fail.* +### Public/published packages + +The [https://github.com/hyperledger/caliper/tree/main/packages/](packages/) directory contains the following public/published packages: + +* [caliper-cli](https://github.com/hyperledger/caliper/tree/main/packages/caliper-cli/): The command line interface (CLI) of Caliper. +* [caliper-core](https://github.com/hyperledger/caliper/tree/main/packages/caliper-core/): The core and common codebase of Caliper, used by the other packages. +* [caliper-ethereum](https://github.com/hyperledger/caliper/tree/main/packages/caliper-ethereum/): The Ethereum and Hyperledger Besu connector implementation. +* [caliper-fabric](https://github.com/hyperledger/caliper/tree/main/packages/caliper-fabric/): The Hyperledger Fabric connector implementation. +* [generator-caliper](https://github.com/hyperledger/caliper/tree/main/packages/generator-caliper/): The Yeaoman generator for Caliper configuration files. + +### Internal packages + +The [https://github.com/hyperledger/caliper/tree/main/packages/](packages/) directory contains the following internal packages: + +* [caliper-publish](https://github.com/hyperledger/caliper/tree/main/packages/caliper-publish/): Utility CLI for publishing Caliper to NPM and DockerHub. +* [caliper-tests-integration](https://github.com/hyperledger/caliper/tree/main/packages/caliper-tests-integration/): Collection of CI integration tests. + +## Testing Methodologies + +This section outlines the testing methodologies that this project follows, including both unit-level and integration-level testing. + +### Unit Level Testing + +Unit testing focuses on testing individual packages in isolation. The tests are typically located within a test folder at the same level as the corresponding lib folder, mirroring the structure of the lib folder for easy navigation. This setup ensures that each component of the code is verified independently, confirming that it behaves as expected without interference from other parts of the system. + +#### Unit Testing Dependencies and Their Use + +The following are the recommended testing modules for this project. While these tools are commonly used in the current codebase, other appropriate tools may be used as long as they facilitate effective testing. + +* [mockery](https://www.npmjs.com/package/mockery): Mockery is a simple module for mocking Node.js modules during testing. It allows you to replace real modules with mocks or stubs. + +* [mocha](https://mochajs.org/): Mocha is a feature-rich JavaScript test framework that runs on Node.js and in the browser. It facilitates asynchronous testing, making it easy to write simple and flexible tests. + +* [chai](https://www.npmjs.com/package/chai): Chai is a BDD/TDD assertion library for Node.js and the browser. It can be paired with any JavaScript testing framework. We use it to create readable and expressive assertions. + +* [sinon](https://sinonjs.org/releases/v18/): Sinon is a standalone test spies, stubs, and mocks for JavaScript. It works with any test framework and integrates well with Mocha and Chai. We utilize Sinon for checking how functions are called during testing. + +* [sinon-chai](https://www.npmjs.com/package/sinon-chai): This library provides a set of custom assertions for using Sinon with Chai. It allows you to write more readable assertions for Sinon spies, stubs, and mocks. + +* [nyc](https://www.npmjs.com/package/nyc): NYC is a command-line utility for generating code coverage reports. It is often used with Mocha to ensure that tests cover as much code as possible. + +#### Mandatory Tools in the Testing Pipeline + +In addition to the testing frameworks, the following tools are mandatory for all testing pipelines: + +* [eslint](https://eslint.org/): ESLint is a static code analysis tool for identifying problematic patterns in JavaScript code. It is essential for maintaining code quality. +* [license-check-and-add](https://www.npmjs.com/package/license-check-and-add): This tool ensures that all files in the codebase contain the required license headers. It is mandatory for all code submissions. + +#### Points to Note for Adding a Conforming Unit Test + +When writing unit tests, the following structure and practices are mandatory: + +1. **License Header**: All test files must include the project's license header. +2. **'use strict' Directive**: Ensure strict mode is enabled in all test files. +3. **Test Organization**: + * Use `describe` blocks to group related test cases. + * Use `it` statements for individual test cases. + * Nested `describe` blocks are encouraged for organizing complex test scenarios. +4. **Consistent Test Naming**: Test descriptions should flow naturally, making it clear what behavior is being tested (e.g., 'should return the correct value when input is valid'). +5. **Mocking Guidance**: Be cautious with mocks that persist across tests. Always clean up after each test to avoid unexpected behavior. +6. **Test Patterns**: Refer to the Fabric Unit tests for examples of recommended patterns and best practices. +7. **Final Checks**: Always run all unit tests before submitting a PR and ensure no `.only` is left in the code, which would skip other tests. + +### Integration Level Testing + +Integration testing ensures that Caliper integrates correctly with various packages, effectively testing the functionality of the package itself. These tests are organized within the caliper-tests-integration folder, with each test suite dedicated to a specific package or module. + ### Testing the code Caliper has both unit tests and integration tests. @@ -75,6 +249,12 @@ user@ubuntu:~/caliper$ node ./packages/caliper-cli/caliper.js launch manager \ --caliper-networkconfig networks/fabric/test-network.yaml ``` +## Creating New SUT Connectors + +Connectors are relatively heavy components in Caliper. Before you attempt to create a new connector for a new SUT type, consult with the Caliper maintainers (on Discord, or in the form of a feature request). + +> More importantly, make sure that you are overly familiar with the documentation page about [implementing new connectors](../connectors/writing-connectors.md). + ### Publishing to local NPM repository The NPM publishing and installing steps for the modified code-base can be tested through a local NPM proxy server, Verdaccio. The steps to perform are the following: diff --git a/docs/source/getting-started/faq.md b/docs/source/getting-started/faq.md index beb0628c4..57f30d107 100644 --- a/docs/source/getting-started/faq.md +++ b/docs/source/getting-started/faq.md @@ -3,7 +3,7 @@ ## **I. Environment, Platform & Version** **Q:** How do I run Caliper to test a blockchain system? -**A:** Details for setting up Caliper to run benchmark tests on a blockchain system are provided in the [Getting Started](https://hyperledger.github.io/caliper/v0.6.0/overview/getting-started/) page of the site. When you run Caliper to test a blockchain network, you may encounter some errors. If so, first you should check the version of tools, SDKs and modules to make sure it is right. +**A:** Details for setting up Caliper to run benchmark tests on a blockchain system are provided in the [Getting Started](../index.md) page of the site. When you run Caliper to test a blockchain network, you may encounter some errors. If so, first you should check the version of tools, SDKs and modules to make sure it is right. ## **II. Configuration Files of Caliper** @@ -18,7 +18,7 @@ There is another configuration file, namely `./config/default.yaml`, containing **A:** Now you can use Caliper to test Besu, Ethereum and Fabric. **Q:** How can I test a blockchain system that Caliper does not support currently? -**A:** If you want to test the blockchain system that Caliper does not support now, you must write your own blockchain adapter that Caliper can use to inferface with the backend network. For details, you can refer to the [Writing Adapters](https://hyperledger.github.io/caliper/v0.6.0/caliper-faq/reference/writing-connectors/) page. The Caliper-specific configurations remain unchanged. Take a look at the provided adapter implementations and example networks to gather some best-practices. +**A:** If you want to test the blockchain system that Caliper does not support now, you must write your own blockchain adapter that Caliper can use to inferface with the backend network. For details, you can refer to the [Writing Adapters](../connectors/writing-connectors.md) page. The Caliper-specific configurations remain unchanged. Take a look at the provided adapter implementations and example networks to gather some best-practices. ## **IV. Other Questions Related to Caliper** diff --git a/docs/source/getting-started/installing-caliper.md b/docs/source/getting-started/installing-caliper.md index d816af0d3..d82bd6375 100644 --- a/docs/source/getting-started/installing-caliper.md +++ b/docs/source/getting-started/installing-caliper.md @@ -2,7 +2,7 @@ ## Overview -Caliper is published as the [@hyperledger/caliper-cli](https://www.npmjs.com/package/@hyperledger/caliper-cli) NPM package and the [hyperledger/caliper](https://hub.docker.com/r/hyperledger/caliper) Docker image, both containing the CLI binary. Refer to the [Installing from NPM](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/#installing-from-npm) and [Using the Docker image](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/#using-the-docker-image) sections for the available versions and their intricacies. +Caliper is published as the [@hyperledger/caliper-cli](https://www.npmjs.com/package/@hyperledger/caliper-cli) NPM package and the [hyperledger/caliper](https://hub.docker.com/r/hyperledger/caliper) Docker image, both containing the CLI binary. Refer to the [Installing from NPM](#installing-from-npm) and [Using the Docker image](#using-the-docker-image) sections for the available versions and their intricacies. Installing and running Caliper consists of the following steps, thoroughly detailed by the remaining sections: @@ -34,7 +34,7 @@ Unless you are embedding the Caliper packages in your own application, you will !!! note - *The following examples assume a locally installed CLI in the `~/caliper-benchmarks` directory, hence the `npx` call before the `caliper` binary. Refer to the [Local NPM install](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/#local-npm-install) section for the specifics.* + *The following examples assume a locally installed CLI in the `~/caliper-benchmarks` directory, hence the `npx` call before the `caliper` binary. Refer to the [Local NPM install](#local-npm-install) section for the specifics.* The entry point of the CLI is the `caliper` binary. You can confirm whether the CLI is installed correctly by checking its version: @@ -71,7 +71,7 @@ You can also request the help page of a specific command, as demonstrated by the !!! note - *the command options can be set either through the command line, or from various other sources supported by the [configuration mechanism](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/) of Caliper. This flexibility makes it easy to embed the CLI in different environments.* + *the command options can be set either through the command line, or from various other sources supported by the [configuration mechanism](../concepts/runtime-config.md) of Caliper. This flexibility makes it easy to embed the CLI in different environments.* ### The bind command @@ -110,7 +110,7 @@ The following SUT name and SDK version combinations are supported: The `bind` command is useful when you plan to run multiple benchmarks against the same SUT version. Bind once, then run different benchmarks without the need to bind again. As you will see in the next sections, the launcher commands for the manager and worker processes can also perform the binding step if the required parameter is present. #### Custom bindings -The built-in bindings can be overridden by setting the `caliper-bind-file` parameter to a YAML file path. The file must match the structure of the [default binding file](https://github.com/hyperledger/caliper/blob/main/packages/caliper-cli/lib/lib/config.yaml), documented [here](https://hyperledger.github.io/caliper/v0.6.0/reference/writing-connectors#binding-configuration). This way you can use experimental SDK versions that are not (yet) officially supported by Caliper. **This also means that we cannot provide help for such SDK versions!** +The built-in bindings can be overridden by setting the `caliper-bind-file` parameter to a YAML file path. The file must match the structure of the [default binding file](https://github.com/hyperledger/caliper/blob/main/packages/caliper-cli/lib/lib/config.yaml), documented [here](../connectors/writing-connectors.md#binding-configuration). This way you can use experimental SDK versions that are not (yet) officially supported by Caliper. **This also means that we cannot provide help for such SDK versions!** ### The unbind command @@ -205,7 +205,7 @@ Options: As you can see, you can configure the worker processes the same way as the manager process. Including the optional binding step, but also the three mandatory parameters mentioned in the previous section. #### Caliper test phase control -Caliper commands are capable of passing all [runtime configuration settings](https://hyperledger.github.io/caliper/v0.6.0/reference/runtime-config/). A subset of these commands are for flow control that provide direct control over the following Caliper phases: +Caliper commands are capable of passing all [runtime configuration settings](../concepts/runtime-config.md). A subset of these commands are for flow control that provide direct control over the following Caliper phases: - start - init @@ -345,7 +345,7 @@ Parts of starting a Caliper container (following the recommendations above): !!! note - *the **latest** tag is **not supported**, i.e, you explicitly have to specify the image version you want: hyperledger/caliper:0.6.0, similar to the recommended approach for the [NPM packages](https://hyperledger.github.io/caliper/v0.6.0/overview/installing-caliper/#versioning-semantics).* + *the **latest** tag is **not supported**, i.e, you explicitly have to specify the image version you want: hyperledger/caliper:0.6.0, similar to the recommended approach for the [NPM packages](#versioning-semantics).* Putting it all together, split into multiple lines for clarity, and naming the container `caliper`: @@ -390,4 +390,4 @@ docker-compose up ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/index.md b/docs/source/index.md index 016236bb9..e29eae69b 100644 --- a/docs/source/index.md +++ b/docs/source/index.md @@ -30,15 +30,13 @@ Head to the [Install & Usage page](getting-started/installing-caliper.md) if you ## Sample Networks Sample benchmarks that may be used by Caliper are hosted on a companion [GitHub repository](https://github.com/hyperledger/caliper-benchmarks). -Performance reports for the provided samples are hosted on the [documentation pages of the repository](https://hyperledger.github.io/caliper-benchmarks/). - !!! note "Important" *make sure that the version/tag of the benchmark repository matches the version of Caliper you are using! For example, if you are using Caliper v0.6.0, then `checkout` the `v0.6.0` tag after cloning the benchmark repository. The `main` branch of the benchmark repository corresponds to the latest `unstable` Caliper version.* ## How to Contribute -Every contribution is welcome! See the [Contributing](https://hyperledger.github.io/caliper/v0.6.0/contributing/) page for details. +Every contribution is welcome! See the [Contributing](getting-started/contributing.md) page for details. ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file diff --git a/docs/source/tutorial/fabric.md b/docs/source/tutorial/fabric.md index c11dde223..4d44ce279 100644 --- a/docs/source/tutorial/fabric.md +++ b/docs/source/tutorial/fabric.md @@ -515,4 +515,4 @@ You have successfully benchmarked a smart contract. You can repeat the test vary ## License -The Caliper codebase is released under the [Apache 2.0 license](https://hyperledger.github.io/caliper/v0.6.0/general/license/). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file +The Caliper codebase is released under the [Apache 2.0 license](../getting-started/license.md). Any documentation developed by the Caliper Project is licensed under the Creative Commons Attribution 4.0 International License. You may obtain a copy of the license, titled CC-BY-4.0, at [http://creativecommons.org/licenses/by/4.0/](http://creativecommons.org/licenses/by/4.0/). \ No newline at end of file