feature(charts): hermes chart fixes, bech32 updates, ibc bridge test#1130
feature(charts): hermes chart fixes, bech32 updates, ibc bridge test#1130steezeburger merged 52 commits intomainfrom
Conversation
* add celestia ibc account * fix some values
dev/values/hermes/local.yml
Outdated
| gasPrice: 1 | ||
| gasDenom: nria | ||
| trustThreshold: 2/3 | ||
| trustThreshold: 1/3 |
There was a problem hiding this comment.
this should probably be 2/3 to match tendermint?
There was a problem hiding this comment.
Updated!
I got these values from https://github.com/astriaorg/hermes/blob/astria/config-astria-celestia.toml
Should I update there as well? Not 100% sure of the implication/meaning of trustThreshold
There was a problem hiding this comment.
The trust threshold defines what fraction of the total voting power of a known and trusted validator set is sufficient for a commit to be accepted going forward. - hermes docs
Basically 2/3 is the threshold for CometBFT to accept a block so I don't think it makes sense to accept lower than that.
* main: fix(charts): conductor configmap fix (#1146) feat(sequencer): add `allowed_fee_asset_ids` abci query and `sequencer_client` support (#1127) chore(conductor): release conductor 0.17 (#1139) feat: use macro to declare metric constants (#1129) refactor(merkle): remove source of panics in audit API (#1137) feat(conductor): skip outdated block metadata (#1120) refactor(sequencer): remove mint module (#1134) feat(bridge-withdrawer): add justfile (#1135) chore(chart): change evm back to latest on dev (#1132) feat(conductor, proto)!: celestia base heights in commitment state (#1121)
* main: fix: ignore RUSTSEC-2021-0139 (#1171) chore(sequencer-relayer)!: remove functionality to restrict relaying blocks to only those proposed by a given validator (#1168) chore(metrics): update `metric_name` macro to handle a collection of names (#1163) fix(bridge-withdrawer): skip linting generated contract code (#1172) fix(core, sequencer): prefix removal source non-refund ics20 packet (#1162) chore(docs): add sequencer-relayer doc to specs (#1126) feat(bridge-withdrawer): sync logic (#1165) chore(withdrawer): replace contracts with `astria-bridge-contracts` submodule (#1164) feat(sequencer)!: implement bridge sudo and withdrawer addresses (#1142) feat(sequencer): implement refund to rollup logic upon ics20 transfer refund (#1161) feat(bridge-withdrawer): bridge withdrawer startup (#1160) feat(core, proto)!: add bech32m addresses (#1124) feat(withdrawer): bridged ERC20 token withdrawals (#1149) feat(sequencer-relayer)!: add chain IDs for sequencer and Celestia to config env vars (#1063) test(bridge-withdrawer): add submitter tests (#1133) chore: bump penumbra deps (#1159) feat(sequencer): implement `bridge/account_last_tx_hash` abci query (#1158) fix(withdrawer): use block subscription in batcher; send to destination_chain_address (#1157) fix(withdrawer): update AstriaWithdrawer to check that withdrawal value is sufficient (#1148) chore(ci): build bridge withdrawer images (#1156)
testing astria-geth bech32 updates
* main: chore(bridge-withdrawer): add missing errors and clean up names (#1178) feat(sequencer): add ttl and invalid cache to app mempool (#1138) chore(astria-merkle): add benchmarks (#1179) chore(sequencer-relayer): add timeout to gRPCs to Celestia app (#1191) refactor(core): parse ics20 denoms as ibc or trace prefixed variants (#1181) Mycodecrafting/sequencer seed node (#1188) chore: register all metrics during startup (#1144) feat(charts): option to purge geth mempool (#1182)
* main: (27 commits) refactor(sequencer): fix prepare proposal metrics (#1211) refactor(bridge-withdrawer): move generated contract bindings to crate (#1237) fix(sequencer) fix wrong metric and remove unused metric (#1240) feat(sequencer): implement transaction fee query (#1196) chore(cli)!: remove unmaintained rollup subcommand (#1235) release(sequencer): 0.14.1 patch release (#1233) feat(sequencer-utils): generate example genesis state (#1224) feat(sequencer): implement abci query for bridge account info (#1189) feat(charts): bridge-withdrawer, smoke test, various chart improvements (#1141) chore(charts): update for new geth update (#1226) chore(chart)!: dusk-8 chart version updates (#1223) release(conductor): fix conductor release version (#1222) release: dusk-8 versions (#1219) fix(core): revert `From` ed25519_consensus types for crypto mod (#1220) Refactor(chart, sequencer): restructure sequencer chart, adjust configs (#1193) refactor(withdrawer): read from block subscription stream and get events on each block (#1207) feat(core): implement with verification key for address builder and crypto improvements (#1218) feat(proto, sequencer)!: use full IBC ICS20 denoms instead of IDs (#1209) chore(chart): update evm chart for new prefix field (#1214) chore: bump penumbra deps (#1216) ...
| bridge_rpc_port: "{{ .Values.ports.bridgeRPC }}" | ||
| celestia_app_host_port: "{{ .Values.ports.celestiaAppHostPort }}" | ||
| celestia_app_grpc_port: "{{ .Values.ports.celestiaAppGrpcPort }}" | ||
| ibc_account_mnemonic: "{{ .Values.ibcAccountMnemonic }}" |
There was a problem hiding this comment.
Should we maybe update to a generic structure here in values that is array of accounts with object fields name, mnemonic, value, staked_value? This would allow customizing the chart to generically generate genesis setup with any number of accounts.
| nginx.ingress.kubernetes.io/enable-cors: "true" | ||
| # allow requests from bridge web app | ||
| nginx.ingress.kubernetes.io/cors-allow-origin: "http://localhost:3000" |
* main: feat(cli): add cmd to collect withdrawal events and submit as actions (#1261) fix(core, bridge, sequencer)!: dismabiguate return addresses (#1266) fix(withdrawer): support withdrawer address that differs from bridge address (#1262) (core, sequencer)!: generate serde traits impls for all protocol protobufs (#1260) fix(charts): add resources for sequencer/cometbft (#1254) chore(sequencer)!: add metrics (#1248) fix(sequencer-utils): fixes issue in `parse_blob` tests (#1243) feat(core, proto)!: make bridge unlock memo string (#1244) fix(conductor): don't panic during panic (#1252) feat(core)!: lowerCamelCase for protobuf json mapping (#1250) refactor(bridge-withdrawer)!: refactor startup to a separate subtask and remove balance check from startup (#1190) fix: rollup archive node configurations (#1249) refactor(core, bridge-withdrawer)!: move bridge-unlock memo to core (#1245) fix(sequencer)!: store native asset ibc->trace mapping in init_chain (#1242)
joroshiba
left a comment
There was a problem hiding this comment.
looks good enough to me, we can merge and then clean up
* main: chore(cli): remove unused rollup cli code (#1275)
* main: (24 commits) chore: update `bytes` and `ics23` crates (#1279) fix(sequencer): improve and fix instrumentation (#1255) feature(charts): hermes chart fixes, bech32 updates, ibc bridge test (#1130) chore(cli): remove unused rollup cli code (#1275) chore(test): use a temporary file to not pollute the workspace (#1269) chore(sequencer): add mempool benchmarks (#1238) fix(bridge-withdrawer)!: fix nonce handling (#1215) feat(cli, bridge-withdrawer)!: share code between cli and service (#1270) feat(cli): add cmd to collect withdrawal events and submit as actions (#1261) fix(core, bridge, sequencer)!: dismabiguate return addresses (#1266) fix(withdrawer): support withdrawer address that differs from bridge address (#1262) (core, sequencer)!: generate serde traits impls for all protocol protobufs (#1260) fix(charts): add resources for sequencer/cometbft (#1254) chore(sequencer)!: add metrics (#1248) fix(sequencer-utils): fixes issue in `parse_blob` tests (#1243) feat(core, proto)!: make bridge unlock memo string (#1244) fix(conductor): don't panic during panic (#1252) feat(core)!: lowerCamelCase for protobuf json mapping (#1250) refactor(bridge-withdrawer)!: refactor startup to a separate subtask and remove balance check from startup (#1190) fix: rollup archive node configurations (#1249) ...
…1130) ## Summary Fixes hermes helm chart ## Background We want to run hermes via helm chart so we can automate e2e testing. ## Changes * add 2nd funded celestia account * use this account's key in hermes * fix hermes chart values * add new chart `bridge-test` * add new justfile `dev/bridgetester.just` * add `AstriaSequencerHrpPrefix` to evm rollup geth-genesis ## Testing - `just deploy-cluster` - `just deploy-ibc-test-infra` - deploys ingress controller - deploys celestia-local - deploys single astria sequencer - `./charts/sequencer/values.yaml` - `./dev/values/validators/single.yaml` - deploys evm rollup - `./charts/evm-rollup/values.yaml` - `./dev/values/rollup/dev.yaml` - `./dev/values/rollup/ibc-bridge-test.yaml` - deploy hermes - `./charts/hermes/values.yaml` - `./dev/values/hermes/local.yml` - `just deploy-bridge-tester` - initContainer handles initializing bridge account on the sequencer - container runs scripts - `celestia-appd keys add` - `celestia-appd tx ibc-transfer transfer` - checks balance before and after and fails if ibc-transfer did not go through ## Metrics - List out metrics added by PR, delete section if none. ## Breaking Changelist - Bulleted list of breaking changes, any notes on migration. Delete section if none. ## Related Issues Link any issues that are related, prefer full github links. closes <!-- list any issues closed here -->
Summary
Fixes hermes helm chart
Background
We want to run hermes via helm chart so we can automate e2e testing.
Changes
bridge-testdev/bridgetester.justAstriaSequencerHrpPrefixto evm rollup geth-genesisTesting
just deploy-clusterjust deploy-ibc-test-infra./charts/sequencer/values.yaml./dev/values/validators/single.yaml./charts/evm-rollup/values.yaml./dev/values/rollup/dev.yaml./dev/values/rollup/ibc-bridge-test.yaml./charts/hermes/values.yaml./dev/values/hermes/local.ymljust deploy-bridge-testercelestia-appd keys addcelestia-appd tx ibc-transfer transferMetrics
Breaking Changelist
Related Issues
Link any issues that are related, prefer full github links.
closes