mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-04-29 23:09:44 -04:00
0.18: wallet: Fix -maxtxfee check by moving it to CWallet::CreateTransaction
Github-Pull: #16322
Rebased-From: 5c1b9714cb
This commit is contained in:
parent
8f354ced6e
commit
a11dbaa547
3 changed files with 16 additions and 6 deletions
|
@ -2690,11 +2690,6 @@ bool CWallet::FundTransaction(CMutableTransaction& tx, CAmount& nFeeRet, int& nC
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nFeeRet > maxTxFee) {
|
|
||||||
strFailReason = _("Fee exceeds maximum configured by -maxtxfee");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3131,6 +3126,11 @@ bool CWallet::CreateTransaction(interfaces::Chain::Lock& locked_chain, const std
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (nFeeRet > maxTxFee) {
|
||||||
|
strFailReason = _("Fee exceeds maximum configured by -maxtxfee");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (gArgs.GetBoolArg("-walletrejectlongchains", DEFAULT_WALLET_REJECT_LONG_CHAINS)) {
|
if (gArgs.GetBoolArg("-walletrejectlongchains", DEFAULT_WALLET_REJECT_LONG_CHAINS)) {
|
||||||
// Lastly, ensure this tx will pass the mempool's chain limits
|
// Lastly, ensure this tx will pass the mempool's chain limits
|
||||||
LockPoints lp;
|
LockPoints lp;
|
||||||
|
|
|
@ -134,7 +134,7 @@ class PSBTTest(BitcoinTestFramework):
|
||||||
assert_greater_than(0.06, res["fee"])
|
assert_greater_than(0.06, res["fee"])
|
||||||
|
|
||||||
# feeRate of 10 BTC / KB produces a total fee well above -maxtxfee
|
# feeRate of 10 BTC / KB produces a total fee well above -maxtxfee
|
||||||
# previously this was silenty capped at -maxtxfee
|
# previously this was silently capped at -maxtxfee
|
||||||
assert_raises_rpc_error(-4, "Fee exceeds maximum configured by -maxtxfee", self.nodes[1].walletcreatefundedpsbt, [{"txid":txid,"vout":p2wpkh_pos},{"txid":txid,"vout":p2sh_p2wpkh_pos},{"txid":txid,"vout":p2pkh_pos}], {self.nodes[1].getnewaddress():29.99}, 0, {"feeRate": 10})
|
assert_raises_rpc_error(-4, "Fee exceeds maximum configured by -maxtxfee", self.nodes[1].walletcreatefundedpsbt, [{"txid":txid,"vout":p2wpkh_pos},{"txid":txid,"vout":p2sh_p2wpkh_pos},{"txid":txid,"vout":p2pkh_pos}], {self.nodes[1].getnewaddress():29.99}, 0, {"feeRate": 10})
|
||||||
|
|
||||||
# partially sign multisig things with node 1
|
# partially sign multisig things with node 1
|
||||||
|
|
|
@ -73,6 +73,7 @@ class BumpFeeTest(BitcoinTestFramework):
|
||||||
test_unconfirmed_not_spendable(rbf_node, rbf_node_address)
|
test_unconfirmed_not_spendable(rbf_node, rbf_node_address)
|
||||||
test_bumpfee_metadata(rbf_node, dest_address)
|
test_bumpfee_metadata(rbf_node, dest_address)
|
||||||
test_locked_wallet_fails(rbf_node, dest_address)
|
test_locked_wallet_fails(rbf_node, dest_address)
|
||||||
|
test_maxtxfee_fails(self, rbf_node, dest_address)
|
||||||
self.log.info("Success")
|
self.log.info("Success")
|
||||||
|
|
||||||
|
|
||||||
|
@ -204,6 +205,15 @@ def test_settxfee(rbf_node, dest_address):
|
||||||
rbf_node.settxfee(Decimal("0.00000000")) # unset paytxfee
|
rbf_node.settxfee(Decimal("0.00000000")) # unset paytxfee
|
||||||
|
|
||||||
|
|
||||||
|
def test_maxtxfee_fails(test, rbf_node, dest_address):
|
||||||
|
test.restart_node(1, ['-maxtxfee=0.00003'] + test.extra_args[1])
|
||||||
|
rbf_node.walletpassphrase(WALLET_PASSPHRASE, WALLET_PASSPHRASE_TIMEOUT)
|
||||||
|
rbfid = spend_one_input(rbf_node, dest_address)
|
||||||
|
assert_raises_rpc_error(-4, "Specified or calculated fee 0.0000332 is too high (cannot be higher than maxTxFee 0.00003)", rbf_node.bumpfee, rbfid)
|
||||||
|
test.restart_node(1, test.extra_args[1])
|
||||||
|
rbf_node.walletpassphrase(WALLET_PASSPHRASE, WALLET_PASSPHRASE_TIMEOUT)
|
||||||
|
|
||||||
|
|
||||||
def test_rebumping(rbf_node, dest_address):
|
def test_rebumping(rbf_node, dest_address):
|
||||||
# check that re-bumping the original tx fails, but bumping the bumper succeeds
|
# check that re-bumping the original tx fails, but bumping the bumper succeeds
|
||||||
rbfid = spend_one_input(rbf_node, dest_address)
|
rbfid = spend_one_input(rbf_node, dest_address)
|
||||||
|
|
Loading…
Add table
Reference in a new issue