From 1b81700785332c9bfc450d9021bbc26bbb9c63a2 Mon Sep 17 00:00:00 2001 From: Ranadeep Biswas Date: Wed, 13 Jul 2022 10:27:22 +0200 Subject: [PATCH 1/3] adr03 --- doc/src/adr03-atomkraft-init.md | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 doc/src/adr03-atomkraft-init.md diff --git a/doc/src/adr03-atomkraft-init.md b/doc/src/adr03-atomkraft-init.md new file mode 100644 index 0000000..c6deea9 --- /dev/null +++ b/doc/src/adr03-atomkraft-init.md @@ -0,0 +1,32 @@ +# ADR-03: Atomkraft init subcommand + +| authors | revision | revision date | +| --------------- | -------: | ------------: | +| Ranadeep Biswas | 1 | July 13, 2022 | + +## Status + +Proposed + +## Context + +We are figuring out how a user will use Atomkraft - produce tests, interact with test setup, and execute them. + +The idea is to provide an `atomkraft` cli, which initializes a [poetry](https://python-poetry.org) project with [pytest](https://docs.pytest.org) dependency and other necessary configurations. + +## Decision + +To set up an `atomkraft` project, + +- `atomkraft init BINARY DIR` is executed which sets up a poetry project at `DIR`. +- After changing the directory to `DIR`, a user should be able to execute some kick-the-tire tests (included in Atomkraft) for standard Cosmos-SDK modules right out of the box. +- The chain parameters can be queried/modified using `atomkraft chain config CONFIGFILE KEYPATH [VALUE]` +- A testnet can be started via `atomkraft chain up [-d]`. +- A testnet can be shut down via `atomkraft chain down`. + +## Summary + +- `atomkraft init` to initialize atomkraft project as a poetry project with python 3.10 and pytest dependency +- `atomkraft test-drive` to execute a set of standard Cosmos-SDK tests using provided chain binary. +- `atomkraft chain config CONFIGFILE KEYPATH [VALUE]` to update chain configuration. +- `atomkraft chain [up|down]` to control a testnet. From 78f5758434dd796813f23d4da98d5b8d8ccf1ce0 Mon Sep 17 00:00:00 2001 From: Ranadeep Biswas Date: Thu, 14 Jul 2022 13:09:47 +0200 Subject: [PATCH 2/3] reorder adr seq --- doc/src/{adr03-atomkraft-init.md => adr02-atomkraft-init.md} | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename doc/src/{adr03-atomkraft-init.md => adr02-atomkraft-init.md} (97%) diff --git a/doc/src/adr03-atomkraft-init.md b/doc/src/adr02-atomkraft-init.md similarity index 97% rename from doc/src/adr03-atomkraft-init.md rename to doc/src/adr02-atomkraft-init.md index c6deea9..6e72e87 100644 --- a/doc/src/adr03-atomkraft-init.md +++ b/doc/src/adr02-atomkraft-init.md @@ -1,4 +1,4 @@ -# ADR-03: Atomkraft init subcommand +# ADR-02: Atomkraft init subcommand | authors | revision | revision date | | --------------- | -------: | ------------: | From 4468821b5918547f8ea26ff9e6e0013629ef2568 Mon Sep 17 00:00:00 2001 From: Ranadeep Biswas Date: Mon, 18 Jul 2022 12:35:50 +0200 Subject: [PATCH 3/3] revision --- doc/src/adr02-atomkraft-init.md | 148 +++++++++++++++++++++++++++++--- 1 file changed, 135 insertions(+), 13 deletions(-) diff --git a/doc/src/adr02-atomkraft-init.md b/doc/src/adr02-atomkraft-init.md index 6e72e87..eb6b56d 100644 --- a/doc/src/adr02-atomkraft-init.md +++ b/doc/src/adr02-atomkraft-init.md @@ -2,7 +2,7 @@ | authors | revision | revision date | | --------------- | -------: | ------------: | -| Ranadeep Biswas | 1 | July 13, 2022 | +| Ranadeep Biswas | 2 | July 18, 2022 | ## Status @@ -14,19 +14,141 @@ We are figuring out how a user will use Atomkraft - produce tests, interact with The idea is to provide an `atomkraft` cli, which initializes a [poetry](https://python-poetry.org) project with [pytest](https://docs.pytest.org) dependency and other necessary configurations. -## Decision +## Summary -To set up an `atomkraft` project, +- Set up a poetry project at the current directory. +- Perform lightweight smoke tests right out of the box. +- Configure chain parameters via CLI. -- `atomkraft init BINARY DIR` is executed which sets up a poetry project at `DIR`. -- After changing the directory to `DIR`, a user should be able to execute some kick-the-tire tests (included in Atomkraft) for standard Cosmos-SDK modules right out of the box. -- The chain parameters can be queried/modified using `atomkraft chain config CONFIGFILE KEYPATH [VALUE]` -- A testnet can be started via `atomkraft chain up [-d]`. -- A testnet can be shut down via `atomkraft chain down`. +### `atomkraft init BINARY [TEST]...` -## Summary +This command is used to initialize an Atomkraft project in the current directory. +It uses [copier](https://pypi.org/project/copier) to copy a template and dynamically update project variables. + +#### Arguments + +- `BINARY` is path to Cosmos-SDK chain binary. + - "gaiad" + - "/opt/cosmos-chains/junod" +- `[TEST]...` is a list of provided lightweight tests that can be included in the project. + - "authz" + - "cosmwasm" + - "feegrant" + +#### Template directory structure + +``` +. +├── .atomkraft +│ └─── config.toml +├── atomkraft.toml +├── chain.toml +├── modelator.toml +├── models +├── reactors +│ ├─── authz.py +│ └─── cosmwasm.py +├── reports +├── tests +│ ├─── conftest.py +│ ├─── test_authz.py +│ └─── test_cosmwasm.py +└── traces +``` + +#### `.atomkraft/config.toml` + +Used to for any configuration local to current user. Example, last used reactor. + +#### `atomkraft.toml` + +This file is used for any top-level project configuration. + +- The lightweight tests are marked in `atomkraft.toml` file. + +##### Sample + +``` +[chain] +binary = "gaia" + +[modelator.apalache] +jar = "/path/to/apalache/jar" + +[tests] +lightweight = ["authz", "cosmwasm"] +``` + +#### `chain.toml` + +The chain config values are stored in `chain.toml` file. + +##### Sample + +``` +name = "cosmoshub" +prefix = "cosmos" +denom = "uatom" +coin = 118 + +[app] +"api.enable" = True +"api.swagger" = True +"api.enabled-unsafe-cors" = True +"minimum-gas-prices" = "0.10uatom" +"rosetta.enable" = False + +[config] +"instrumentation.prometheus" = False +"p2p.addr_book_strict" = False +"p2p.allow_duplicate_ip" = True + +[genesis] +"app_state.gov.voting_params.voting_period" = "600s" +"app_state.mint.minter.inflation" = "0.300000000000000000" +``` + +#### `modelator.toml` + +Configs for Modelator. + +##### Sample + +``` +[[models]] +model = "path/to/module.tla" +config = "path/to/module.cfg" +constants = {"N": 3, "FOO": "bar" } +invariants = ["Inv1", "Inv2"] +samples = ["Ex1", "Ex2"] +md_monitor = "path/to/monitor.md" +html_monitor = "path/to/monitor.html" +``` + +### `atomkraft chain config FILE KEY [VALUE]` + +This command can be used to query or update chain parameters. + +#### Arguments + +- `KEY` is a nested key. + - `coin` + - `"app.api.enable"` + - `"config.p2p.allow_duplicate_ip"` + - `"genesis.app_state.gov.voting_params.voting_period"` + +Note, `app`, `config` and `genesis` prefixes. They correspond to the usual `app.toml`, `config.toml`, and `genesis.json` files in a Cosmos-SDK chain node data directory. + +- `VALUE` is used to overwrite the current value. If it is skipped, the current value is printed. + +### `atomkraft chain test-drive` + +After running `atomkraft init` (with included tests) and `atomkraft chain config`, the project should be ready to perform some lightweight tests. + +`atomkraft chain test-drive` will run the light-weight tests using `reactors/*py` and `tests/test_*py`. + +## Future work -- `atomkraft init` to initialize atomkraft project as a poetry project with python 3.10 and pytest dependency -- `atomkraft test-drive` to execute a set of standard Cosmos-SDK tests using provided chain binary. -- `atomkraft chain config CONFIGFILE KEYPATH [VALUE]` to update chain configuration. -- `atomkraft chain [up|down]` to control a testnet. +- Spawn independent testnet via `atomkraft chain [up|down]`. +- Spawn blockchain explorer via `atomkraft chain explorer [up|down] [PORT]`. +- Spawn testnet with an explorer via `atomkraft chain --explorer [up|down]`.