Skip to content
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

TXM In-memory: address_state methods: step 3-03 #12179

Closed
wants to merge 50 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
c740102
implement MoveUnstartedToInProgress
poopoothegorilla Feb 23, 2024
8f538a0
implement MoveConfirmedMissingReceiptToUnconfirmed
poopoothegorilla Feb 23, 2024
13f3959
implement MoveInProgressToUnconfirmed
poopoothegorilla Feb 23, 2024
feabfb7
update attemptHashToTxAttempt map when moving unstarted to inprogress
poopoothegorilla Feb 23, 2024
105ec2d
implement MoveUnconfirmedToConfirmed
poopoothegorilla Feb 23, 2024
54644db
implement MoveUnstartedToFatalError
poopoothegorilla Feb 23, 2024
99a0839
update comments
poopoothegorilla Feb 23, 2024
e5ed75e
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-03
poopoothegorilla Feb 27, 2024
fd8fb43
implement UpdateTxUnstartedToInProgress
poopoothegorilla Feb 27, 2024
8aebf02
implement UpdateTxAttemptInProgressToBroadcast
poopoothegorilla Feb 27, 2024
c038b3d
revert MoveUnstartedToFatalError and move to another branch
poopoothegorilla Feb 27, 2024
063bd25
implement UpdateTxsUnconfirmed
poopoothegorilla Feb 27, 2024
b932bd2
implement SaveFetchedReceipts
poopoothegorilla Feb 27, 2024
a77c3bf
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-03
poopoothegorilla Mar 7, 2024
d320f2c
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-03
poopoothegorilla Mar 12, 2024
42017d6
remove old comment
poopoothegorilla Mar 12, 2024
43f8f9d
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-tx-unstarted-t…
poopoothegorilla Mar 12, 2024
b60751b
fix merge conflicts
poopoothegorilla Mar 12, 2024
dd82fd2
add basic test framework
poopoothegorilla Mar 12, 2024
4926aaa
add findTxs
poopoothegorilla Mar 12, 2024
2a8c010
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-tx-unstarted-t…
poopoothegorilla Mar 12, 2024
5a76c07
implement tests for UpdateTxUnstartedToInProgress
poopoothegorilla Mar 12, 2024
8e4887a
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-txs-unconfirmed
poopoothegorilla Mar 12, 2024
8be0b28
implement tests for UpdateTxsUnconfirmed
poopoothegorilla Mar 12, 2024
ca8ed94
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-tx-attempt-in-…
poopoothegorilla Mar 12, 2024
65de839
fix merge conflicts
poopoothegorilla Mar 12, 2024
3e18438
implement testing for UpdateTxAttemptInProgressToBroadcast
poopoothegorilla Mar 13, 2024
c6deb3f
Merge branch 'jtw/step-3-03' into jtw/step-3-03-save-fetched-receipts
poopoothegorilla Mar 13, 2024
fb54bf8
implement tests for SaveFetchReceipts
poopoothegorilla Mar 13, 2024
14b935c
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-03
poopoothegorilla Mar 21, 2024
5dfe080
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-tx-attempt-in-…
poopoothegorilla Mar 25, 2024
4ccf558
clean up merge conflicts
poopoothegorilla Mar 25, 2024
30d8146
implement tests for UpdateTxAttemptInProgressToBroadcast
poopoothegorilla Mar 25, 2024
9831e0f
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-tx-unstarted-t…
poopoothegorilla Apr 1, 2024
0931887
cleanup and address comments
poopoothegorilla Apr 1, 2024
48ee5fb
fix context
poopoothegorilla Apr 1, 2024
eced7c7
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-txs-unconfirmed
poopoothegorilla Apr 3, 2024
e9aaffe
clean up context in tests
poopoothegorilla Apr 3, 2024
289e524
Merge pull request #12228 from smartcontractkit/jtw/step-3-03-update-…
poopoothegorilla Apr 3, 2024
bd22a27
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-tx-attempt-in-…
poopoothegorilla Apr 3, 2024
2e6c50c
Merge pull request #12225 from smartcontractkit/jtw/step-3-03-update-…
poopoothegorilla Apr 3, 2024
999d23f
Merge branch 'jtw/step-3-03' into jtw/step-3-03-save-fetched-receipts
poopoothegorilla Apr 3, 2024
bdabb35
small cleanup
poopoothegorilla Apr 3, 2024
85290d1
fix issue where tx is not moved to confirmed from unconfirmed
poopoothegorilla Apr 3, 2024
37dc31b
clean up naming
poopoothegorilla Apr 3, 2024
24beab3
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-tx-unstarted-t…
poopoothegorilla Apr 4, 2024
fa0ff89
Merge pull request #12229 from smartcontractkit/jtw/step-3-03-save-fe…
poopoothegorilla Apr 4, 2024
9b12c13
add check for if the transaction exists in memory
poopoothegorilla Apr 4, 2024
698bbf8
Merge branch 'jtw/step-3-03' into jtw/step-3-03-update-tx-unstarted-t…
poopoothegorilla Apr 4, 2024
a4b6104
Merge pull request #12217 from smartcontractkit/jtw/step-3-03-update-…
poopoothegorilla Apr 4, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
implement MoveUnstartedToInProgress
  • Loading branch information
poopoothegorilla committed Feb 23, 2024
commit c7401026ed80b96cd7307d0a114c59639d6c38ce
30 changes: 27 additions & 3 deletions common/txmgr/address_state.go
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
package txmgr

import (
"fmt"
"sync"
"time"

"gopkg.in/guregu/null.v4"

"github.com/smartcontractkit/chainlink-common/pkg/logger"
feetypes "github.com/smartcontractkit/chainlink/v2/common/fee/types"
txmgrtypes "github.com/smartcontractkit/chainlink/v2/common/txmgr/types"
"github.com/smartcontractkit/chainlink/v2/common/types"
"gopkg.in/guregu/null.v4"
)

// AddressState is the state of all transactions for a given address
Expand Down Expand Up @@ -187,10 +189,32 @@ func (as *AddressState[CHAIN_ID, ADDR, TX_HASH, BLOCK_HASH, R, SEQ, FEE]) AddTxT
}

// MoveUnstartedToInProgress moves the next unstarted transaction to the in-progress state.
// The supplied txAttempt is added to the transaction.
// It returns an error if there is already a transaction in progress.
// It returns an error if there is no unstarted transaction to move to in_progress.
func (as *AddressState[CHAIN_ID, ADDR, TX_HASH, BLOCK_HASH, R, SEQ, FEE]) MoveUnstartedToInProgress(
etx *txmgrtypes.Tx[CHAIN_ID, ADDR, TX_HASH, BLOCK_HASH, SEQ, FEE],
txAttempt *txmgrtypes.TxAttempt[CHAIN_ID, ADDR, TX_HASH, BLOCK_HASH, SEQ, FEE],
txID int64, seq SEQ, broadcastAt time.Time, initialBroadcastAt time.Time,
txAttempt txmgrtypes.TxAttempt[CHAIN_ID, ADDR, TX_HASH, BLOCK_HASH, SEQ, FEE],
) error {
as.Lock()
defer as.Unlock()

if as.inprogressTx != nil {
return fmt.Errorf("move_unstarted_to_in_progress: address %s already has a transaction in progress", as.fromAddress)
}

tx := as.unstartedTxs.RemoveTxByID(txID)
if tx == nil {
return fmt.Errorf("move_unstarted_to_in_progress: no unstarted transaction to move to in_progress")
}
tx.State = TxInProgress
tx.TxAttempts = []txmgrtypes.TxAttempt[CHAIN_ID, ADDR, TX_HASH, BLOCK_HASH, SEQ, FEE]{txAttempt}
tx.Sequence = &seq
tx.BroadcastAt = &broadcastAt
tx.InitialBroadcastAt = &initialBroadcastAt

as.inprogressTx = tx

return nil
}

Expand Down