Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Token commands + Improvements #157

Merged
merged 9 commits into from
Mar 4, 2022
Merged

Token commands + Improvements #157

merged 9 commits into from
Mar 4, 2022

Conversation

RodrigoAD
Copy link
Member

@RodrigoAD RodrigoAD commented Feb 28, 2022

  • OCR Inspection command checks how much it owes to the transmitters and compares with its current balance
  • Transfer Token command now uses abstract command
  • Send LUNA command added.
  • beforeExecute hook added

packages-ts/gauntlet-terra-contracts/codeIds/mainnet.json Outdated Show resolved Hide resolved
packages-ts/gauntlet-terra/src/commands/internal/terra.ts Outdated Show resolved Hide resolved
@@ -65,7 +66,7 @@ export default abstract class TerraCommand extends WriteCommand<TransactionRespo
return await this.provider.wasm.contractQuery(address, input, params)
}

signAndSend = async (messages: MsgExecuteContract[]): Promise<TransactionResponse> => {
signAndSend = async (messages: MsgExecuteContract[] | MsgSend[]): Promise<TransactionResponse> => {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider using a more general Msg[] type as declared in the SDK.

packages-ts/gauntlet-terra-cw-plus/src/lib/types.ts Outdated Show resolved Hide resolved
@RodrigoAD RodrigoAD marked this pull request as ready for review March 1, 2022 12:22
@RodrigoAD RodrigoAD requested a review from sdrug March 3, 2022 09:51
packages-ts/gauntlet-terra-contracts/codeIds/mainnet.json Outdated Show resolved Hide resolved
Comment on lines +22 to +29
constructor(flags, args: string[]) {
super(flags, args)
}

buildCommand = async (flags, args): Promise<TerraCommand> => {
this.input = this.makeInput(flags, args)
return this
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Now you have two construction steps. Why not just do all of this in the constructor?
Designing it like this it's easy to leave the object in a half-constructed state.

Copy link
Member Author

@RodrigoAD RodrigoAD Mar 3, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need a way to construct the object with support for promises basically. Currently gauntlet-core initializes the command using new Command, but we should move into a static create (or buildCommand) style, and be the default way to construct the command, and deprecate the new Command way.
Will open an issue on gauntlet-core.

RodrigoAD and others added 3 commits March 3, 2022 15:50
* transfer ownership checks

* inpect offchain config from event info

* provider in execution context. minor improvements

* updated test

* hex to base64

* Update guantlet e2e test to use an rdd with all non zero false values so the inspect command can check all values have changed
No longer use the digest in the test as it is not needed

Co-authored-by: Tate <[email protected]>
@RodrigoAD
Copy link
Member Author

This should be ready @sdrug @krebernisak

krebernisak
krebernisak previously approved these changes Mar 4, 2022
const data = this.afterExecute(response)
// TODO: Command should be built from gauntet-core
await this.buildCommand(this.flags, this.args)
//
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
//

import { AccAddress, LCDClient } from '@terra-money/terra.js'
import { logger, prompt } from '@chainlink/gauntlet-core/dist/utils'

export type ExecutionContext<Input, ContractInput> = {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Where are these <Input, ContractInput> types defined?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Aha, these are actually generic type definitions but it's confusing (to me at least) as they are named the same as other concrete types. It wouldn't be as confusing if defined as export type ExecutionContext<A, B> = { for example.

No specific suggestions now. Types are improving step by step, and we'll continue to improve them as we go.

})
}),
)

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
const totalOwed = owedPerTransmitter.reduce((agg: BN, v) => agg.add(v), new BN(0)).toString(),

packages-ts/gauntlet-terra-contracts/src/lib/inspection.ts Outdated Show resolved Hide resolved
@RodrigoAD RodrigoAD merged commit 0abf4ec into develop Mar 4, 2022
@RodrigoAD RodrigoAD deleted the token-commands branch March 4, 2022 12:29
akhilchainani added a commit that referenced this pull request Mar 8, 2022
* bugfix: fix abstract command abi validation to work with cw-plus contracts

These use anyOf instead of oneOf to list the available functions

* add report output (#131)

Also adds the option of setting what the report name will be via the environment variable "REPORT_NAME" which aids in automated tests.

* Remove crates/query-proxy

We no longer have the flags proxy so there's no sense to share
definitions.

* Multisig wrapper command (#111)

* commands export data

raw tx on inspection command

* basic package and schema

* multisig command

* multisig command improvements

list some todos

* more detailed state

* execute option on multisig

* refactor

* Feature/29149 multisig group commands (#132)

* 29141: update_admin command

* 29149: update_members command

* 29149: export update_admin and update_memners commands

* 29149: MR feedback - file reorganisation

* 29149: applying formatting

* pkg/terra: add Test_parseAttributes (#128)

* fix tests (#139)

* correctly set cosmos queries

* rename juelsperluna to juelsperfeecoin in the set_config event

* add check to make sure all fields are extracted from logs

* switch to cropping the config digest before publishing to kafka.

* add test for decoding configuration, transmission and balance from the
chain read

* revert to using the decoded config digest

* use the relay monitoring Logger interface instead of the core logger

* fix terra monitoring main

* migration up test boiler (#138)

* fix chaos CI (#140)

* refactor ocr2:deploy --id to args[0] (#137)

* changed flag on proxy command (#144)

* fix proxy query for decimals, version, description

* Improvements after Multisig testing (#145)

* inspection improvements

improvements on inspection

* inspect msig comand

* max voting period 7 days

* Document lack of transmitters prefix (#150)

* additional unit tests for remaining proxy functions (#149)

* add ocr2 spec changes, switch image repo (#152)

* Add gauntlet e2e tests through accepting a proposal (#141)

* Add a hello-world consumer example (#143)

* Add a hello-world consumer example

* wrap up consumer contract + test cases

* remove unneeded boilerplate - simplify mocked contract

Co-authored-by: aalu1418 <[email protected]>

* change env naming convention (#155)

* proxy cmds uses args[0] and pull aggregator from RDD (#148)

* add codeId for proxy_ocr2 testnet (#undefined)

* feat: update OCR2 spec examples (#154)

* Add Ocr2 Proxy E2E Test (#162)

* implement the contracts for proxy so we can deploy them

* Add ocr2 proxy test for latestRound, decimals, and description

* pkg/terra: add MsgEnqueuer.GetMsgs (#113)

* fix inspection bugs + improvements (#161)

* proxy monitoring stub

* move chain reader into its own file

* proxy source factory uses the proxy address. Also update corresponding
data generator for tests

* add prometheus exporter factory and test, along with metrics and mocks

* fix the issues reported by the linter

* bump chainlink-relay to get the panic recover feature from Source

* bump chainlink-relay dependency

* add support for monitoring feeds that don't have a proxy contract
configured

* fix url path for fetching transactions from FCD

* bump to the latest relay version where tx failed/succeeded metrics are
counters instead of gauges

* sequence requests to the terra rpc endpoint for all sources

* bump chainlink-relay

* introduce individual sequencers for TxsEvents and ContractStore

* bump chainlink-relay and add GetType to all the terra monitoring source

* fix go.sum

* Token commands + Improvements (#157)

* added balance diff in inspection

* transfer token and send uluna commands

* added mainnet ids

* refactor before execution

* refactor and improvements

* fix rebase

* Gauntlet sec improvements (#166)

* transfer ownership checks

* inpect offchain config from event info

* provider in execution context. minor improvements

* updated test

* hex to base64

* Update guantlet e2e test to use an rdd with all non zero false values so the inspect command can check all values have changed
No longer use the digest in the test as it is not needed

Co-authored-by: Tate <[email protected]>

* added cw20 code id and more validations

* small refactor

Co-authored-by: Tate <[email protected]>

* unit test: reverted payments do not change owed balance (#169)

* Payout oracles when set_billing is called (#168)

* fix: rename accept_proposal method attribute

* payout oracles when billing is set

* Support negative observations (#165)

* Use generic helper

* Add a test

* Placate linter

* Address comments

* Linter

* 30252 tx simulation (#159)

* 30252: TX Simulation method in AbstractCommand

* 30252: Adding isSimulate instruction field to all oc2 initialize flow commands

* 30252: Formatting

* 30252: Removing optional isSimulate field (i.e always simulate)

* 30252: Tx simulation for the arbitrary provided signer

* 30252: batch simulation

* 30252: tx simulation for multisig

* 30252: Adjusting simulation success message

* 30252: Formatting

* Fee coin bounds check (#172)

* Fee coin bounds check

* Sanity check reimbursement calc

* Cargo fmt

* include chain_id length in config digest (#173)

* include chain_id length in config digest

* validate length below uint8 max, test case assert error

* Providing raw proposal id for command input (#179)

* Multisig simulation: generating tx using provider instead of wallet to avoid default assignments (#178)

* drop the namespace from the logger

* make the proxy source fetch and export the link available for payments
of an aggregator contract

* remove the link_available_for_payments metric on cleaup

* ensure Client methods respect context cancel or expired

* bump chainlink-relay to get the fix on the balances/observations
precision

* More mocked sources for tests (#156)

* More mocked sources tests

* in progress

* Fix regex (#182)

* Feature/31183 settings diff (#171)

* added balance diff in inspection

* transfer token and send uluna commands

* added mainnet ids

* refactor before execution

* refactor and improvements

* transfer ownership checks

* inpect offchain config from event info

* added balance diff in inspection

* transfer token and send uluna commands

* added mainnet ids

* refactor before execution

* refactor and improvements

* fix rebase

* transfer ownership checks

* inpect offchain config from event info

* provider in execution context. minor improvements

* 31183: adding printDiff

* 31183: printDiff function

* 31183: getLatestOCRConfig function

* 31183: proposeConfig

* 31183: proposeOffchainConfig

* 31183: acceptProposal

* 31183: Small fixes based on the code review

* 31183: randomSecret requested while creating the proposal to guarantee deterministic check

* 31183: Cleanup

* 31183: Resolving conflicts with token-commands

* added cw20 code id and more validations

* 31183: longsToNumber into a separate function

* 31183: Updating inspect command with getLatestOCRConfig

* refactor encryptions to accept secret

* 31183: Adding payees to proposedConfig

* Update e2e gauntlet test to grab the offchain proposal secret from the report and use it in the accept proposal

* lint format

* 31183: make longsInObjToNumbers pure and add deepCopy implementation to utils

* 31183: Formatting

* 31183: Review implementation - reorderings, renamings, comments

Co-authored-by: RodrigoAD <[email protected]>
Co-authored-by: Tate <[email protected]>

* Add instructions for running the e2e tests to the readme (#174)

* Add instructions for running the e2e tests to the readme

* Move to docs and use readme link to it

* bring solana and terra more in sync

* Defaulting migrationContract to sender accAddress (#183)

* add prod testnet environment (#184)

* Add default rdd setting, and require for acceptOwnership

Minor changes related to -rdd gauntlet flag (suggested during multisig review):

1. Will default to "../reference-data-directory/directory-terra-mainnet.json" if not passed explicitly
2. acceptOwnership & transferOwnership will throw Error instead of warn, if there is no rdd flag

The first one should make it so the second one can never happen, but this
is better behavior just in case.  And it matches what most other commands already do.

* Update default multisig-proposal expiration time to 24 hours

* Expose payees on the set_config event

* Add a note regarding validation execution

* Fix event names in owned crate

* Fix CI by removing a non-working 'defaultFlags.rdd'

* copy all versions of cosmwasm to /lib

* upgrade contract codeIds to v0.1.5

* update testnet-internal and add new lines to all codeIds files

Co-authored-by: Domino Valdano <[email protected]>
Co-authored-by: Tate <[email protected]>
Co-authored-by: Blaž Hrastnik <[email protected]>
Co-authored-by: Rodrigo Ariza <[email protected]>
Co-authored-by: Sergei Drugalev <[email protected]>
Co-authored-by: Jordan Krage <[email protected]>
Co-authored-by: Sergey Kudasov <[email protected]>
Co-authored-by: alexandru topliceanu <[email protected]>
Co-authored-by: Frank Zhu <[email protected]>
Co-authored-by: aalu1418 <[email protected]>
Co-authored-by: Connor Stein <[email protected]>
Co-authored-by: Aaron Lu <[email protected]>
Co-authored-by: Rens Rooimans <[email protected]>
Co-authored-by: Gheorghe Strimtu <[email protected]>
Co-authored-by: Akhil Chainani <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants