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

refactor!: remove legacyamino functions #17746

Closed
wants to merge 5 commits into from
Closed

Conversation

tac0turtle
Copy link
Member

@tac0turtle tac0turtle commented Sep 14, 2023

Description

second attempt at removing amino usage in the sdk in favor of the automated version

This pr removes:

  • Grpc decode aminotxs since this is no longer supported

ref #17775


Author Checklist

All items are required. Please add a note to the item if the item is not applicable and
please add links to any relevant follow up issues.

I have...

  • included the correct type prefix in the PR title
  • added ! to the type prefix if API or client breaking change
  • targeted the correct branch (see PR Targeting)
  • provided a link to the relevant issue or specification
  • followed the guidelines for building modules
  • included the necessary unit and integration tests
  • added a changelog entry to CHANGELOG.md
  • included comments for documenting Go code
  • updated the relevant documentation or specification
  • reviewed "Files changed" and left comments if necessary
  • run make lint and make test
  • confirmed all CI checks have passed

Reviewers Checklist

All items are required. Please add a note if the item is not applicable and please add
your handle next to the items reviewed if you only reviewed selected items.

I have...

  • confirmed the correct type prefix in the PR title
  • confirmed ! in the type prefix if API or client breaking change
  • confirmed all author checklist items have been addressed
  • reviewed state machine logic
  • reviewed API design and naming
  • reviewed documentation is accurate
  • reviewed tests and test coverage
  • manually tested (if applicable)

@tac0turtle tac0turtle marked this pull request as ready for review September 16, 2023 21:07
@tac0turtle tac0turtle requested a review from a team as a code owner September 16, 2023 21:07
@github-prbot github-prbot requested review from a team and alexanderbez and removed request for a team September 16, 2023 21:07
Copy link
Contributor

@alexanderbez alexanderbez left a comment

Choose a reason for hiding this comment

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

Pretty substantial PR, but from the looks of it, it seems good to me.

@@ -58,24 +58,6 @@ service Service {
body: "*"
};
}
// TxEncodeAmino encodes an Amino transaction from JSON to encoded bytes.
Copy link
Member

Choose a reason for hiding this comment

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

Why do we delete this actually?
Wasn't it added per community request?

Copy link
Member

@kocubinski kocubinski Sep 18, 2023

Choose a reason for hiding this comment

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

I think I agree; we can still encode to amino JSON via the encoder in x/tx or is this talking about a different amino format? (I remember something about a binary amino format).

Instead maybe keep the messages/services and have the decode service return an error since this is what we're dropping support for.

Copy link
Member Author

Choose a reason for hiding this comment

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

technically this doesn't work for modules that dont registerlegacyamino, so we have a bit of a discrepancy on support here. I can look at adding back the encode but decode id just remove.

Copy link
Member

Choose a reason for hiding this comment

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

Shouldn't this stay as well? cc @kocubinski

Copy link
Member

@kocubinski kocubinski Sep 18, 2023

Choose a reason for hiding this comment

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

I really think we should find a way to keep these tests; even if that means moving the (now) legacy amino json encoder dependency into a _test namespace or package.

They are asserting that the amino json encoder has equivalent output to the legacy one which could prove valuable if issues arise down the road.

Copy link
Member Author

Choose a reason for hiding this comment

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

i can look at registering the amino types needed for this test in the test but the modules wont be reverted. Modules need to move forward and breaking things is part of it. Otherwise we will never be able to move forward

Copy link
Member

Choose a reason for hiding this comment

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

I see what you mean. I'm not sure how this would work right exactly right now, but another possibility is to obtain a "golden file" comprising the output of passing the proto types generated through rapidproto at a particular seed (doesn't matter what).

Since this golden file, made in good faith, has the same output as legacy amino json encoder we could delete the encoder code and all the wiring for it but still assert the correctness of the x/tx one.

Copy link
Member

Choose a reason for hiding this comment

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

Also the golden file is committed to source control.

Copy link
Member

@kocubinski kocubinski left a comment

Choose a reason for hiding this comment

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

I think we should retain the generative tests, lmk if you need help generating the golden file.

@tac0turtle
Copy link
Member Author

closing this for now, would like to pair it with another issue

@tac0turtle tac0turtle closed this Oct 18, 2023
@tac0turtle tac0turtle deleted the marko/amino_removal branch April 17, 2024 08:47
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants