AssumeUTXO follow-ups #28562

pull fjahr wants to merge 10 commits into bitcoin:master from fjahr:2023-10-au-followups changing 18 files +73 −73
  1. fjahr commented at 10:42 pm on October 2, 2023: contributor

    Addressing what I consider to be non- or not-too-controversial comments from #27596.

    Let me know if I missed anything among the many comments that can be easily included here.

  2. DrahtBot commented at 10:42 pm on October 2, 2023: contributor

    The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.

    Code Coverage

    For detailed information about the code coverage, see the test coverage report.

    Reviews

    See the guideline for information on the review process.

    Type Reviewers
    ACK ryanofsky
    Stale ACK jamesob, Sjors

    If your review is incorrectly listed, please react with 👎 to this comment and the bot will ignore it on the next update.

    Conflicts

    Reviewers, this pull request conflicts with the following ones:

    • #28608 (assumeutxo state and locking cleanup by ryanofsky)

    If you consider this pull request important, please also help to review the conflicting pull requests. Ideally, start with the one that should be merged first.

  3. fjahr force-pushed on Oct 2, 2023
  4. fjahr force-pushed on Oct 2, 2023
  5. fjahr marked this as ready for review on Oct 2, 2023
  6. fanquake requested review from jamesob on Oct 3, 2023
  7. fanquake requested review from ryanofsky on Oct 3, 2023
  8. in src/node/blockstorage.cpp:765 in 26c815b60c outdated
    762     if (cursor) {
    763-        // The cursor may not exist after a snapshot has been loaded but before any
    764-        // blocks have been downloaded.
    765         return FlushBlockFile(cursor->file_num, /*fFinalize=*/false, /*finalize_undo=*/false);
    766     }
    767     return false;
    


    jamesob commented at 8:55 am on October 3, 2023:
    Didn’t @ryanofsky say it might be good to return true; here in order to avoid spurious warnings?

    fjahr commented at 9:17 am on October 3, 2023:
    Right, I saw it but then missed to addressed it. Now added.
  9. jamesob approved
  10. jamesob commented at 8:55 am on October 3, 2023: contributor
  11. in test/functional/feature_assumeutxo.py:164 in 0081d1298e outdated
    161         self.sync_blocks(nodes=(n0, n1))
    162 
    163         self.log.info("Ensuring background validation completes")
    164         # N.B.: the `snapshot` key disappears once the background validation is complete.
    165-        wait_until_helper(lambda: not n1.getchainstates().get('snapshot'))
    166+        wait_until_helper(lambda: not n1.getchainstates().get('snapshot'), timeout_factor=2)
    


    maflcko commented at 11:45 am on October 3, 2023:

    not a fan of overwriting and hard-coding the user-picked timeout factor. Why not use self.wait_until?

    I think it could make sense to rename wait_until_helper to wait_until_helper_internal?


    fjahr commented at 4:36 pm on October 3, 2023:
    all done
  12. maflcko commented at 11:45 am on October 3, 2023: member
    Could also rename HaveTxsDownloaded to HaveNumChainTxs to fix the TODO in the function?
  13. in src/rpc/blockchain.cpp:2860 in 42d585d981 outdated
    2854@@ -2855,6 +2855,9 @@ return RPCHelpMan{
    2855         return data;
    2856     };
    2857 
    2858+    // We present the IBD/background chainstate as "normal" to users, since
    2859+    // it should not matter to them if there is also a snapshot chainstate.
    2860+    // To users, the IBD chainstate should always be considered "normal".
    


    ryanofsky commented at 1:58 pm on October 3, 2023:

    In commit “doc: Add and edit some comments around assumeutxo” (42d585d981350052b00001fa52a895ddca642c11)

    It does not seem accurate that a user would not care if there is a snapshot chainstate, otherwise why would they have loaded a snapshot to begin with?

    I’m not sure exactly which question this comment is trying to answer, but if the goal is just to explain the code maybe it can say “// If a chainstate has m_from_snapshot_blockhash set and there is more than one chainstate, then it a partially validated snapshot chainstate. Otherwise it is a fully validated normal chainstate.”


    fjahr commented at 8:42 pm on October 3, 2023:

    I think we have a simple misunderstanding of my wording, probably my English makes the comment harder to parse than it needs to be :)

    My goal is to explain to developers why we talk about a “normal” chainstate when speaking to the user (via RPC interface) while internally referring to it as ibd/background in the code. I am trying to convey the same thing you said in your comment here: #27596 (review)

    Particularly when you say The idea is for the "normal" chainstate to refer to a typical fully validated chainstate [...] I think the term "IBD chainstate" is basically meaningless because both chainstates are downloaded during IBD. I am trying to say the same thing here: The normal chainstate is the ibd chainstate, no matter if there is a snapshot chainstate or not. Hence “it does not matter” that there is a snapshot with regards to the naming of the ibd/background/normal chainstate from the user perspective.

    I am happy to take suggestions for better wording but I don’t want to just explain what the code does. I want to document the internal/external divergence in the naming of the chainstates for future developers.


    ryanofsky commented at 10:36 pm on October 3, 2023:

    re: #28562 (review)

    Thanks, that is helpful. You’re convincing me it’s not a good idea to add new names and definitions in this RPC.

    I think a good solution would be to get rid of the names entirely and switch to an array. This should be both more clear and more convenient for figuring out the active chain. Something like the following (draft change, untested):

     0--- a/src/rpc/blockchain.cpp
     1+++ b/src/rpc/blockchain.cpp
     2@@ -2807,6 +2807,7 @@ const std::vector<RPCResult> RPCHelpForChainstate{
     3     {RPCResult::Type::STR_HEX, "snapshot_blockhash", /*optional=*/true, "the base block of the snapshot this chainstate is based on, if any"},
     4     {RPCResult::Type::NUM, "coins_db_cache_bytes", "size of the coinsdb cache"},
     5     {RPCResult::Type::NUM, "coins_tip_cache_bytes", "size of the coinstip cache"},
     6+    {RPCResult::Type::BOOL, "validated", "whether the chainstate is fully validated. True if all blocks in the chainstate were validated, false if the chain is based on a snapshot and the snapshot has not yet been validated."},
     7 };
     8 
     9 static RPCHelpMan getchainstates()
    10@@ -2818,8 +2819,7 @@ return RPCHelpMan{
    11         RPCResult{
    12             RPCResult::Type::OBJ, "", "", {
    13                 {RPCResult::Type::NUM, "headers", "the number of headers seen so far"},
    14-                {RPCResult::Type::OBJ, "normal", /*optional=*/true, "fully validated chainstate containing blocks this node has validated starting from the genesis block", RPCHelpForChainstate},
    15-                {RPCResult::Type::OBJ, "snapshot", /*optional=*/true, "only present if an assumeutxo snapshot is loaded. Partially validated chainstate containing blocks this node has validated starting from the snapshot. After the snapshot is validated (when the 'normal' chainstate advances far enough to validate it), this chainstate will replace and become the 'normal' chainstate.", RPCHelpForChainstate},
    16+                {RPCResult::Type::ARR, "chainstates", "list of the chainstates ordered by work, with the most-work (active) chainstate last", RPCHelpForChainstate},
    17             }
    18         },
    19         RPCExamples{
    20@@ -2834,7 +2834,7 @@ return RPCHelpMan{
    21     NodeContext& node = EnsureAnyNodeContext(request.context);
    22     ChainstateManager& chainman = *node.chainman;
    23 
    24-    auto make_chain_data = [&](const Chainstate& cs) EXCLUSIVE_LOCKS_REQUIRED(::cs_main) {
    25+    auto make_chain_data = [&](const Chainstate& cs, bool validated) EXCLUSIVE_LOCKS_REQUIRED(::cs_main) {
    26         AssertLockHeld(::cs_main);
    27         UniValue data(UniValue::VOBJ);
    28         if (!cs.m_chain.Tip()) {
    29@@ -2852,20 +2852,18 @@ return RPCHelpMan{
    30         if (cs.m_from_snapshot_blockhash) {
    31             data.pushKV("snapshot_blockhash", cs.m_from_snapshot_blockhash->ToString());
    32         }
    33+        data.pushKV("validated", validated);
    34         return data;
    35     };
    36 
    37-    if (chainman.GetAll().size() > 1) {
    38-        for (Chainstate* chainstate : chainman.GetAll()) {
    39-            obj.pushKV(
    40-                chainstate->m_from_snapshot_blockhash ? "snapshot" : "normal",
    41-                make_chain_data(*chainstate));
    42-        }
    43-    } else {
    44-        obj.pushKV("normal", make_chain_data(chainman.ActiveChainstate()));
    45-    }
    46     obj.pushKV("headers", chainman.m_best_header ? chainman.m_best_header->nHeight : -1);
    47 
    48+    const auto& chainstates = chainman.GetAll();
    49+    UniValue obj_chainstates{UniValue::VARR};
    50+    for (Chainstate* cs : chainstates) {
    51+      obj_chainstates.push_back(make_chain_data(*cs, !cs->m_from_snapshot_blockhash || chainstates.size() == 1));
    52+    }
    53+    obj.pushKV("chainstates", std::move(obj_chainstates));
    54     return obj;
    55 }
    56     };
    

    The reason for introducing new “normal” and “snapshot” names was just to use terms that could be defined and understood very simply. A “normal” chainstate is a chainstate where every block has been validated. A “snapshot” chainstate is a chainstate loaded from a snapshot where every block has not been validated.

    Exposing these new names was a lot better than exposing our internal “ibd chainstate” and “snapshot chainstate” names which are can’t be defined without reference to temporary implementation details of our code like the fact that IBD snapshot is not deleted until the next node restart after it is done being used. I think these names are also just objectively very bad and add unneeded complexity to our code. I’m working on a change to get rid of them (fb02d9f7cc90f606516e3c3bc55ba177049c4411).

    EDIT: Did some more work on the internal representation change, draft PR is #28608. The getchainstates RPC change was implemented in #28590


    ryanofsky commented at 4:00 pm on October 4, 2023:

    re: #28562 (review)

    I implemented the changes I suggested above in #28590, so will mark this thread resolved to avoid unnecessarily slowing down this PR.


    Sjors commented at 2:29 pm on October 6, 2023:
    21ad0c53760cf051b4daa177885db1358785d17a: this comment can be dropped now afaik since #28590 was merged.

    fjahr commented at 5:02 pm on October 6, 2023:
    yepp, done
  14. fjahr force-pushed on Oct 3, 2023
  15. fjahr commented at 4:37 pm on October 3, 2023: contributor
    Addressed feedback from @MarcoFalke
  16. in test/functional/feature_assumeutxo.py:84 in ce120f73e6 outdated
    80@@ -81,7 +81,7 @@ def run_test(self):
    81         self.sync_blocks()
    82 
    83         def no_sync():
    84-            pass
    85+            self.no_op
    


    ryanofsky commented at 6:48 pm on October 3, 2023:

    In commit “test: Increase timeout tolerance of feature_assumeutxo” (613e8317275ecb0051f9dcea57786aabe7dfdb27)

    This seem strange since it is just referencing the function without calling it. Is it missing ()? Also, it’s not clear why no_op is better than pass. Would be helpful to have a comment.


    fjahr commented at 9:36 pm on October 3, 2023:
    It was actually better to remove no_sync completely and just use self.no_op directly. I think it’s clearer then because we don’t need the same no_op function declaration that we already have in the framework.
  17. in test/functional/feature_assumeutxo.py:159 in ce120f73e6 outdated
    155@@ -156,19 +156,19 @@ def no_sync():
    156         self.connect_nodes(0, 1)
    157 
    158         self.log.info(f"Ensuring snapshot chain syncs to tip. ({FINAL_HEIGHT})")
    159-        wait_until_helper(lambda: n1.getchainstates()['snapshot']['blocks'] == FINAL_HEIGHT)
    160+        self.wait_until(lambda: n1.getchainstates()['snapshot']['blocks'] == FINAL_HEIGHT, timeout=120)
    


    ryanofsky commented at 6:51 pm on October 3, 2023:

    In commit “test: Increase timeout tolerance of feature_assumeutxo” (613e8317275ecb0051f9dcea57786aabe7dfdb27)

    It would be great to eliminate all these duplicate 120s. I’m surprised the test framework doesn’t provide a way to set a default time within the unit tests, but if it doesn’t I think it would be better to just declare a WAIT_TIMEOUT = 120 constant at the top of the test, or add a helper method that calls wait_until.


    maflcko commented at 8:58 pm on October 3, 2023:
    There shouldn’t be a need to pass a timeout value here, unless there is a reason to.

    fjahr commented at 9:35 pm on October 3, 2023:
    @MarcoFalke Did you see @achow101 ’s comment: #27596 (review) ?

    fjahr commented at 9:39 pm on October 3, 2023:
    @ryanofsky I think that’s an interesting idea to set a test-wide default for the wait_until helper, I implemented this here for now but it may be better to pull it out into its own PR… What do you think about this idea @MarcoFalke ?
  18. in src/init.cpp:466 in 949be74b0c outdated
    461@@ -462,8 +462,8 @@ void SetupServerArgs(ArgsManager& argsman)
    462     argsman.AddArg("-prune=<n>", strprintf("Reduce storage requirements by enabling pruning (deleting) of old blocks. This allows the pruneblockchain RPC to be called to delete specific blocks and enables automatic pruning of old blocks if a target size in MiB is provided. This mode is incompatible with -txindex. "
    463             "Warning: Reverting this setting requires re-downloading the entire blockchain. "
    464             "(default: 0 = disable pruning blocks, 1 = allow manual pruning via RPC, >=%u = automatically prune block files to stay under the specified target size in MiB)", MIN_DISK_SPACE_FOR_BLOCK_FILES / 1024 / 1024), ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    465-    argsman.AddArg("-reindex", "Rebuild chain state and block index from the blk*.dat files on disk. This will also rebuild active optional indexes.", ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    466-    argsman.AddArg("-reindex-chainstate", "Rebuild chain state from the currently indexed blocks. When in pruning mode or if blocks on disk might be corrupted, use full -reindex instead.", ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    467+    argsman.AddArg("-reindex", "Rebuild chain state and block index from the blk*.dat files on disk. This will also rebuild active optional indexes. Warning: Not yet validated snapshot chainstates will be removed.", ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    468+    argsman.AddArg("-reindex-chainstate", "Rebuild chain state from the currently indexed blocks. When in pruning mode or if blocks on disk might be corrupted, use full -reindex instead. Warning: Not yet validated snapshot chainstates will be removed.", ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    


    ryanofsky commented at 7:12 pm on October 3, 2023:

    In commit “doc: Add snapshot chainstate removal warning to reindexing documentation” (2bd1d39491f8ad811dcb6d3787e1e18ca0b928ad)

    These warnings seem too alarmist, and also not very actionable. The point of reindex commands is to wipe state and rebuild it. So it should not be surprising that state loaded from an assumeutxo snapshot is also wiped. I think it would be a better to add a clarification instead of a warning here, and a suggestion to reload the snapshot. Maybe: “If an assumeutxo snapshot was loaded and not yet validated, it will need to be reloaded for its chain state to be rebuilt.”


    fjahr commented at 9:35 pm on October 3, 2023:
    Done, adapted with your text.
  19. ryanofsky approved
  20. ryanofsky commented at 7:35 pm on October 3, 2023: contributor
    Code review ACK 69fbb77cff92649c51d5d22e06b3853db928b8e1
  21. DrahtBot requested review from jamesob on Oct 3, 2023
  22. maflcko commented at 8:56 pm on October 3, 2023: member
    Left some more review comments on the parent pull.
  23. fjahr force-pushed on Oct 3, 2023
  24. fjahr commented at 2:43 pm on October 4, 2023: contributor
    The handling of timeouts in feature_assumeutxo was moved out into #28586
  25. fjahr force-pushed on Oct 4, 2023
  26. fanquake commented at 3:09 pm on October 4, 2023: member
    Can you point back to / comment on #27596 in regards to what is fixed / followed up on here, and what still needs fixing? Given there are now a number of post-merge review comments.
  27. ryanofsky approved
  28. ryanofsky commented at 4:11 pm on October 4, 2023: contributor
    Code review ACK 2c9a84136bd4e9bdf7c85296e56364dc6a22f6b2
  29. ryanofsky commented at 4:21 pm on October 4, 2023: contributor

    re: #28562 (comment)

    Can you point back to / comment on #27596 in regards to what is fixed / followed up on here, and what still needs fixing? Given there are now a number of post-merge review comments.

    This would be great, but there are a lot of open review comments on #27596 right now and this PR only addresses a small number of them, so it would be hard to compile a list of what is left and decide what is worth spending time to fix.

    It would be good to comment on #27596 about what things were addressed here, though, so if someone wants to make another PR that addresses other issues that seem important, they can do that after this one.

  30. DrahtBot added the label Needs rebase on Oct 4, 2023
  31. DrahtBot commented at 6:50 pm on October 4, 2023: contributor

    🐙 This pull request conflicts with the target branch and needs rebase.

  32. achow101 referenced this in commit 0b2c93bc56 on Oct 5, 2023
  33. Sjors commented at 12:28 pm on October 6, 2023: member
    Can you give this a rebase? I think 952f03704958ff3f924ddf140fc9eb7663eea118 can be dropped after #28590?
  34. fanquake added this to the milestone 26.0 on Oct 6, 2023
  35. in src/init.cpp:465 in bdee0fd4de outdated
    461@@ -462,8 +462,8 @@ void SetupServerArgs(ArgsManager& argsman)
    462     argsman.AddArg("-prune=<n>", strprintf("Reduce storage requirements by enabling pruning (deleting) of old blocks. This allows the pruneblockchain RPC to be called to delete specific blocks and enables automatic pruning of old blocks if a target size in MiB is provided. This mode is incompatible with -txindex. "
    463             "Warning: Reverting this setting requires re-downloading the entire blockchain. "
    464             "(default: 0 = disable pruning blocks, 1 = allow manual pruning via RPC, >=%u = automatically prune block files to stay under the specified target size in MiB)", MIN_DISK_SPACE_FOR_BLOCK_FILES / 1024 / 1024), ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    465-    argsman.AddArg("-reindex", "Rebuild chain state and block index from the blk*.dat files on disk. This will also rebuild active optional indexes.", ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    466-    argsman.AddArg("-reindex-chainstate", "Rebuild chain state from the currently indexed blocks. When in pruning mode or if blocks on disk might be corrupted, use full -reindex instead.", ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    467+    argsman.AddArg("-reindex", "Rebuild chain state and block index from the blk*.dat files on disk. This will also rebuild active optional indexes. If an assumeutxo snapshot was loaded and not yet validated, it will need to be reloaded for its chain state to be rebuilt.", ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
    


    Sjors commented at 2:31 pm on October 6, 2023:
    bdee0fd4de85c533b799db853c514297cdc22b7c: what does this look like in practice? You start with -reindex and then call the RPC to load the snapshot (in time)?

    ryanofsky commented at 5:08 pm on October 6, 2023:

    re: #28562 (review)

    bdee0fd: what does this look like in practice? You start with -reindex and then call the RPC to load the snapshot (in time)?

    Right, if you want a snapshot to be used after reindexing you have to reload the snapshot. Reindexing wipes and rebuilds chain states, and without a snapshot there is no snapshot chainstate to rebuild.

    Maybe the following would be clearer: “If enabled, wipe chain state and block index, and rebuild them from blk*.dat files on disk. Also wipe and rebuild other optional indexes that are active. If an assumeutxo snapshot was loaded, its chainstate will be wiped as well. The snapshot can then be reloaded via RPC.”


    fjahr commented at 5:44 pm on October 6, 2023:
    Sounds good to me, I am using this and an adapted version for reindex-chainste now.
  36. Sjors commented at 2:33 pm on October 6, 2023: member
    utACK 0b2c93bc560cfb0f6cbf2151bb033d67f2648891 modulo dropping commit 952f03704958ff3f924ddf140fc9eb7663eea118 and its related comment.
  37. DrahtBot requested review from Sjors on Oct 6, 2023
  38. validation: remove unused mempool param in DetectSnapshotChainstate 0a39b8cbd8
  39. doc: Add and edit some comments around assumeutxo
    Co-authored-by: Ryan Ofsky <ryan@ofsky.org>
    a47fbe7d49
  40. test: Improvements of feature_assumeutxo
    - Remove usage of the internal wait_until_helper function
    - Use framework self.no_op instead of new no_sync function
    
    co-authored-by: Andrew Chow <github@achow101.com>
    4e915e926b
  41. fjahr force-pushed on Oct 6, 2023
  42. fjahr force-pushed on Oct 6, 2023
  43. ryanofsky approved
  44. ryanofsky commented at 5:10 pm on October 6, 2023: contributor
    Code review ACK 62db927ab516a91660de0bbf2ca7dc2c8c07ceea. Just new commit removing assumevalid mentions and rebase since last review
  45. doc: Add snapshot chainstate removal warning to reindexing documentation 2c9354facb
  46. validation, test: Improve and document nChainTx check for testability
    Co-authored-by: Ryan Ofsky <ryan@ofsky.org>
    73700fb554
  47. blockstorage: Let FlushChainstateBlockFile return true in case of missing cursor
    Co-authored-by: Ryan Ofsky <ryan@ofsky.org>
    82e48d20f1
  48. chain: Rename HaveTxsDownloaded to HaveNumChainTxs
    Co-authored-by: MarcoFalke <falke.marco@gmail.com>
    a482f86779
  49. test: Rename wait_until_helper to wait_until_helper_internal
    Co-authored-by: MarcoFalke <falke.marco@gmail.com>
    1ff1c34656
  50. doc: Drop references to assumevalid in assumeutxo docs 710e5db61b
  51. rpc: Use Ensure(Any)Chainman in assumeutxo related RPCs 5d227a6862
  52. fjahr force-pushed on Oct 6, 2023
  53. DrahtBot added the label CI failed on Oct 6, 2023
  54. fjahr commented at 5:47 pm on October 6, 2023: contributor
    Rebased, addressed a few more comments, dropped the changes that have been addressed elsewhere in the meantime. I also tried to comment on everything that is addressed here or elsewhere in #27596.
  55. DrahtBot removed the label CI failed on Oct 6, 2023
  56. ryanofsky referenced this in commit 12b3a6b205 on Oct 6, 2023
  57. ryanofsky approved
  58. ryanofsky commented at 10:17 pm on October 6, 2023: contributor
    Code review ACK 5d227a68627614efa8618d360efee22a47afa88b. Just suggested doc change and new EnsureChainman RPC cleanup commit since last review.
  59. fanquake merged this on Oct 7, 2023
  60. fanquake closed this on Oct 7, 2023

  61. in src/validation.cpp:4850 in 73700fb554 outdated
    4849-            assert(pindex->pprev->nChainTx <= pindex->nChainTx);
    4850-        }
    4851+        // Make sure nChainTx sum is correctly computed.
    4852+        unsigned int prev_chain_tx = pindex->pprev ? pindex->pprev->nChainTx : 0;
    4853+        assert((pindex->nChainTx == pindex->nTx + prev_chain_tx)
    4854+               // For testing, allow transaction counts to be completely unset.
    


    maflcko commented at 3:40 pm on October 9, 2023:
    Which testing do you mean? -chain=main -checkblockindex on mainnet?

    fjahr commented at 4:01 pm on October 9, 2023:
    The tests that are changed in the same commit.

    maflcko commented at 6:45 am on October 10, 2023:

    I removed the “testing” check and ran the main binary (not the tests) and it crashed here.

    Generally I don’t think a good place to put test-only code is the main production code. Especially when it comes to consensus critical code. This makes it impossible to properly test and review the code in a production environment outside of unit tests.


    fjahr commented at 3:38 pm on October 10, 2023:

    I removed the “testing” check and ran the main binary (not the tests) and it crashed here.

    Hm, can you say what exactly you removed and what you can to see the crash? I couldn’t reproduce that so far.

    Generally I don’t think a good place to put test-only code is the main production code. Especially when it comes to consensus critical code. This makes it impossible to properly test and review the code in a production environment outside of unit tests.

    I guess we should improve our test setup to include realistic nTx and nChainTx values so we can remove those checks again.


    maflcko commented at 3:43 pm on October 10, 2023:

    I used this diff IIRC, which also fails the functional tests:

     0diff --git a/src/validation.cpp b/src/validation.cpp
     1index 9108f911f0..3bfa5091ad 100644
     2--- a/src/validation.cpp
     3+++ b/src/validation.cpp
     4@@ -4847,10 +4847,7 @@ void ChainstateManager::CheckBlockIndex()
     5         // Make sure nChainTx sum is correctly computed.
     6         unsigned int prev_chain_tx = pindex->pprev ? pindex->pprev->nChainTx : 0;
     7         assert((pindex->nChainTx == pindex->nTx + prev_chain_tx)
     8-               // For testing, allow transaction counts to be completely unset.
     9-               || (pindex->nChainTx == 0 && pindex->nTx == 0)
    10-               // For testing, allow this nChainTx to be unset if previous is also unset.
    11-               || (pindex->nChainTx == 0 && prev_chain_tx == 0 && pindex->pprev));
    12+                 );
    13 
    14         if (pindexFirstAssumeValid == nullptr && pindex->nStatus & BLOCK_ASSUMED_VALID) pindexFirstAssumeValid = pindex;
    15         if (pindexFirstInvalid == nullptr && pindex->nStatus & BLOCK_FAILED_VALID) pindexFirstInvalid = pindex;
    

    maflcko commented at 4:22 pm on November 8, 2023:
    Another report, which could replicate the crash, see #https://github.com/bitcoin/bitcoin/pull/28791

    maflcko commented at 2:39 pm on January 17, 2024:
  62. maflcko removed the label Needs rebase on Oct 10, 2023
  63. ryanofsky referenced this in commit f8701707f1 on Oct 10, 2023
  64. ryanofsky referenced this in commit c6122e4c73 on Oct 11, 2023
  65. ryanofsky referenced this in commit 4ee775ed1e on Oct 12, 2023
  66. ryanofsky referenced this in commit decf338fa5 on Oct 12, 2023
  67. ryanofsky referenced this in commit 2738b971fc on Oct 12, 2023
  68. ryanofsky referenced this in commit 70484b7178 on Oct 12, 2023
  69. Frank-GER referenced this in commit 5c83247e86 on Oct 13, 2023
  70. Frank-GER referenced this in commit 4858ad1038 on Oct 13, 2023
  71. ryanofsky referenced this in commit 638841e2ba on Feb 23, 2024
  72. ryanofsky referenced this in commit 35d0519c47 on Feb 23, 2024
  73. bitcoin locked this on Jan 16, 2025

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 09:12 UTC

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