mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-01-18 22:35:39 +01:00
wallet: trigger MaybeResendWalletTxs() every minute
ResendWalletTransactions() only executes every 12-36h (24h average). Triggering it every second is excessive, once per minute should be plenty.
This commit is contained in:
@@ -151,7 +151,7 @@ void StartWallets(WalletContext& context, CScheduler& scheduler)
|
||||
if (context.args->GetBoolArg("-flushwallet", DEFAULT_FLUSHWALLET)) {
|
||||
scheduler.scheduleEvery([&context] { MaybeCompactWalletDB(context); }, std::chrono::milliseconds{500});
|
||||
}
|
||||
scheduler.scheduleEvery([&context] { MaybeResendWalletTxs(context); }, std::chrono::milliseconds{1000});
|
||||
scheduler.scheduleEvery([&context] { MaybeResendWalletTxs(context); }, 1min);
|
||||
}
|
||||
|
||||
void FlushWallets(WalletContext& context)
|
||||
|
||||
@@ -29,11 +29,11 @@ class ResendWalletTransactionsTest(BitcoinTestFramework):
|
||||
self.log.info("Create a new transaction and wait until it's broadcast")
|
||||
txid = node.sendtoaddress(node.getnewaddress(), 1)
|
||||
|
||||
# Wallet rebroadcast is first scheduled 1 sec after startup (see
|
||||
# Wallet rebroadcast is first scheduled 1 min sec after startup (see
|
||||
# nNextResend in ResendWalletTransactions()). Tell scheduler to call
|
||||
# MaybeResendWalletTxn now to initialize nNextResend before the first
|
||||
# setmocktime call below.
|
||||
node.mockscheduler(1)
|
||||
node.mockscheduler(60)
|
||||
|
||||
# Can take a few seconds due to transaction trickling
|
||||
peer_first.wait_for_broadcast([txid])
|
||||
@@ -60,7 +60,7 @@ class ResendWalletTransactionsTest(BitcoinTestFramework):
|
||||
twelve_hrs = 12 * 60 * 60
|
||||
two_min = 2 * 60
|
||||
node.setmocktime(now + twelve_hrs - two_min)
|
||||
node.mockscheduler(1) # Tell scheduler to call MaybeResendWalletTxn now
|
||||
node.mockscheduler(60) # Tell scheduler to call MaybeResendWalletTxn now
|
||||
assert_equal(int(txid, 16) in peer_second.get_invs(), False)
|
||||
|
||||
self.log.info("Bump time & check that transaction is rebroadcast")
|
||||
@@ -69,7 +69,7 @@ class ResendWalletTransactionsTest(BitcoinTestFramework):
|
||||
with node.assert_debug_log(['ResendWalletTransactions: resubmit 1 unconfirmed transactions']):
|
||||
node.setmocktime(now + 36 * 60 * 60)
|
||||
# Tell scheduler to call MaybeResendWalletTxn now.
|
||||
node.mockscheduler(1)
|
||||
node.mockscheduler(60)
|
||||
# Give some time for trickle to occur
|
||||
node.setmocktime(now + 36 * 60 * 60 + 600)
|
||||
peer_second.wait_for_broadcast([txid])
|
||||
|
||||
Reference in New Issue
Block a user