/testnet-load-generator

A dapp that generates somewhat realistic loads for testnet

Primary LanguageJavaScriptApache License 2.0Apache-2.0

Load Generator

The loadgen is implemented as a dapp deploy script which runs forever and listens for config updates. It can perform 3 different type of load generating tasks at any given interval (cycle): faucet, amm, vault. Each task is deployed to a vat on the solo client. Additionally the faucet task installs a faucet app on the chain. When the loadgen server starts a task's cycle, it invokes the task's agent running on the solo client, which performs its load generation on the chain.

The loadgen accepts config updates from a local http port, or by connecting to a remote orchestration service.

For alternative usages of the loadgen, see the Extended Readme.

Setup

Since the loadgen is a dapp, it requires a local agoric-sdk to execute, and a running solo client provisioned and connected to a chain.

Prerequisite

Make sure you have the agoric-sdk with the correct revision built, with the agoric cli available in your PATH. Follow the steps in the Getting started documentation. You'll need to checkout the version of the SDK corresponding to the testnet .

git clone https://github.com/Agoric/agoric-sdk.git -b agorictest-17
git checkout

# Install and build Agoric Javascript packages
yarn install
yarn build

# Install and build Agoric Cosmos SDK support
(cd packages/cosmic-swingset && make)

yarn link-cli <agoric script location>

Clone the loadgen and cd into the directory. All following commands run from the loadgen folder.

git clone https://github.com/Agoric/testnet-load-generator.git
cd testnet-load-generator

Running client

To interact with the chain, a client must be running. With a local agoric-sdk available, the easiest to run a client for the testnet chain is directly using the following command:

agoric start testnet 8000 https://testnet.agoric.net/network-config

The above command stores the client's state in the current directory's _agstate/agoric-servers/testnet-8000. If for any reason you need to reset your client, you can delete that directory.

More information can be found in the agoric CLI reference.

Alternatively, you can run the client as a docker image.

Optional: Make client use a private RPC node

To avoid having the solo client, and by extension the loadgen, be impacted by load on public RPC nodes, it's preferable to initially configure the client to connect to a private RPC chain node. When running the solo client directly, the easiest is to start the client specifying a modified network-config.

wget https://testnet.agoric.net/network-config
vi network-config # add/replace rpcAddrs with the address of the local chain node as `"xxx.xxx.xxx.xxx:yyyyy"`
agoric start testnet 8000 $(pwd)/network-config

If you need to edit the rpcAddresses after the first start, you can modify _agstate/agoric-servers/testnet-8000/connections.json.

Setup and start the loadgen

The first time, you need to install the loadgen dependencies:

agoric install

After the client is started (Deployed Wallet! shown in the output), the loadgen can be started as well.

yarn loadgen

or directly using the agoric cli

agoric deploy loadgen/loop.js

See the deploy CLI reference for options like configuring the host/port of the client.

(Testnet) Link loadgen to remote orchestrator

The loadgen's config can be remotely controlled by an orchestration service (currently using Firebase).

To link the loadgen to the remote orchestrator, you need to provide authentication details. For the incentivized testnet, login to https://submit.agoric.app/, visit the Load Generator Key page, and follow the instructions.

Loadgen types

The load generators defined so far:

  • faucet: initialize by creating a dapp-fungible-faucet -style mint on the chain, then each cycle requests an invitation and completes it, adding 1000 Tokens to Bob's Purse. Takes 4 round-trips to complete.
  • amm: initialize by selling some (currently 33%) of the initial RUN to get a trade token, then record the balances. Each cycle sells 1% of the recorded trade token to get RUN, then sells 1% of the recorded RUN to get the trade token back. Because of fees, the total available will drop slowly over time.
  • vault: initialize by recording our collateral token balance and the collateral/RUN price. Each cycle deposits 1% of the recorded collateral balance and borrows half its value in RUN, then pays back the loan and recovers the collateral (less fees).