-
Notifications
You must be signed in to change notification settings - Fork 2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Resend transactions #11167
Resend transactions #11167
Conversation
@@ -79,6 +91,8 @@ async def create(cls, db_wrapper: DBWrapper): | |||
self.tx_record_cache = {} | |||
self.tx_submitted = {} | |||
self.unconfirmed_for_wallet = {} | |||
self.last_wallet_tx_resend_time = int(time.time()) | |||
self.wallet_tx_resend_timeout_secs = 60 * 60 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this no longer used, I couldn't find any other reference to it in WalletTransactionStore
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's right - I moved this out of WalletTransactionStore. I thought it made it more clear, and better separated the job of WalletTransactionStore. Thank you.
Adam, any tests we can write for this? Also, can you add a brief description to the PR? |
@@ -542,3 +542,6 @@ wallet: | |||
# if an unknown CAT belonging to us is seen, a wallet will be automatically created | |||
# the user accepts the risk/responsibility of verifying the authenticity and origin of unknown CATs | |||
automatically_add_unknown_cats: False | |||
|
|||
# Interval to resend unconfirmed transactions, even if previously accepted into Mempool | |||
tx_resend_timeout_secs: 1800 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm envisioning forgotten transactions accrue in the system over time. And a future where a significant load comes from wallets automatically submitting old transactions that will never make it into a block. Perhaps because their fee is too low, or maybe because they're no longer valid.
Do we stop this resending, and delete transactions if we receive an error from the node we're sending them to?
Do we validate transactions periodically? e.g. that the coins the TX spends are still unspent
(It would be great to cover those cases in tests too)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We do not resend if we get an error from a node, only if we got "pending", and it is not confirmed.
I don't believe we validate on the client side before sending - not a bad idea.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I also think we need to enhance the reporting of which transactions are pending, and maybe add your idea about timing out submitted transactions, but that will have to be in another PR.
@@ -1033,7 +1045,9 @@ async def new_peak_wallet(self, new_peak: wallet_protocol.NewPeakWallet, peer: W | |||
|
|||
if peer.peer_node_id in self.synced_peers: | |||
await self.wallet_state_manager.blockchain.set_finished_sync_up_to(new_peak.height) | |||
await self.wallet_state_manager.new_peak(new_peak) | |||
|
|||
async with self.wallet_state_manager.lock: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can you explain a bit why the lock needs to be held here?
It seems a bit odd to have a lock member of wallet_state_manager
but still require callers to lock it. Couldn't this be done within the new_peak()
function?
current_time = int(time.time()) | ||
|
||
if self.wallet_node.last_wallet_tx_resend_time < current_time - self.wallet_node.wallet_tx_resend_timeout_secs: | ||
self.tx_pending_changed() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I take it this will submit all unconfirmed transactions in the wallet, is that right?
Does that mean that, previously, if you made 1 transaction, then made another one before the first one confirmed, the first would be resent to the network?
As I mentioned above, I think we should be careful to not load the network with unnecessary or redundant transactions, so I think the code should make it clear we're not doing that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yea, there are classes of errors that should likely never retry because they will never actually succeed. I think that will need to wait for a follow-up PR. I think versions < 1.3 always retried the transactions regardless of error as well
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No, this will not resend transactions that have been rejected by that specific peer.
This is handled elsewhere in the code. I agree this is not clear. Bit tangled in here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This will not load the network with unnecessary transactions though, it's only sending them to the nodes you are connected to. These nodes will just ignore it efficiently if they already have it.
2e04578
to
f0ae12c
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, the only think I would change is the following:
Now that we have the overrides, we should use that instead of manually setting the config inside block_tools.py line 196 (BlockTools.__init__
)
This pull request introduces 1 alert when merging 6c95af4 into a4ec7e7 - view on LGTM.com new alerts:
|
isort pre-commit:
|
This pull request introduces 1 alert when merging 3837d27 into 9a07247 - view on LGTM.com new alerts:
|
This pull request has conflicts, please resolve those before we can evaluate the pull request. |
Conflicts have been resolved. A maintainer will review the pull request shortly. |
This pull request has conflicts, please resolve those before we can evaluate the pull request. |
Conflicts have been resolved. A maintainer will review the pull request shortly. |
* Resend transactions (#11167) * Resend transactions * Don't recheck transactions more frequently than timeout * Add wallet resend parameter to config, move timeout code out of tx store, but close to call site * Add a test for wallet transaction resend * Add test for wallet retry * isort new files for precommit and update workflows * Use correct fixture name * LGTM - remove unused import Co-authored-by: Earle Lowe <[email protected]> * less except -> false (#10219) * less except -> false * establish_connection() and .perform_handshake() can just return None * remove more pointless, and no wrong, assertions * Write python version error to stderr (#11239) Co-authored-by: wjblanke <[email protected]> * simplify SizedBytes and StructStream (#11429) * simplify SizedBytes and StructStream * lint * super() !!! * do not pass parameter up to super().__init__() * Update chia/util/struct_stream.py Co-authored-by: Arvid Norberg <[email protected]> * parse fixed-width int data from class name * add int512 and uint128 .from_bytes(), test .parse() failures * test serialization against struct.pack() * use typing_extensions for final * override ignore * stop using struct for StructStream oh the irony * fixup .to_bytes() to accept parameters again for where we use that * bring back signed parameter * format * adjust tests for new exception * eliminate custom coding for uint128 and int512 * tidy * remove unused StructStream.PACK attribute * add direct tests for parse_metadata_from_name() * stricter hinting * remove no-longer-needed typeshed work-around * apply strict type checking to all touched files * remove StructStream override of .to_bytes() * tidy * types touchup * add unused parameter comments Co-authored-by: Arvid Norberg <[email protected]> Co-authored-by: wjblanke <[email protected]> * Allow services to set a non-default max request body size limit (#11516) * updated bls to 13 (#11529) * reduce the redundant computations of coin_ids in block_body_validation (#11530) * add test for streamable -> json conversion (#11527) * add test for streamable -> json conversion * fixup test * Uses the new `from_bytes_unchecked` method in blspy, to improve perfo… (#11463) * Uses the new `from_bytes_unchecked` method in blspy, to improve performance * Update test * Fix merge conflict * Use from_bytes_unchecked in post_init and from_json * More uniform code * rename test files that are missing test_ prefix (#10712) * rename test files that are missing test_ prefix * update mypy and isort excludes * skip test_get_host_addr6() in GitHub Actions under macOS * rebuild workflows * Coin Selection Refactor With CAT Coin Selection Refactor (#9975) * add exact match and best exact match algorithms * optimize algorithm further this might be good. * lint * fix bad logic * add final algorithms * delete lint * oops * Update coin_selection.py * simplify and fix knapsack algoritm * simplify code and correct logic * make it way better. * clarify comments and check for edge cases. * add comments and stuff * improve coin selection addressed comments Thanks! * add coin_selection rpc tests. * clean up and add new unit tests * undo test changes * add extra test cases * move coin_selection to its own function and switch to it for cat and main wallet. * add cat tests * lint * make function align with standards also removed test * make test better * add proper types * Improve code clarity * wallet: fix coin selection bugs * wallet: add an assert just in case * tests: add some sleeps to reduce flakiness * Isort Co-authored-by: Kyle Altendorf <[email protected]> * fix bad merge * lint * fix tests * address aforementioned changes. * remove wallet test * isort * more tests and fixes * lint * rename to amount for coin selection rpc * fix incase we have no smaller coins * fix tests + lint * re add asserts * oops missed me. * lint * fix test * Squashed commit of the following: commit 34a2235 Author: Jack Nelson <[email protected]> Date: Wed Apr 13 10:09:42 2022 -0400 clarify comment commit adbf7f4 Author: Jack Nelson <[email protected]> Date: Tue Apr 12 20:27:05 2022 -0400 linty lint commit 5ebc1ac Author: Jack Nelson <[email protected]> Date: Tue Apr 12 20:17:19 2022 -0400 add failure test and final changes commit 7e5a21b Author: Jack Nelson <[email protected]> Date: Tue Apr 12 19:35:18 2022 -0400 add descriptions and slim down code commit 31c95b9 Merge: d7b9129 d9b0ef5 Author: Jack Nelson <[email protected]> Date: Mon Apr 11 10:12:05 2022 -0400 Merge branch 'jack-cat-coinselection' into jn_coinselection_dust commit d7b9129 Author: Jack Nelson <[email protected]> Date: Sun Apr 10 20:31:09 2022 -0400 lint commit 30dc7c0 Author: Jack Nelson <[email protected]> Date: Sun Apr 10 20:25:52 2022 -0400 fix tests commit 6c8c2e4 Author: Jack Nelson <[email protected]> Date: Thu Mar 31 15:06:00 2022 -0400 remove duplicate code. commit 9f79b6f Author: Jack Nelson <[email protected]> Date: Thu Mar 31 15:01:10 2022 -0400 address more concerns commit 67c1b39 Author: Jack Nelson <[email protected]> Date: Thu Mar 31 12:59:05 2022 -0400 fix logic error commit 2d19a53 Author: Jack Nelson <[email protected]> Date: Thu Mar 31 11:47:52 2022 -0400 simplify and de duplicate code commit 6ab1cc7 Author: Jack Nelson <[email protected]> Date: Wed Mar 30 21:34:50 2022 -0400 add function and select individual coin commit 582c17a Merge: ce21659 618fbae Author: Jack Nelson <[email protected]> Date: Wed Mar 30 21:14:37 2022 -0400 Merge branch 'jack-cat-coinselection' into jn_coinselection_dust commit ce21659 Merge: 16aabb3 6daba28 Author: Jack Nelson <[email protected]> Date: Wed Mar 30 20:53:21 2022 -0400 Merge branch 'jack-cat-coinselection' into jn_coinselection_dust commit 16aabb3 Merge: 0b9fc28 2286fe4 Author: Jack Nelson <[email protected]> Date: Wed Mar 30 20:49:02 2022 -0400 Merge branch 'jack-cat-coinselection' into jn_coinselection_dust commit 0b9fc28 Author: Jack Nelson <[email protected]> Date: Wed Mar 30 20:38:12 2022 -0400 lint commit 62e74c7 Author: Jack Nelson <[email protected]> Date: Wed Mar 30 20:34:22 2022 -0400 fix logic and tests commit e738f44 Author: Jack Nelson <[email protected]> Date: Wed Mar 30 18:52:05 2022 -0400 deal with dust and add tests * make sure that we do not use any dust * minor change * address concerns * adjust comments * adjust comment Co-authored-by: Mariano Sorgente <[email protected]> Co-authored-by: Kyle Altendorf <[email protected]> * rebuild workflows (#11543) * remove the cache from CoinStore. It appears the cost of maintaining the cache outweighs the gains. (#11540) * Keep daemon websocket alive during keyring unlock (#11371) * When prompting to unlock the keyring during daemon launch, it's possible that the daemon websocket connection will timeout before the user has entered their passphrase. We can't quickly detect that the connection has timed-out, so instead we now reconnect after collecting the passphrase, unlock the keyring, and then close the old connection. * mypy fix * Switch to using asyncio.loop.run_in_executor to collect the passphrase on its own thread. * Use a new ThreadPoolExecutor configured with 1 worker thread. * Support searching derived addresses on testnet. (#11449) * Support searching derived addresses on testnet. * Added tests * Optimize code to not perform useless subgroup checks (#11546) * Optimize code to not perform useless subgroup checks * Revert less important optimizations * hints and strict type checking for test_wallet (#11541) * hints and strict type checking for test_wallet * fixup * flip flop * disable pytest-monitor by default (#11507) * disable pytest-monitor by default * take 2 * make recurse_jsonify() work directly on types (#11537) * make recurse_jsonify() work directly on types, circumventing the dataclasses.asdict() step. This enables simpler integration of non dataclasses into the Streamable and JSON protocols * add benchmark for Streamable.to_json_dict() * tests: Split up and improve `test_wallet_rpc.py` (#11552) This breaks up the one big test into ``` test_send_transaction test_create_signed_transaction test_create_signed_transaction_with_coin_announcement test_create_signed_transaction_with_puzzle_announcement test_send_transaction_multi test_get_transactions test_get_transaction_count test_cat_endpoints test_offer_endpoints test_key_and_address_endpoints ``` Note that there is still much more room for improvements. Also the following tests can still be split up more: ``` test_get_transactions test_cat_endpoints test_offer_endpoints test_key_and_address_endpoints ``` * Remove unneeded uint64() intermediate in CAT wallet (#11575) * Get get_args() and get_origin() from typing_extensions (#11571) * Get get_args() and get_origin() from typing_extensions * Update streamable.py * cleanup * Fix several flaky tests (#11576) * Increase some of the timeouts to reduce flakiness * Experiment with CI for flakiness * Force more runs * Add argument name * Fix flaky mempool test * Attempt to fix another flaky test * Fix wallet retry test * Missing arg * Lint * Increase benchmark test time * Debug * Debug * Simplify retry test * Lint * More lint * Return false instead of assert * No need to check disconnect twice (since we don't break, this was flaky) * Remove useless changes * Accidental changes revert * Accidental changes revert 2 * Accidental changes revert 3 * Revert fixture * Fix a few additional flaky tests (#11597) * Fix a few additional flaky tests * Lint * Update tests/core/full_node/stores/test_full_node_store.py Co-authored-by: Jeff <[email protected]> * Fix merge conflict * Remove unnecessary function Co-authored-by: Jeff <[email protected]> * Bind port 0 to fix race condition when grabbing available ports (#11578) * port 0 to fix flakiness * Try fixing setup_full_system * Try fixing setup_full_system, and lint * More attempts to fix * No more calls to get random ports in setup_nodes * Revert accidental changes * Timelord extra arg * Try with port 0 * Fix daemon test, and lint * Try without 0.0.0.0 * Back to 0.0.0.0 * Try a few timelord changes to get test running * Increase timeout again * Use the correct interface to get the port * INFO logging to debug issue * Revert "INFO logging to debug issue" This reverts commit 7c379e5. * Fix advertised port log * Add extra log * Logging back * Rollback the timelord changes * Try port 0 timelord * Revert "Try port 0 timelord" This reverts commit 4997faf. * Try full green, change ordering * Remove unused var * speed up simulation and cleanup * Now try without the port config * Fix a flaky call to get_event_loop * Try getting the port dynamically * No dynamic port * Try changing the ordering * Try adding a sleep * Back to what works * Timelord before vdf clients * Dynamic port for 1st timelord * Revert "Dynamic port for 1st timelord" This reverts commit 0f322a1. * Revert "Timelord before vdf clients" This reverts commit 3286c34. * Revert "Back to what works" This reverts commit 30380df. * Revert "Try adding a sleep" This reverts commit 9212b66. * Revert "Try changing the ordering" This reverts commit a62597d. * Revert "No dynamic port" This reverts commit 5d2e157. * Revert "Try getting the port dynamically" This reverts commit ef9cd75. * Revert "Fix a flaky call to get_event_loop" This reverts commit 01a000f. * Try one to 0 * Just not 0 * Don't get port dynamically * Cleanup a bit * Fix * Some cleanup work * Some cleanup work * Fix daemon test * Cleanup * Remove arguments * restore missing hints being stored as None (instead of 0-length bytes) (#11568) * Coin simplification (#11567) * factor out as_list() from Coin into free function. Remove unused name_str() from Coin. Minor optimization of hash_coin_ids() for common case. * extend Coin unit test * test installer on fedora:36, drop 33 * add tests.util.misc.assert_maximum_duration for benchmark assertions (#11589) * add tests.util.misc.assert_maximum_duration for benchmark assertions * fix some imports * more * lint * correct duration * hint fixup * rename to caller_file_and_line() * set default timer to thread_time() * extract gc manager and default to disabling * self calibrate overhead * wrap none-ness behind .results() method * add messages * from __future__ import annotations * yield out self * final from typing_extensions * split it * just use Future * tweak * tweak * correction in loosely hint checked file * all future indexing in hints * union for the hints * rename * assert_runtime() * another rename... * message -> label * label all results with test names * oops * early return from _set_spent function (#11594) * check for removals before calling function * move condition to function * remove redundant condition (#11582) * fix built-in profiler to work for mac (#11590) * Bump actions/setup-python from 2 to 3 (#10949) * Bump actions/setup-python from 2 to 3 Bumps [actions/setup-python](https://github.com/actions/setup-python) from 2 to 3. - [Release notes](https://github.com/actions/setup-python/releases) - [Commits](actions/setup-python@v2...v3) --- updated-dependencies: - dependency-name: actions/setup-python dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <[email protected]> * Fixup templates for python@v3 Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Gene Hoffman <[email protected]> * avoid cancelling release/** and long_lived/** (#11519) * tests: Some adjustments in `test_offer_endpoints` (#11558) This is a follow up after #11552 which basically used the initial parts of `test_cat_endpoints` to make `test_offer_endpoints` working. Now this PR drops a lot of the stuff we can assume to be not needed in this test because its tested in `test_cat_endpoints` and it adds some general improvments to it. * async sleep and require connection reset error for DoS test (#11612) * fix jsonify bool * Remove is not None and length assertion in select_coins() (#11569) * Remove is not None and length assertion in select_coins() The `coins is not None` check seems unneeded since `select_coins()` is hinted to return `Set[Coin]`. The length requirement needlessly restricts from being able to request a zero amount. Either situation would either trigger an exception in the next assert, or trigger the assert itself for non-zero amounts requested. * also remove from cat_wallet.py * new port 0 stuff Co-authored-by: Adam Kelly <[email protected]> Co-authored-by: Earle Lowe <[email protected]> Co-authored-by: Evan Graham <[email protected]> Co-authored-by: wjblanke <[email protected]> Co-authored-by: Arvid Norberg <[email protected]> Co-authored-by: Mariano Sorgente <[email protected]> Co-authored-by: Jack Nelson <[email protected]> Co-authored-by: Mariano Sorgente <[email protected]> Co-authored-by: Jeff <[email protected]> Co-authored-by: dustinface <[email protected]> Co-authored-by: neurosis69 <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Gene Hoffman <[email protected]> Co-authored-by: William Allen <[email protected]>
This PR periodically resends unconfirmed transactions to peers. This is needed because acceptance of a SpendBundle into the Mempool by a peer does not guarantee that it will be later confirmed, or even transmitted to other peers.
It does this by resetting the remembered results from add to mempool requests that were successful but not confirmed.
Fixes #10873