You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Merge bitcoin/bitcoin#26720: wallet: coin selection, don't return results that exceed the max allowed weight
25ab147 refactor: coinselector_tests, unify wallet creation code (furszy)
ba9431c test: coverage for bnb max weight (furszy)
5a2bc45 wallet: clean post coin selection max weight filter (furszy)
2d11258 coin selection: BnB, don't return selection if exceeds max allowed tx weight (furszy)
d3a1c09 test: coin selection, add coverage for SRD (furszy)
9d9689e coin selection: heap-ify SRD, don't return selection if exceeds max tx weight (furszy)
6107ec2 coin selection: knapsack, select closest UTXO above target if result exceeds max tx size (furszy)
1284223 wallet: refactor coin selection algos to return util::Result (furszy)
Pull request description:
Coming from the following comment bitcoin/bitcoin#25729 (comment).
The reason why we are adding hundreds of UTXO from different sources when the target
amount is covered only by one of them is because only SRD returns a usable result.
Context:
In the test, we create 1515 UTXOs with 0.033 BTC each, and 1 UTXO with 50 BTC. Then
perform Coin Selection to fund 49.5 BTC.
As the selection of the 1515 small UTXOs exceeds the max allowed tx size, the
expectation here is to receive a selection result that only contain the big UTXO.
Which is not happening for the following reason:
Knapsack returns a result that exceeds the max allowed transaction size, when
it should return the closest utxo above the target, so we fallback to SRD who
selects coins randomly up until the target is met. So we end up with a selection
result with lot more coins than what is needed.
ACKs for top commit:
S3RK:
ACK 25ab147
achow101:
ACK 25ab147
Xekyo:
reACK 25ab147
theStack:
Code-review ACK 25ab147
Tree-SHA512: 2425de4cc479b4db999b3b2e02eb522a2130a06379cca0418672a51c4076971a1d427191173820db76a0f85a8edfff100114e1c38fb3b5dc51598d07cabe1a60
0 commit comments