Block notifications not working with invalidateblock #8698

issue domob1812 openend this issue on September 11, 2016
  1. domob1812 commented at 4:57 pm on September 11, 2016: contributor

    Describe the issue

    The notification callbacks for new blocks / changes to the tip are not invoked when using invalidateblock. This leads, among other things, to the issue with the new waitfornewblock RPC and, consequently, to failures in regression tests using sync_blocks and invalidateblock to trigger reorgs. (I’m not sure if that involves any of the official regression tests, but it can be observed with custom tests.)

    This seems to be strongly related to #5806.

    As far as I can tell, the problem is that InvalidateBlock (as called from the invalidateblock RPC handler) already changes chainActive.Tip(), and then ActivateBestChain (which is supposed to trigger the notifications and other updates) returns early as the most work block is already the chain tip.

    I’d like to fix the issue, but do not feel confident enough with the involved code to decide how to best do it. I see two straight-forward solutions, which both have their pros and cons - I’d be grateful for any insights into which one (if any of them) is the correct:

    1. Trigger the notifications and updates from ActivateBestChain even if the most work block is already the chain tip. This seems clean and straight-forward, but I’m not sure if ActivateBestChain might be called even without any changes done to the chain, in which case it would yield spurious notification calls. Is this possible?
    2. InvalidateBlock is only called from the invalidateblock RPC and is a somewhat special situation. We could manually trigger the same notifications as ActivateBestChain does from there. This requires to either duplicate the notification and update code or factor it out into a new function, and feels less clean.

    Is the issue reproducible?

    List steps to reproduce below:

    1. Run a regtest mode daemon.
    2. Call waitfornewblock.
    3. Call invalidateblock on the currently best block.

    Expected behavior

    waitfornewblock should return with the new best block (i. e., the block that was previously the one just before the tip).

    Actual behavior

    The change to the chain tip is not noticed and waitfornewblock keeps on waiting.

  2. jonasschnelli added the label RPC/REST/ZMQ on Sep 12, 2016
  3. domob1812 referenced this in commit 20cad46272 on Oct 6, 2016
  4. domob1812 referenced this in commit a322b829a4 on Oct 7, 2016
  5. TheBlueMatt commented at 10:47 pm on October 31, 2019: member
    I think this is the correct behavior - its not a “new” block, and I presume it’ll be fine after the next block comes in.
  6. MarcoFalke closed this on May 8, 2020

  7. DrahtBot locked this on Feb 15, 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-15 12:12 UTC

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