-
Notifications
You must be signed in to change notification settings - Fork 2k
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
Add puzzles, driver and lifecycle tests for revocable CATs #19000
base: main
Are you sure you want to change the base?
Conversation
Details can be found in the accompanying CHIP
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Happy to let this sit in PR for the sake of developing within chia-blockchain
but I don't think this should be merged unless it's actually going to be used because otherwise it's clutter.
@@ -0,0 +1,64 @@ | |||
; This layer ensures that a second puzzle hash or "backdoor" that can be used without the inner puzzle's permission |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why are you duplicating this puzzle rather than importing the existing one?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Various people didn't want to use the previous name.
So I've added it with a different name, since I didn't want to change the VC code.
def construct_p2_delegated_by_singleton(issuer_launcher_id: bytes32) -> Program: | ||
singleton_struct: Program = Program.to( | ||
( | ||
SINGLETON_TOP_LAYER_MOD_HASH, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's important in these drivers to have optional ways to override these values. Sometimes, in tests, I like to use a "mock" singleton puzzle, and these drivers wouldn't work for that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same goes for similar functions below.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's a good idea, although as you said, I don't think that driver will be merged into chia-blockchain anytime soon.
Would add that in case we do want to use it here.
|
||
|
||
@pytest.mark.anyio | ||
async def test_revocable_cat_lifecycle(cost_logger): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I realize this is copied from a real in-"production" test but it's from like 3 years ago. Using the standard puzzle as the p2 puzzle really over complicates the whole file and makes it difficult to review and get accurate cost metrics. I would rather use Program.to(1)
as the inner puzzle where possible because it's the minimal-est puzzle that allows for what you need and therefore weighs on the cost number the least.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That makes sense, will use that!
I've seen that with other tests, but my first thought was that using the "real" puzzle brings the tests closer to reality.
But that doesn't really matter, I imagine.
|
||
@pytest.mark.anyio | ||
async def test_revocable_cat_lifecycle(cost_logger): | ||
async with sim_and_client() as (sim, sim_client): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I left comments on the other file that should apparently be deleted about simplifying this test function.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, that other file was a duplicate I've committed by mistake
Your commits are not signed and our branch protection rules require signed commits. For more information on how to create signed commits, please visit this page: https://docs.github.com/en/authentication/managing-commit-signature-verification/about-commit-signature-verification. Please use the button towards the bottom of the page to close this pull request and open a new one with signed commits. |
1b38f2f
to
b29d87f
Compare
(defun-inline singleton_struct_for_delta (ISSUER_LAUNCHER_ID MELTER_LAUNCHER_ID delta) | ||
(if (> 0 delta) | ||
(c SINGLETON_MOD_HASH (c MELTER_LAUNCHER_ID LAUNCHER_PUZZLE_HASH)) ; delta is negative, so we melt | ||
(c SINGLETON_MOD_HASH (c ISSUER_LAUNCHER_ID LAUNCHER_PUZZLE_HASH)) ; delta is positive or 0, so we mint |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm pretty sure you should swap this with a parent_is_cat
check. I think (though I have not fully thought it through), that a melting authority could play games here where it issues a CAT and then immediately melts some of it. That initial issuance doesn't count as a positive delta and therefore you would be able to have a negative delta even though more total CAT exists on the blockchain. I don't think you need to acommodate positive deltas, that kind of minting is kind of silly.
|
||
(defun-inline authorize_via_singleton (SINGLETON_STRUCT singleton_inner_puzzle_hash delta) | ||
(list | ||
(list RECEIVE_MESSAGE 23 delta (calculate_full_puzzle_hash SINGLETON_STRUCT singleton_inner_puzzle_hash)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please leave a comment about what bits these are and what that means
Details can be found in the accompanying CHIP.