From c98a3fbfbc6da2d77e448219b35eb38488db01a9 Mon Sep 17 00:00:00 2001 From: Anmol1696 Date: Thu, 30 May 2024 19:16:31 +0530 Subject: [PATCH 1/3] add dym chain docker images --- starship/docker/chains/versions.yaml | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/starship/docker/chains/versions.yaml b/starship/docker/chains/versions.yaml index 73fc5553..a48e43bd 100644 --- a/starship/docker/chains/versions.yaml +++ b/starship/docker/chains/versions.yaml @@ -297,3 +297,8 @@ chains: - v0.13.1 - v0.13.0 - v0.12.0 + - name: dymension + base: ghcr.io/strangelove-ventures/heighliner/dymension + tags: + - v3.1.0 + - v3.0.0 From 6890989670c1ededf0bc465a33e2712f1160a047 Mon Sep 17 00:00:00 2001 From: Anmol1696 Date: Sun, 2 Jun 2024 15:55:43 +0530 Subject: [PATCH 2/3] initial support for dym chain in starshi --- starship/charts/devnet/defaults.yaml | 27 +++++++++++++++++++++++ starship/charts/devnet/values.schema.json | 3 ++- 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/starship/charts/devnet/defaults.yaml b/starship/charts/devnet/defaults.yaml index 242c268d..d3b403d9 100644 --- a/starship/charts/devnet/defaults.yaml +++ b/starship/charts/devnet/defaults.yaml @@ -669,6 +669,33 @@ defaultChains: exponent: 6 coingecko_id: inter-stable-token keywords: [ "inter-stable-token" ] + dymension: + image: ghcr.io/cosmology-tech/starship/dymension:v3.1.0 + home: /root/.dymension + binary: dymd + prefix: dym + denom: adym + prettyName: Dymension Hub + coins: 100000000000000000000000000adym + hdPath: m/44'/60'/0'/0/0 + coinType: 60 + repo: https://github.com/dymensionxyz/dymension + assets: + - base: adym + description: "The native governance and staking token of the Dymension Hub" + name: Dymension + display: dym + symbol: DYM + logo_URIs: + png: "https://raw.githubusercontent.com/cosmos/chain-registry/master/dymension/images/dymension-logo.png" + svg: "https://raw.githubusercontent.com/cosmos/chain-registry/master/dymension/images/dymension-logo.svg" + denom_units: + - denom: adym + exponent: 0 + - denom: dym + exponent: 18 + coingecko_id: dymension + keywords: [ "dymension" ] eth: storageClassName: hostpath genesisStateUrl: https://github.com/eth-clients/merge-testnets/blob/main/sepolia/genesis.ssz diff --git a/starship/charts/devnet/values.schema.json b/starship/charts/devnet/values.schema.json index 081fe4b7..12d26eaa 100644 --- a/starship/charts/devnet/values.schema.json +++ b/starship/charts/devnet/values.schema.json @@ -137,7 +137,8 @@ "polymer", "virtual", "akash", - "agoric" + "agoric", + "dymension" ] }, "numValidators": { From a318282ee82879cd9035d2cb2ab5e26f52b21eba Mon Sep 17 00:00:00 2001 From: Anmol1696 Date: Fri, 21 Jun 2024 13:23:24 +0530 Subject: [PATCH 3/3] start to create custom dymension starting up scripts --- clients/go/client/go.mod | 6 +- clients/go/client/go.sum | 5 + starship/charts/devnet/defaults.yaml | 5 + .../devnet/scripts/dymension/update-config.sh | 79 ++++++++++ .../scripts/dymension/update-genesis.sh | 136 ++++++++++++++++++ starship/tests/e2e/configs/dymension.yaml | 34 +++++ 6 files changed, 262 insertions(+), 3 deletions(-) create mode 100644 starship/charts/devnet/scripts/dymension/update-config.sh create mode 100644 starship/charts/devnet/scripts/dymension/update-genesis.sh create mode 100644 starship/tests/e2e/configs/dymension.yaml diff --git a/clients/go/client/go.mod b/clients/go/client/go.mod index 9bf25ac4..b18d4406 100644 --- a/clients/go/client/go.mod +++ b/clients/go/client/go.mod @@ -107,7 +107,7 @@ require ( github.com/jmespath/go-jmespath v0.4.0 // indirect github.com/jmhodges/levigo v1.0.0 // indirect github.com/json-iterator/go v1.1.12 // indirect - github.com/klauspost/compress v1.16.3 // indirect + github.com/klauspost/compress v1.16.7 // indirect github.com/lib/pq v1.10.7 // indirect github.com/libp2p/go-buffer-pool v0.1.0 // indirect github.com/magiconair/properties v1.8.7 // indirect @@ -128,7 +128,7 @@ require ( github.com/pkg/errors v0.9.1 // indirect github.com/pmezard/go-difflib v1.0.0 // indirect github.com/prometheus/client_golang v1.14.0 // indirect - github.com/prometheus/client_model v0.4.0 // indirect + github.com/prometheus/client_model v0.5.0 // indirect github.com/prometheus/common v0.40.0 // indirect github.com/prometheus/procfs v0.9.0 // indirect github.com/rakyll/statik v0.1.7 // indirect @@ -136,7 +136,7 @@ require ( github.com/rs/cors v1.8.3 // indirect github.com/rs/zerolog v1.28.0 // indirect github.com/sasha-s/go-deadlock v0.3.1 // indirect - github.com/spf13/afero v1.9.3 // indirect + github.com/spf13/afero v1.10.0 // indirect github.com/spf13/cast v1.5.0 // indirect github.com/spf13/cobra v1.6.1 // indirect github.com/spf13/jwalterweatherman v1.1.0 // indirect diff --git a/clients/go/client/go.sum b/clients/go/client/go.sum index fee84754..a89dc73d 100644 --- a/clients/go/client/go.sum +++ b/clients/go/client/go.sum @@ -721,6 +721,7 @@ github.com/klauspost/compress v1.12.3/go.mod h1:8dP1Hq4DHOhN9w426knH3Rhby4rFm6D8 github.com/klauspost/compress v1.15.11/go.mod h1:QPwzmACJjUTFsnSHH934V6woptycfrDDJnH7hvFVbGM= github.com/klauspost/compress v1.16.3 h1:XuJt9zzcnaz6a16/OU53ZjWp/v7/42WcR5t2a0PcNQY= github.com/klauspost/compress v1.16.3/go.mod h1:ntbaceVETuRiXiv4DpjP66DpAtAGkEQskQzEyD//IeE= +github.com/klauspost/compress v1.16.7/go.mod h1:ntbaceVETuRiXiv4DpjP66DpAtAGkEQskQzEyD//IeE= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/kr/fs v0.1.0/go.mod h1:FFnZGqtBN9Gxj7eW1uZ42v5BccTP0vu6NEaFoC2HwRg= @@ -878,6 +879,7 @@ github.com/prometheus/client_model v0.1.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6T github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= github.com/prometheus/client_model v0.4.0 h1:5lQXD3cAg1OXBf4Wq03gTrXHeaV0TQvGfUooCfx1yqY= github.com/prometheus/client_model v0.4.0/go.mod h1:oMQmHW1/JoDwqLtg57MGgP/Fb1CJEYF2imWWhWtMkYU= +github.com/prometheus/client_model v0.5.0/go.mod h1:dTiFglRmd66nLR9Pv9f0mZi7B7fk5Pm3gvsjB5tr+kI= github.com/prometheus/common v0.2.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4= github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4= github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA= @@ -937,6 +939,7 @@ github.com/spaolacci/murmur3 v1.1.0/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2 github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ= github.com/spf13/afero v1.9.3 h1:41FoI0fD7OR7mGcKE/aOiLkGreyf8ifIOQmJANWogMk= github.com/spf13/afero v1.9.3/go.mod h1:iUV7ddyEEZPO5gA3zD4fJt6iStLlL+Lg4m2cihcDf8Y= +github.com/spf13/afero v1.10.0/go.mod h1:UBogFpq8E9Hx+xc5CNTTEpTnuHVmXDwZcZcE1eb/UhQ= github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= github.com/spf13/cast v1.5.0 h1:rj3WzYc11XZaIZMPKmwP96zkFEnnAmV8s6XbB2aY32w= github.com/spf13/cast v1.5.0/go.mod h1:SpXXQ5YoyJw6s3/6cMTQuxvgRl3PCJiyaX9p6b155UU= @@ -1054,6 +1057,7 @@ golang.org/x/crypto v0.0.0-20200728195943-123391ffb6de/go.mod h1:LzIPMQfyMNhhGPh golang.org/x/crypto v0.0.0-20210421170649-83a5a9bb288b/go.mod h1:T9bdIzuCu7OtxOm1hfPfRQxPLYneinmdGuTeoZ9dtd4= golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= golang.org/x/crypto v0.0.0-20211108221036-ceb1ce70b4fa/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= +golang.org/x/crypto v0.0.0-20220722155217-630584e8d5aa/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= golang.org/x/crypto v0.14.0 h1:wBqGXzWJW6m1XrIKlAH0Hs1JJ7+9KBwnIO8v66Q9cHc= golang.org/x/crypto v0.14.0/go.mod h1:MVFd36DqK4CsrnJYDkBA3VC4m2GkXAM0PvzMCn4JQf4= golang.org/x/crypto v0.24.0/go.mod h1:Z1PMYSOR5nyMcyAVAIQSKCDwalqy85Aqn1x3Ws4L5DM= @@ -1147,6 +1151,7 @@ golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96b golang.org/x/net v0.0.0-20210428140749-89ef3d95e781/go.mod h1:OJAsFXCWl8Ukc7SiCT/9KSuxbyM7479/AVlXFRxuMCk= golang.org/x/net v0.0.0-20210503060351-7fd8e65b6420/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= golang.org/x/net v0.0.0-20210805182204-aaa1db679c0d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= +golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= golang.org/x/net v0.0.0-20220127200216-cd36cc0744dd/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= golang.org/x/net v0.0.0-20220225172249-27dd8689420f/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= golang.org/x/net v0.0.0-20220325170049-de3da57026de/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk= diff --git a/starship/charts/devnet/defaults.yaml b/starship/charts/devnet/defaults.yaml index 2a8ed89e..c50977b4 100644 --- a/starship/charts/devnet/defaults.yaml +++ b/starship/charts/devnet/defaults.yaml @@ -696,6 +696,11 @@ defaultChains: exponent: 18 coingecko_id: dymension keywords: [ "dymension" ] + scripts: + updateGenesis: + file: scripts/dymension/update-genesis.sh + updateConfig: + file: scripts/dymension/update-config.sh eth: storageClassName: hostpath genesisStateUrl: https://github.com/eth-clients/merge-testnets/blob/main/sepolia/genesis.ssz diff --git a/starship/charts/devnet/scripts/dymension/update-config.sh b/starship/charts/devnet/scripts/dymension/update-config.sh new file mode 100644 index 00000000..d01ca562 --- /dev/null +++ b/starship/charts/devnet/scripts/dymension/update-config.sh @@ -0,0 +1,79 @@ +#!/bin/bash + +CHAIN_ID="${CHAIN_ID:=osmosis}" +CHAIN_DIR="${CHAIN_DIR:=$HOME/.osmosisd}" +KEYS_CONFIG="${KEYS_CONFIG:=configs/keys.json}" + +set -eux + +ls $CHAIN_DIR + +enable_monitoring() { + sed -i'' -e "/\[telemetry\]/,+8 s/enabled = .*/enabled = true/" "$APP_CONFIG_FILE" + sed -i'' -e "s/^prometheus-retention-time =.*/prometheus-retention-time = 31104000/" "$APP_CONFIG_FILE" + sed -i'' -e "s/^prometheus =.*/prometheus = true/" "$TENDERMINT_CONFIG_FILE" + sed -ie 's/enabled-unsafe-cors.*$/enabled-unsafe-cors = true/' "$APP_CONFIG_FILE" + sed -ie 's/enable-unsafe-cors.*$/enabled-unsafe-cors = true/' "$APP_CONFIG_FILE" + sed -ie 's/cors_allowed_origins.*$/cors_allowed_origins = ["*"]/' "$TENDERMINT_CONFIG_FILE" +} + +echo "Update config.toml file" +sed -i -e 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' $CHAIN_DIR/config/config.toml +sed -i -e 's/index_all_keys = false/index_all_keys = true/g' $CHAIN_DIR/config/config.toml +sed -i -e 's/seeds = ".*"/seeds = ""/g' $CHAIN_DIR/config/config.toml +sed -i -e 's#cors_allowed_origins = \[\]#cors_allowed_origins = \["*"\]#g' $CHAIN_DIR/config/config.toml + + +echo "Update client.toml file" +sed -i -e 's#keyring-backend = "os"#keyring-backend = "test"#g' $CHAIN_DIR/config/client.toml +sed -i -e 's#output = "text"#output = "json"#g' $CHAIN_DIR/config/client.toml +sed -i -e "s#chain-id = \"\"#chain-id = \"$CHAIN_ID\"#g" $CHAIN_DIR/config/client.toml + + +echo "Update app.toml file" +sed -i -e "s#minimum-gas-prices = \".*\"#minimum-gas-prices = \"0$DENOM\"#g" $CHAIN_DIR/config/app.toml +sed -i -e "s#pruning = \".*\"#pruning = \"default\"#g" $CHAIN_DIR/config/app.toml +sed -i -e 's#enabled-unsafe-cors = false#enabled-unsafe-cors = true#g' $CHAIN_DIR/config/app.toml +sed -i -e 's#swagger = false#swagger = true#g' $CHAIN_DIR/config/app.toml +sed -i -e 's/enable-unsafe-cors = false/enable-unsafe-cors = true/g' $CHAIN_DIR/config/app.toml +sed -i -e 's/enabled-unsafe-cors = false/enabled-unsafe-cors = true/g' $CHAIN_DIR/config/app.toml + +function get_next_line_number() { + local txt=$1 + local file=$2 + local line_number=$(grep -n "$txt" $file | cut -d: -f1 | head -1) + echo $((line_number + 1)) +} + +line_number=$(get_next_line_number "Enable defines if the API server should be enabled." $CHAIN_DIR/config/app.toml) +sed -i -e "${line_number}s/enable = false/enable = true/g" $CHAIN_DIR/config/app.toml + +line_number=$(get_next_line_number "Address defines the API server to listen on." $CHAIN_DIR/config/app.toml) +sed -i -e "${line_number}s#address = \".*\"#address = \"tcp://0.0.0.0:1317\"#g" $CHAIN_DIR/config/app.toml + +line_number=$(get_next_line_number "Enable defines if the gRPC server should be enabled." $CHAIN_DIR/config/app.toml) +sed -i -e "${line_number}s/enable = false/enable = true/g" $CHAIN_DIR/config/app.toml + +line_number=$(get_next_line_number "Address defines the gRPC server address to bind to." $CHAIN_DIR/config/app.toml) +sed -i -e "${line_number}s#address = \".*\"#address = \"0.0.0.0:9090\"#g" $CHAIN_DIR/config/app.toml + +if [ "$METRICS" == "true" ]; then + line_number=$(get_next_line_number "other sinks such as Prometheus." $CHAIN_DIR/config/app.toml) + sed -i -e "${line_number}s/enabled = false/enabled = true/g" $CHAIN_DIR/config/app.toml + + line_number=$(get_next_line_number "PrometheusRetentionTime, when positive, enables a Prometheus metrics sink." $CHAIN_DIR/config/app.toml) + sed -i -e "${line_number}s/prometheus-retention-time = 0/prometheus-retention-time = 3600/g" $CHAIN_DIR/config/app.toml +fi + +echo "Update consensus params in config.toml" +sed -i -e "s#timeout_propose = \".*\"#timeout_propose = \"$TIMEOUT_PROPOSE\"#g" $CHAIN_DIR/config/config.toml +sed -i -e "s#timeout_propose_delta = \".*\"#timeout_propose_delta = \"$TIMEOUT_PROPOSE_DELTA\"#g" $CHAIN_DIR/config/config.toml +sed -i -e "s#timeout_prevote = \".*\"#timeout_prevote = \"$TIMEOUT_PREVOTE\"#g" $CHAIN_DIR/config/config.toml +sed -i -e "s#timeout_prevote_delta = \".*\"#timeout_prevote_delta = \"$TIMEOUT_PREVOTE_DELTA\"#g" $CHAIN_DIR/config/config.toml +sed -i -e "s#timeout_precommit = \".*\"#timeout_precommit = \"$TIMEOUT_PRECOMMIT\"#g" $CHAIN_DIR/config/config.toml +sed -i -e "s#timeout_precommit_delta = \".*\"#timeout_precommit_delta = \"$TIMEOUT_PRECOMMIT_DELTA\"#g" $CHAIN_DIR/config/config.toml +sed -i -e "s#timeout_commit = \".*\"#timeout_commit = \"$TIMEOUT_COMMIT\"#g" $CHAIN_DIR/config/config.toml + +if [ "$METRICS" == "true" ]; then + sed -i -e "s/prometheus = false/prometheus = true/g" $CHAIN_DIR/config/config.toml +fi diff --git a/starship/charts/devnet/scripts/dymension/update-genesis.sh b/starship/charts/devnet/scripts/dymension/update-genesis.sh new file mode 100644 index 00000000..e33f300f --- /dev/null +++ b/starship/charts/devnet/scripts/dymension/update-genesis.sh @@ -0,0 +1,136 @@ +#!/bin/bash + +DENOM="${DENOM:=uosmo}" +CHAIN_BIN="${CHAIN_BIN:=osmosisd}" +CHAIN_DIR="${CHAIN_DIR:=$HOME/.osmosisd}" + +set -eux + +ls $CHAIN_DIR/config + +GENESIS_FILE=$CHAIN_DIR/config/genesis.json + + +tmp=$(mktemp) + +set_gov_params() { + echo "setting gov params" + jq '.app_state.gov.deposit_params.min_deposit[0].denom = "adym"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state.gov.deposit_params.min_deposit[0].amount = "1000000"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq -r '.app_state.gov.deposit_params.max_deposit_period |= "30s"' $CHAIN_DIR/config/genesis.json > /tmp/genesis.json; mv /tmp/genesis.json $CHAIN_DIR/config/genesis.json + jq -r '.app_state.gov.voting_params.voting_period |= "30s"' $CHAIN_DIR/config/genesis.json > /tmp/genesis.json; mv /tmp/genesis.json $CHAIN_DIR/config/genesis.json + jq -r '.app_state.gov.tally_params.quorum |= "0.000000000000000000"' $CHAIN_DIR/config/genesis.json > /tmp/genesis.json; mv /tmp/genesis.json $CHAIN_DIR/config/genesis.json + jq -r '.app_state.gov.tally_params.threshold |= "0.000000000000000000"' $CHAIN_DIR/config/genesis.json > /tmp/genesis.json; mv /tmp/genesis.json $CHAIN_DIR/config/genesis.json + jq -r '.app_state.gov.tally_params.veto_threshold |= "0.000000000000000000"' $CHAIN_DIR/config/genesis.json > /tmp/genesis.json; mv /tmp/genesis.json $CHAIN_DIR/config/genesis.json +} + +set_hub_params() { + echo "setting hub params" + sed -i'' -e 's/bond_denom": ".*"/bond_denom": "adym"/' "$GENESIS_FILE" + sed -i'' -e 's/mint_denom": ".*"/mint_denom": "adym"/' "$GENESIS_FILE" + + jq '.app_state.rollapp.params.dispute_period_in_blocks = "50"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + + #increase the tx size cost per byte from 10 to 100 + jq '.app_state.auth.params.tx_size_cost_per_byte = "100"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + + jq -r '.app_state.staking.params.unbonding_time |= "120s"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + + # jail validators faster, and shorten recovery time, no slash for downtime + jq '.app_state.slashing.params.signed_blocks_window = "10000"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state.slashing.params.min_signed_per_window = "0.800000000000000000"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state.slashing.params.downtime_jail_duration = "120s"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state.slashing.params.slash_fraction_downtime = "0.0"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" +} + +set_consenus_params() { + # cometbft's updated values + # MaxBytes: 4194304, // four megabytes + # MaxGas: 10000000, // ten million + echo "setting consensus params" + jq '.consensus_params["block"]["max_bytes"] = "4194304"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.consensus_params["block"]["max_gas"] = "10000000"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" +} + +set_EVM_params() { + echo "setting EVM params" + jq '.app_state["feemarket"]["params"]["no_base_fee"] = true' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state.evm.params.evm_denom = "adym"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state.evm.params.enable_create = false' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" +} + +#Adding a "minute" epoch +set_epochs_params() { + echo "setting epochs params" + jq '.app_state.epochs.epochs += [{ + "identifier": "minute", + "start_time": "0001-01-01T00:00:00Z", + "duration": "60s", + "current_epoch": "0", + "current_epoch_start_time": "0001-01-01T00:00:00Z", + "epoch_counting_started": false, + "current_epoch_start_height": "0" + }]' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" +} + +#should be set to days on live net and lockable duration to 2 weeks +set_incentives_params() { + echo "setting incentives params" + jq '.app_state.incentives.params.distr_epoch_identifier = "minute"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state.incentives.lockable_durations = ["60s"]' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" +} + + +set_misc_params() { + echo "setting misc params" + jq '.app_state.crisis.constant_fee.denom = "adym"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq -r '.app_state.gamm.params.pool_creation_fee[0].denom = "adym"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state["txfees"]["basedenom"] = "adym"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + jq '.app_state["txfees"]["params"]["epoch_identifier"] = "minute"' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" + + jq -r '.app_state.gamm.params.enable_global_pool_fees = true' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" +} + +set_bank_denom_metadata() { + echo "setting bank denom params" + jq '.app_state.bank.denom_metadata = [ + { + "base": "adym", + "denom_units": [ + { + "aliases": [], + "denom": "adym", + "exponent": 0 + }, + { + "aliases": [], + "denom": "DYM", + "exponent": 18 + } + ], + "description": "Denom metadata for DYM (adym)", + "display": "DYM", + "name": "DYM", + "symbol": "DYM" + } + ]' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" +} + +set_authorised_deployer_account() { + jq --arg address $1 '.app_state.rollapp.params.deployer_whitelist += [{ "address": $address }]' "$GENESIS_FILE" > "$tmp" && mv "$tmp" "$GENESIS_FILE" +} + +set_consenus_params +set_gov_params +set_hub_params +set_misc_params +set_EVM_params +set_bank_denom_metadata +set_epochs_params +set_incentives_params + +echo "Update genesis.json file with updated local params" +sed -i "s/\"time_iota_ms\": \".*\"/\"time_iota_ms\": \"$TIME_IOTA_MS\"/" $CHAIN_DIR/config/genesis.json + +$CHAIN_BIN tendermint show-node-id + diff --git a/starship/tests/e2e/configs/dymension.yaml b/starship/tests/e2e/configs/dymension.yaml new file mode 100644 index 00000000..5212a91c --- /dev/null +++ b/starship/tests/e2e/configs/dymension.yaml @@ -0,0 +1,34 @@ +chains: + - id: dymension_1100-1 + name: dymension + numValidators: 2 + faucet: + enabled: true + type: starship + ports: + rest: 1313 + rpc: 26653 + exposer: 38083 + - id: cosmoshub-4 + name: cosmoshub + image: ghcr.io/cosmology-tech/starship/gaia:v10.0.1 + numValidators: 1 + ports: + rest: 1317 + rpc: 26657 + exposer: 38087 + faucet: 8007 + +relayers: + - name: dym-cosmos + type: hermes + replicas: 1 + chains: + - dymension_1100-1 + - cosmoshub-4 + +registry: + enabled: true + ports: + rest: 8081 + grpc: 9091