test: fix the unreachable code at feature_taproot #21081

pull brunoerg wants to merge 1 commits into bitcoin:master from brunoerg:taproot-test-return changing 1 files +0 −1
  1. brunoerg commented at 12:45 pm on February 4, 2021: member
    This PR removes the unnecessary return statement at the beginning of the function that makes the rest of the function unreachable.
  2. fix the unreachable code at feature_taproot 5e0cd25e29
  3. michaelfolkson commented at 1:10 pm on February 4, 2021: contributor

    Concept ACK from #20354 (review)

    There should only be one commit @brunoerg. There are currently three. You should work on top of latest version of master to avoid these merge commits but you may be able to resolve this by squashing commits

  4. fanquake added the label Tests on Feb 4, 2021
  5. michaelfolkson commented at 1:23 pm on February 4, 2021: contributor

    I don’t know if you need this @brunoerg but if you do you can do a reset on your branch to the current top commit on master, then re-adding your commit and force pushing.

    git reset -hard insert_current_top_commit_hash_on_master

    Then add a single commit on top and force pushing. @fanquake helped me a while back with that :)

  6. brunoerg force-pushed on Feb 4, 2021
  7. brunoerg commented at 1:54 pm on February 4, 2021: member
    Thanks a lot! It helped me! @michaelfolkson
  8. theStack commented at 1:56 pm on February 4, 2021: member
    Concept ACK, almost approach ACK I’d suggest to be a bit more verbose in the commit subject line (you could e.g. simply use the PR title).
  9. brunoerg force-pushed on Feb 4, 2021
  10. MarcoFalke renamed this:
    test, refactor: fix the unreachable code at feature_taproot
    test: fix the unreachable code at feature_taproot
    on Feb 4, 2021
  11. MarcoFalke commented at 5:27 pm on February 4, 2021: member
    Removed “refactor”
  12. practicalswift commented at 8:39 am on February 5, 2021: contributor

    Another nice catch @brunoerg!

    And another case of “how the heck did this pass our peer review”? :)

    Given enough eyeballs, all bugs are shallow.

    Nice to have your eyeballs joining us! Again: warm welcome! :)

  13. practicalswift commented at 8:43 am on February 5, 2021: contributor

    Got so excited that I missed my actual review comment! :D

    cr ACK 5e0cd25e29541e6c19559fb5c2555e008ed896fa: patch looks correct!

  14. MarcoFalke commented at 9:00 am on February 5, 2021: member
    If this is merged we’ll have to regenerate the unit tests, I presume?
  15. flack commented at 11:09 am on February 5, 2021: contributor

    And another case of “how the heck did this pass our peer review”? :)

    I’m more surprised that this wasn’t caught by some linter. Or is unreachable code detection in Python just not reliable enough to be useful?

  16. MarcoFalke commented at 3:55 pm on February 5, 2021: member

    Or is unreachable code detection in Python just not reliable enough to be useful?

    See f4beb4996d27f2cdaf4f0a63e7dc044bf17decce. Maybe things have changes since then?

  17. theStack approved
  18. theStack commented at 10:07 pm on February 6, 2021: member

    Tested ACK 5e0cd25e29541e6c19559fb5c2555e008ed896fa 🏔️ Ran feature_taproot.py multiple (>10) times on the PR branch to verify that it succeeds with all code paths in random_checksig_style.

    If this is merged we’ll have to regenerate the unit tests, I presume?

    Seems reasonable. I couldn’t find any taproot unit tests in this repo, but I suppose you mean https://github.com/bitcoin-core/qa-assets/blob/master/unit_test_data/script_assets_test.json

  19. sanket1729 approved
  20. sanket1729 commented at 0:55 am on February 8, 2021: contributor

    tACK 5e0cd25e29541e6c19559fb5c2555e008ed896fa. I noted this a while ago while fixing feature_taproot.py for elements. Verified that the extreme ranges of CScriptNum are correct and the overflow case for CHECKSIGADD works as intended. Adding 1 to 2^31 - 1 results in an overflow, but the interpreter puts a vch of corresponding to 2^31 on stack. Even though it cannot be converted to CscriptNum(restricted to 4 bytes), it’s result can still be compared by OP_EQUAL.

    There are also some control flow warnings that I discovered. I was not sure if they’re worth fixing because this was test code.

    All of them are of the form:

    0for ...
    1   # declare var in loop
    2   var = 
    3# use var outside loop.
    4f(var)
    

    instances: hashtype and common in https://github.com/bitcoin/bitcoin/blob/6c6140846f37de8c132b3b6abf09f3d7940554a7/test/functional/feature_taproot.py#L668-L672 pubkey1 and eckey1 here: https://github.com/bitcoin/bitcoin/blob/6c6140846f37de8c132b3b6abf09f3d7940554a7/test/functional/feature_taproot.py#L1117

  21. sanket1729 commented at 1:05 am on February 8, 2021: contributor

    If this is merged we’ll have to regenerate the unit tests, I presume?

    I don’t follow this. Is a JSON dump for these used elsewhere?

  22. sipa commented at 1:14 am on February 8, 2021: member

    All of them are of the form:

    That’s allowed in Python. All variables are global or function scope; there is no scope associated with individual code blocks.

    I don’t follow this. Is a JSON dump for these used elsewhere?

    Yes, there is a dump extracted & minimized from the Python tests, that runs as a unit test (see src/test/script.cpp’s script_asset_tests).

    If this is merged we’ll have to regenerate the unit tests, I presume?

    No need to start over, but we should use the additional output generated from this to add more cases to the minimized dump. I’ll do so if nobody else does.

  23. sipa commented at 1:15 am on February 8, 2021: member

    ACK 5e0cd25e29541e6c19559fb5c2555e008ed896fa.

    I think this is a leftover from debugging…

  24. fanquake merged this on Feb 8, 2021
  25. fanquake closed this on Feb 8, 2021

  26. MarcoFalke referenced this in commit 4607019798 on Feb 8, 2021
  27. MarcoFalke commented at 9:28 am on February 8, 2021: member
  28. sidhujag referenced this in commit c694f572c4 on Feb 8, 2021
  29. MarcoFalke referenced this in commit d19639d2b6 on Feb 15, 2021
  30. sidhujag referenced this in commit 41bc01f866 on Feb 15, 2021
  31. brunoerg deleted the branch on Feb 16, 2021
  32. UdjinM6 referenced this in commit 68f62d4e93 on Sep 10, 2021
  33. UdjinM6 referenced this in commit 31b4209318 on Sep 24, 2021
  34. UdjinM6 referenced this in commit 5071a8070b on Oct 4, 2021
  35. UdjinM6 referenced this in commit dbfa92990a on Oct 5, 2021
  36. kittywhiskers referenced this in commit 8949ce83f8 on Oct 12, 2021
  37. pravblockc referenced this in commit 6872c4a44d on Nov 18, 2021
  38. DrahtBot locked this on Aug 16, 2022

github-metadata-mirror

This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 15:12 UTC

This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me