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.
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.
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
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.
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
.
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.
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.
The load generators defined so far:
faucet
: initialize by creating adapp-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).