test: add assumeutxo wallet test #28838
pull Sjors wants to merge 1 commits into bitcoin:master from Sjors:2023/11/test-wallet-assume changing 2 files +165 −0-
Sjors commented at 1:15 am on November 10, 2023: memberExtracted from #28616, this adds a (very) basic wallet test for assume utxo. It checks some circumstances where a backup can and can’t be loaded.
-
DrahtBot commented at 1:15 am on November 10, 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 theStack, maflcko, achow101 Concept ACK BrandonOdiwuor Stale ACK pablomartin4btc 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:
- #28616 (Show transactions as not fully confirmed during background validation by Sjors)
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.
-
DrahtBot added the label Tests on Nov 10, 2023
-
in test/functional/wallet_assumeutxo.py:87 in 0b81433961 outdated
82+ 83+ # Ensure everyone is seeing the same headers. 84+ for n in self.nodes: 85+ assert_equal(n.getblockchaininfo()["headers"], SNAPSHOT_BASE_HEIGHT) 86+ 87+ w.backupwallet("/tmp/abc.dat")
maflcko commented at 8:50 am on November 10, 2023:My diff was a hack, obviously. I don’t think it makes sense to escape the datadir “sandbox” and potentially overwrite user data when running a test.in test/functional/wallet_assumeutxo.py:10 in 0b81433961 outdated
5+"""Test for assumeutxo wallet related behavior. 6+See feature_assumeutxo.py for background. 7+ 8+## Possible test improvements 9+ 10+- TODO: the "assumed" field for a confirmed wallet transaction should be
maflcko commented at 8:51 am on November 10, 2023:Seems odd to add a TODO to add a test based on a feature that doesn’t even exist.
Sjors commented at 6:29 am on November 13, 2023:Droppedin test/functional/wallet_assumeutxo.py:66 in 0b81433961 outdated
61+ for n in self.nodes: 62+ n.setmocktime(n.getblockheader(n.getbestblockhash())['time']) 63+ 64+ self.sync_blocks() 65+ 66+ n0.createwallet('test',blank=True, disable_private_keys=True, descriptors=True)
maflcko commented at 8:52 am on November 10, 2023:nit:blank
may not be needed? Also, could run a python formatter on this file to fix the whitespace?
Sjors commented at 6:25 am on November 13, 2023:Might indeed just give the wallet some keys, so later tests can have transactions and rescans.
Which formatter? Ah PEP-8 https://github.com/bitcoin/bitcoin/tree/master/test/functional#style-guidelines
in test/functional/wallet_assumeutxo.py:76 in 0b81433961 outdated
71+ # Generate a series of blocks that `n0` will have in the snapshot, 72+ # but that n1 doesn't yet see. In order for the snapshot to activate, 73+ # though, we have to ferry over the new headers to n1 so that it 74+ # isn't waiting forever to see the header of the snapshot's base block 75+ # while disconnected from n0. 76+ for i in range(100):
brunoerg commented at 1:45 pm on November 10, 2023:In 0b8143396183d23e215fc90a2d24813ad1b7ad23: nit
0 for _ in range(100):
Sjors force-pushed on Nov 13, 2023Sjors commented at 6:43 am on November 13, 2023: memberPushed some cleanups.in test/functional/wallet_assumeutxo.py:33 in f4f3a0c910 outdated
28+ """Use the pregenerated, deterministic chain up to height 199.""" 29+ self.num_nodes = 2 30+ self.rpc_timeout = 120 31+ self.extra_args = [ 32+ [], 33+ ["-fastprune", "-prune=1"]
maflcko commented at 8:47 am on November 13, 2023:Could add a comment why this is needed?
Sjors commented at 11:13 am on November 13, 2023:It’s not. Replaced with a TODO comment to add wallet test for a pruned node.
achow101 commented at 2:14 pm on November 28, 2023:It doesn’t seem like this was pushed?in test/functional/wallet_assumeutxo.py:62 in f4f3a0c910 outdated
57+ self.sync_blocks() 58+ 59+ n0.createwallet('w') 60+ w = n0.get_wallet_rpc("w") 61+ 62+ w.importdescriptors([{"desc": "addr(mjTkW3DjgyZck4KbiRusZsqTgaYTxdSz6z)#jdtmxdcm",
Sjors commented at 11:13 am on November 13, 2023:Also dropping this import since the wallet is no longer watch-only. I added a TODO instead to test scenarios like when you import a descriptor with existing transactions while background sync is in progress.
achow101 commented at 2:14 pm on November 28, 2023:It doesn’t seem like this was pushed?test: add assumeutxo wallet test
Co-Authored-By: MarcoFalke <*~=`'#}+{/-|&$^_@721217.xyz>
pablomartin4btc commented at 10:55 pm on November 25, 2023: membermaflcko commented at 9:32 am on November 27, 2023: memberlgtm ACK f4f3a0c910a148a158e1879f8c9e6767575539dbSjors force-pushed on Nov 28, 2023Sjors commented at 3:24 pm on November 28, 2023: member@achow101 good catch, I indeed forgot to push. @pablomartin4btc I think he likes it this wayBrandonOdiwuor commented at 8:58 am on December 29, 2023: contributorConcept ACKtheStack commented at 12:43 pm on January 10, 2024: contributorConcept ACK
Will review in a bit. As a follow-up idea, maybe we could put the AssumeUTXO chain and snapshot creation in a shared module, in order to deduplicate code between feature_assumeutxo.py and wallet_assumeutxo.py? If we ever wanted to change the snapshot chainstate for e.g. more advanced tests, it’d be quite annoying having to touch several files.
glozow referenced this in commit 632a2bb731 on Jan 10, 2024in test/functional/wallet_assumeutxo.py:82 in 997b9a73e5
77+ n1.submitheader(newblock) 78+ 79+ # Ensure everyone is seeing the same headers. 80+ for n in self.nodes: 81+ assert_equal(n.getblockchaininfo()[ 82+ "headers"], SNAPSHOT_BASE_HEIGHT)
theStack commented at 5:49 pm on January 10, 2024:nit: looks like an unintended newline here?
0 assert_equal(n.getblockchaininfo()["headers"], SNAPSHOT_BASE_HEIGHT)
theStack approvedtheStack commented at 5:51 pm on January 10, 2024: contributorCode-review ACK 997b9a73e5166b4244f7c5b4fe144d524f3005f4
Also ran the test locally.
DrahtBot requested review from pablomartin4btc on Jan 10, 2024DrahtBot requested review from maflcko on Jan 10, 2024DrahtBot requested review from BrandonOdiwuor on Jan 10, 2024DrahtBot removed review request from BrandonOdiwuor on Jan 10, 2024DrahtBot requested review from BrandonOdiwuor on Jan 10, 2024maflcko commented at 10:16 am on January 11, 2024: memberlgtm ACK 997b9a73e5166b4244f7c5b4fe144d524f3005f4DrahtBot removed review request from maflcko on Jan 11, 2024DrahtBot removed review request from BrandonOdiwuor on Jan 11, 2024DrahtBot requested review from BrandonOdiwuor on Jan 11, 2024achow101 commented at 4:23 pm on January 11, 2024: memberACK 997b9a73e5166b4244f7c5b4fe144d524f3005f4DrahtBot removed review request from BrandonOdiwuor on Jan 11, 2024DrahtBot requested review from BrandonOdiwuor on Jan 11, 2024achow101 merged this on Jan 11, 2024achow101 closed this on Jan 11, 2024
jamesob commented at 4:31 pm on January 11, 2024: contributorPosthumous ACK https://github.com/bitcoin/bitcoin/commit/997b9a73e5166b4244f7c5b4fe144d524f3005f4
Was just in the middle of reviewing this and figuring out how to add some balance checks. May file a followup.
maflcko commented at 4:58 pm on January 11, 2024: memberhttps://github.com/bitcoin/bitcoin/actions/runs/7491713362/job/20393561752?pr=29218#step:27:7881
0 test_framework.authproxy.JSONRPCException: remove_all: The process cannot access the file because it is being used by another process.: "D:\a\_temp\test_runner_?_??_20240111_163825\wallet_assumeutxo_47\node1\regtest\w" (-1)
Sjors deleted the branch on Jan 12, 2024in test/functional/wallet_assumeutxo.py:84 in 997b9a73e5
79+ # Ensure everyone is seeing the same headers. 80+ for n in self.nodes: 81+ assert_equal(n.getblockchaininfo()[ 82+ "headers"], SNAPSHOT_BASE_HEIGHT) 83+ 84+ w.backupwallet("backup_w.dat")
Sjors commented at 6:16 pm on January 12, 2024:From reading the test again (it’s a been a while) I don’t think we care about this loaded walletw
anymore.
achow101 commented at 6:16 pm on January 12, 2024:I don’t think the problem is that the original wallet is open. The error is the path for the restored wallet on node1, not the original on node0.
achow101 commented at 6:25 pm on January 12, 2024:Sounds like the node that made the backup holds on to it after writing? Maybe restart the node? Or copy the backup file?
We don’t remove the backup. The failure is in cleaning up the restored wallet after it fails to restore. The backup file is copied to a new path, and that is what
remove_all
is trying to remove.I think it’s more likely that the database isn’t fully closed yet even though the
CWallet
should be destructed.
Sjors commented at 6:30 pm on January 12, 2024:Ok, so it has nothing to do with what n0 did. I’m surprised none of the other wallet backup & restore tests have this issue. But I guess it’s a different failure condition.
achow101 commented at 6:32 pm on January 12, 2024:It looks like we don’t have any other tests that have a failure inCWallet::Create
, which I don’t think is that surprising since generally the wallet needs to be corrupted for that to happen.
achow101 commented at 6:45 pm on January 12, 2024:I think it’s more likely that the database isn’t fully closed yet even though the
CWallet
should be destructed.Maybe it’s because of
-unsafesqlitesync
, going to try turning that off for the test.
Sjors commented at 6:51 pm on January 12, 2024:I wonder why it’s called unsafe :-)bitcoin locked this on Jan 11, 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