sendtoaddress subtractfeefromamount=true does not respect paytxfee values #10034

issue cryptogenesis openend this issue on March 19, 2017
  1. cryptogenesis commented at 8:38 am on March 19, 2017: none
    When using subtractfeeamount=true with the sendtoaddress RPC call, the wallet does not always respect paytxfee values and seems to occasionally employ an arbitrary (and very high! 0.004 BTC/KB at latest glance) fee. Strangely, after sending a standard call with subtractfeeamount=false, subsequent calls that include subtractfeeamount=true seem to respect the value set by paytxfee.
  2. jonasschnelli added the label Wallet on Mar 19, 2017
  3. jonasschnelli commented at 8:54 am on March 19, 2017: contributor

    Can you write down some steps to reproduce… a little test told me if working correct. But maybe I’m wrong.

    Started ./src/bitcoind -printtoconsole --regtest --paytxfee=100 Sent with SFA: ./src/bitcoin-cli --regtest sendtoaddress n3NkSZqoPMCQN5FENxUBw4qVATbytH6FDK 1 "" "" true List tx tells me:

     0  "details": [
     1    {
     2      "account": "",
     3      "address": "n3NkSZqoPMCQN5FENxUBw4qVATbytH6FDK",
     4      "category": "send",
     5      "amount": -0.90000000,
     6      "label": "",
     7      "vout": 1,
     8      "fee": -0.10000000,
     9      "abandoned": false
    10    }
    
  4. cryptogenesis commented at 9:00 am on March 19, 2017: none

    Hi Jonas,

    I have a bash script pay.sh that just calls:

    #!/bin/bash bitcoin-cli sendtoaddress $1 $2 "" "" true

    I then call this like ./pay.sh {address} {amount}

    My current info is:

    ~/.bitcoin$ bitcoin-cli getinfo { “version”: 140000, “protocolversion”: 70015, “walletversion”: 130000, “balance”: X.XXXXXXXX, “blocks”: 457937, “timeoffset”: 0, “connections”: XX, “proxy”: “”, “difficulty”: 475705205061.6292, “testnet”: false, “keypoololdest”: 1489899731, “keypoolsize”: 100, “paytxfee”: 0.0016XXXX, “relayfee”: 0.00005000, “errors”: "" }

    I routinely empty this wallet. I also have a CRON running on the hour that adjusts fees to target 5 block confirmation:

    #!/bin/bash FEE="$(bitcoin-cli estimatefee 5)" bitcoin-cli settxfee $FEE

    However, when I call pay.sh for the first time after receiving a deposit, it doesn’t seem to respect the value of paytxfee (and has been paying 0.004 BTC/KB). I noticed that if I call the sendtoaddress command without referencing subtractfeefromamount, and then call my pay.sh script, the subtractfeefromamount will then reference the correctly defined paytxfee. Very odd to say the least.

    I am happy to provide txids privately if you’d like which will demonstrate the behavior above.

    Thank you for taking a look.

  5. MarcoFalke commented at 9:07 am on March 19, 2017: member
    If this only and always happens the fist time you send, there might be a bug in your code to set fees. Otherwise, this is might be an instance of the known issue: https://github.com/bitcoin/bitcoin/blob/baae3149d63909c527e7b28c52c9124957ce8206/src/wallet/wallet.cpp#L2567
  6. MarcoFalke added the label Bug on Mar 19, 2017
  7. MarcoFalke added the label Priority Medium on Mar 19, 2017
  8. MarcoFalke added this to the milestone 0.15.0 on Mar 19, 2017
  9. laanwj assigned morcos on Jul 27, 2017
  10. morcos commented at 7:14 pm on July 27, 2017: member

    @cryptogenesis sorry for the delay, but i’m going to take another look at this. If you’d be willing to point me to a few txid’s, i’m not sure if it will help or not

    morcos at chaincode.com

    Thanks

  11. morcos commented at 9:29 pm on July 27, 2017: member

    @cryptogenesis I opened #10942 to fix a (hopefully very rare) edge case that was not yet fixed. But I’m not sure that’s the cause of your issue.

    You are sure that the estimatefee call wasn’t sometimes causing you to settxfee to a higher feerate?

    I looked through the code and didn’t see anything obviously wrong, but am willing to look more if you have more information (I realize its quite old now).

  12. laanwj referenced this in commit 2e857bb619 on Aug 3, 2017
  13. MarcoFalke commented at 11:44 am on August 3, 2017: member
    Most likely fixed in #10942 by @morcos!
  14. MarcoFalke closed this on Aug 3, 2017

  15. PastaPastaPasta referenced this in commit 63d259e5f5 on Aug 6, 2019
  16. PastaPastaPasta referenced this in commit 0441bf2cbd on Aug 6, 2019
  17. PastaPastaPasta referenced this in commit 778404621a on Aug 6, 2019
  18. PastaPastaPasta referenced this in commit bdc7ca1fdc on Aug 7, 2019
  19. PastaPastaPasta referenced this in commit 4d6bc0e571 on Aug 8, 2019
  20. PastaPastaPasta referenced this in commit e72a2e278f on Aug 12, 2019
  21. barrystyle referenced this in commit 013237fbcd on Jan 22, 2020
  22. MarcoFalke locked this on Sep 8, 2021

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

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