miner: always assume we can build witness blocks #24421

pull glozow wants to merge 1 commits into bitcoin:master from glozow:2022-02-miner-fincludewitness changing 3 files +10 −30
  1. glozow commented at 4:20 pm on February 22, 2022: member
    Given the low possibility of a reorg reverting the segwit soft fork, there is no longer a need to check whether segwit is active to see if it’s okay to add to the block template (see also #23512, #21009, etc). TestBlockValidity() is also run on the block template at the end of CreateNewBlock(), so any invalid block would be caught there.
  2. glozow added the label Mining on Feb 22, 2022
  3. glozow force-pushed on Feb 22, 2022
  4. laanwj commented at 5:24 pm on February 22, 2022: member
    Concept and code review ACK 03c37ccae48fa7cb295f019fc8ca98924634660d
  5. jamesob commented at 5:32 pm on February 22, 2022: member
    Concept ACK
  6. theStack commented at 0:24 am on February 23, 2022: member
    Concept ACK
  7. [miner] always assume we can create witness blocks
    Given the low possibility of a reorg reverting the segwit soft fork,
    there is no need to check whether segwit is active here. Also,
    TestBlockValidity is run on the block template after it has been
    created.
    40e871d9b4
  8. in test/functional/feature_segwit.py:198 in 03c37ccae4 outdated
    196-        self.log.info("Verify witness txs are skipped for mining before the fork")
    197-        self.skip_mine(self.nodes[2], wit_ids[NODE_2][P2WPKH][0], True)  # block 424
    198-        self.skip_mine(self.nodes[2], wit_ids[NODE_2][P2WSH][0], True)  # block 425
    199-        self.skip_mine(self.nodes[2], p2sh_ids[NODE_2][P2WPKH][0], True)  # block 426
    200-        self.skip_mine(self.nodes[2], p2sh_ids[NODE_2][P2WSH][0], True)  # block 427
    201+        self.generate(self.nodes[0], 264)  # block 427
    


    MarcoFalke commented at 7:27 am on February 23, 2022:
    Not really a fan of removing this test. Why not keep it to make the change in behaviour explicit and clarify that mining before segwit is active will result in a json exception?

    glozow commented at 10:57 am on February 23, 2022:
    Done

    jnewbery commented at 6:01 pm on March 9, 2022:
    I disagree. Why do we need to test that a miner on a pre-segwit chain with segwit transactions in its mempool fails to mine a block? If we think that this scenario is possible (and so needs testing), then we shouldn’t make the change in this PR, since failing to mine a block is strictly worse behaviour than mining a block without the segwit transaction.

    glozow commented at 12:44 pm on March 10, 2022:
    I guess this way we have test coverage for “unexpected witness”

    jnewbery commented at 2:03 pm on March 10, 2022:

    I guess this way we have test coverage for “unexpected witness”

    That’s a very indirect way of testing a failure condition in ContextualCheckBlock(). If we want a test for that condition, then we should have a functional test where a non-witness block (which is possible to create even after segwit activation) is stuffed with witness data. That’s a condition that could happen on mainnet, and so isn’t relying on impossible-to-hit-in-production mining code. Even better would be a unit test for ContextualCheckBlock().

    I think it’s inconsistent to remove production code that is “impossible to hit” and then add a test that hits that exact condition.


    MarcoFalke commented at 12:56 pm on March 11, 2022:

    I see the point why this practically doesn’t need test coverage. I also think the changes here are safe to make. However, I think we should still think about the case where our assumptions fail or our expectations aren’t met. It is minimally useful for the test to remind reviewers what will happen in the unexpected case.

    For example, I disagree about:

    failing to mine a block is strictly worse behaviour than mining a block without the segwit transaction.

    If this code path were to be triggerable by an attacker, it would be a strictly better outcome to fail to mine a block before witness than to mine a block. First, a block mined far behind the tip will never be accepted into the main chain and thus never financially rewarded, so there is no benefit of mining it. Second, returning an error early may tell the attacked miner that they have been eclipsed earlier. Third, mining a block (and submitting it, then later reorging it (if it was accepted)) is going to execute more code during the eclipse attack than not mining a block. If there are bugs in the executed code, it gives more tools to the attacker for no benefit. So I think it also serves as a belt-and-suspender.

    Another example (unrelated to this pull request):

    If an attacker could make the blocksdir unusable (until a manual -reindex) by executing a reorg that is large enough that we think it won’t happen, I still think we should fix the bug so that the blocksdir remains usable after any states the software went through.


    glozow commented at 9:10 am on March 15, 2022:
    Removing this test would also fix the “unexpected witness” CI failures
  9. glozow force-pushed on Feb 23, 2022
  10. theStack approved
  11. theStack commented at 11:10 am on February 24, 2022: member
    Code-review ACK 40e871d9b4e55f5b5f7ce2a89157cd3d9f152037
  12. fanquake added this to the milestone 24.0 on Feb 24, 2022
  13. ccdle12 commented at 7:11 pm on March 2, 2022: contributor
    Concept ACK
  14. luke-jr commented at 10:08 pm on March 7, 2022: member
    (See also #19391 for more dead code)
  15. in test/functional/feature_segwit.py:210 in 40e871d9b4
    212         self.log.info("Verify unsigned p2sh witness txs without a redeem script are invalid")
    213         self.fail_accept(self.nodes[2], "mandatory-script-verify-flag-failed (Operation not valid with the current stack size)", p2sh_ids[NODE_2][P2WPKH][1], sign=False)
    214         self.fail_accept(self.nodes[2], "mandatory-script-verify-flag-failed (Operation not valid with the current stack size)", p2sh_ids[NODE_2][P2WSH][1], sign=False)
    215 
    216-        self.generate(self.nodes[2], 4)  # blocks 428-431
    217+        self.generate(self.nodes[0], 4)  # blocks 428-431
    


    otech47 commented at 3:19 pm on March 9, 2022:
    does this test not care which node mines these blocks?

    MarcoFalke commented at 3:52 pm on March 9, 2022:

    No. This is only used to increase the block height, so that the activation height is hit. See also:

    0                "-testactivationheight=segwit@432",
    
  16. jnewbery commented at 6:02 pm on March 9, 2022: member
    utACK 40e871d9b4, although I disagree about changing the test for segwit transaction in mempool before activagtion, instead of just removing it: #24421 (review).
  17. glozow requested review from MarcoFalke on Mar 11, 2022
  18. MarcoFalke approved
  19. MarcoFalke commented at 1:08 pm on March 11, 2022: member

    LGTM.

    I think there is a small theoretical concern that this will make Bitcoin Core internally minimally more inconsistent. See the comment why I initially held back on proposing this pull.

    It is safe to make the changes here, because we assume that the nMinimumChainWork bundled in any release that will include this patch is sufficiently large to make reorg-attacks during IBD while eclipsed prohibitively expensive. The same assumption was made in commit https://github.com/bitcoin/bitcoin/commit/0a8b7b4b33c9d78574627fc606267e2d8955cd1c and https://github.com/bitcoin/bitcoin/pull/23536

  20. achow101 commented at 2:41 pm on March 11, 2022: member
    ACK 40e871d9b4e55f5b5f7ce2a89157cd3d9f152037
  21. fanquake merged this on Mar 11, 2022
  22. fanquake closed this on Mar 11, 2022

  23. glozow deleted the branch on Mar 11, 2022
  24. sidhujag referenced this in commit eec9a795cb on Mar 11, 2022
  25. ajtowns commented at 0:54 am on March 15, 2022: member

    I’m sometimes seeing

    0test_framework.authproxy.JSONRPCException: CreateNewBlock: TestBlockValidity failed: unexpected-witness, ContextualCheckBlock : unexpected witness data found (-1)
    

    from feature_segwit.py, generated by

    0  File "/home/aj/P/bitcoin/bitcoin/chk/test/functional/./feature_segwit.py", line 210, in run_test
    1    self.generate(self.nodes[0], 4)  # blocks 428-431
    

    that looks like it might be due to this PR? (Took about 80 runs to reproduce)

  26. MarcoFalke commented at 7:29 am on March 15, 2022: member
    Probably happens because the witness txs from node 2 are sent to node 0? You can check this by adding a sync_mempools call or maybe even just with the noban permission flag for faster relay.
  27. ajtowns commented at 8:54 am on March 15, 2022: member

    The problem doesn’t appear to get hit prior to this PR (after ~250 runs). Adding self.sync_mempools() prior to generate for blocks 428 appears to make it fail reliably with this PR, while the same change prior to this PR doesn’t seem to cause failures. Adding -whitelist=127.0.0.1 makes the failure more frequent but not quite reliable.

    Seems to me that random test suite failures makes this worth reverting…

  28. glozow commented at 9:03 am on March 15, 2022: member

    Probably happens because the witness txs from node 2 are sent to node 0?

    That’s my guess as well. Can probably fix by disconnecting node0/node2 before generate, and then reconnecting after 431 is mined. But definitely feel free to revert, sorry for missing this!

  29. MarcoFalke commented at 9:22 am on March 15, 2022: member
  30. 78877i referenced this in commit 1e9697bed8 on Mar 15, 2022
  31. jnewbery commented at 4:48 pm on March 17, 2022: member

    I think there are two options:

    My vote would be for removing the invalid test :)

  32. MarcoFalke commented at 4:51 pm on March 17, 2022: member
    #https://github.com/bitcoin/bitcoin/pull/24578 ;)
  33. MarcoFalke referenced this in commit 66e2d21ef2 on Mar 18, 2022
  34. sidhujag referenced this in commit d6df2cc09e on Mar 18, 2022
  35. DrahtBot locked this on Mar 17, 2023

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-21 06:12 UTC

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