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-04 #12178

Closed
wants to merge 77 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
77 commits
Select commit Hold shift + click to select a range
2af9ffa
implement MoveInProgressToFatalError
poopoothegorilla Feb 23, 2024
1aa98d3
implement MoveConfirmedMissingReceiptToFatalError
poopoothegorilla Feb 23, 2024
3c301dd
implement MoveUnconfirmedToConfirmedMissingReceipt
poopoothegorilla Feb 23, 2024
659b2fb
implement MoveInProgressToConfirmedMissingReceipt
poopoothegorilla Feb 23, 2024
debfdc9
implement MoveConfirmedToUnconfirmed
poopoothegorilla Feb 23, 2024
c3611e3
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-04
poopoothegorilla Feb 27, 2024
e8ae7f4
implement MoveUnstartedToFatalError
poopoothegorilla Feb 27, 2024
66be6d3
implement UpdateTxFatalError
poopoothegorilla Feb 27, 2024
5153d24
implement SaveConfirmedMissingReceiptAttempts
poopoothegorilla Feb 27, 2024
f91d5ab
implement apply find and delete for address state
poopoothegorilla Feb 27, 2024
42c82ac
implement MarkOldTxesMissingReceiptAsErrored
poopoothegorilla Feb 27, 2024
ef987f4
implement ReapTxHistory
poopoothegorilla Feb 27, 2024
a65204a
implement DeleteInProgressAttempt
poopoothegorilla Feb 27, 2024
b971ee6
implement SaveReplacementInProgressAttempt
poopoothegorilla Feb 27, 2024
b43bdd3
refactor MoveXXXToFatal to MoveTxToFatal
poopoothegorilla Feb 29, 2024
07a2760
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-04
poopoothegorilla Feb 29, 2024
f139fe6
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-04
poopoothegorilla Mar 7, 2024
fbd76d6
address comments
poopoothegorilla Mar 7, 2024
8d3960f
address comments
poopoothegorilla Mar 7, 2024
18b8eb3
address new comments
poopoothegorilla Mar 7, 2024
5d473d8
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-04
poopoothegorilla Mar 13, 2024
433177a
Merge branch 'jtw/step-3-04' into jtw/step-3-04-save-replacement-in-p…
poopoothegorilla Mar 13, 2024
afe6280
initial implementation of SaveReplacementInProgressAttempt
poopoothegorilla Mar 13, 2024
0833ddd
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-04
poopoothegorilla Mar 13, 2024
0583a9f
Merge branch 'jtw/step-3-04' into jtw/step-3-04-save-replacement-in-p…
poopoothegorilla Mar 13, 2024
5af2106
update tests for SaveReplacementInProgressAttempt
poopoothegorilla Mar 13, 2024
09e2eac
Merge branch 'jtw/step-3-04' into jtw/step-3-04-delete-in-progress-at…
poopoothegorilla Mar 13, 2024
82521c3
implement tests for DeleteInProgressAttempt
poopoothegorilla Mar 13, 2024
8f4d145
Merge branch 'jtw/step-3-04' into jtw/step-3-04-reap-tx-history
poopoothegorilla Mar 13, 2024
1cae6ff
Merge branch 'jtw/step-3-04' into jtw/step-3-04-mark-old-txs-missing-…
poopoothegorilla Mar 16, 2024
f74f45a
implement tests for MarkOldTxesMissingReceiptAsErrored
poopoothegorilla Mar 18, 2024
051ebe2
add panic
poopoothegorilla Mar 21, 2024
cbacd55
fix linter issue
poopoothegorilla Mar 21, 2024
4e12e66
Merge branch 'jtw/step-3-in-memory-work' into jtw/step-3-04
poopoothegorilla Mar 21, 2024
da6d235
address comments
poopoothegorilla Mar 21, 2024
0cc19ea
Merge branch 'jtw/step-3-04' into jtw/step-3-04-mark-old-txs-missing-…
poopoothegorilla Mar 21, 2024
39566e9
address comments
poopoothegorilla Mar 21, 2024
b8d09d8
Merge branch 'jtw/step-3-04' into jtw/step-3-04-delete-in-progress-at…
poopoothegorilla Mar 21, 2024
53e0657
address comments
poopoothegorilla Mar 21, 2024
0693806
TXM In-memory: step 3-04-UpdateTxForRebroadcast (#12231)
poopoothegorilla Mar 22, 2024
337f2e1
Merge branch 'jtw/step-3-04' into jtw/step-3-04-mark-old-txs-missing-…
poopoothegorilla Mar 22, 2024
2c485aa
Merge branch 'jtw/step-3-04' into jtw/step-3-04-delete-in-progress-at…
poopoothegorilla Mar 22, 2024
90f1726
Merge branch 'jtw/step-3-04' into jtw/step-3-04-reap-tx-history
poopoothegorilla Mar 22, 2024
9d59e02
TXM In-memory: step 3-04-MarkAllConfirmedMissingReceipt (#12232)
poopoothegorilla Mar 22, 2024
d22d62c
implement tests for ReapTxHistory
poopoothegorilla Mar 22, 2024
6a0b5ad
panic if wrong chain ID
poopoothegorilla Mar 22, 2024
ae2d267
Merge branch 'jtw/step-3-04' into jtw/step-3-04-mark-old-txs-missing-…
poopoothegorilla Mar 22, 2024
991a5f1
Merge pull request #12233 from smartcontractkit/jtw/step-3-04-mark-ol…
poopoothegorilla Mar 22, 2024
52faeec
Merge branch 'jtw/step-3-04' into jtw/step-3-04-delete-in-progress-at…
poopoothegorilla Mar 22, 2024
3381426
remove merge artifacts
poopoothegorilla Mar 22, 2024
0f1c005
fix in memory address stuff
poopoothegorilla Mar 22, 2024
9ea64b8
Merge branch 'jtw/step-3-04' into jtw/step-3-04-reap-tx-history
poopoothegorilla Mar 22, 2024
26d432a
fix merge conflict
poopoothegorilla Mar 22, 2024
f9bd7e6
implement tests for UpdateTxFatalError
poopoothegorilla Mar 25, 2024
056eaf5
Merge branch 'jtw/step-3-04' into jtw/step-3-04-save-confirmed-missin…
poopoothegorilla Mar 25, 2024
b634183
implement tests for SaveConfirmedMissingReceiptAttempt
poopoothegorilla Mar 26, 2024
f2c2e0b
update
poopoothegorilla Mar 26, 2024
6deab0d
Update common/txmgr/address_state.go
poopoothegorilla Apr 1, 2024
d4684a2
Merge pull request #12234 from smartcontractkit/jtw/step-3-04-reap-tx…
poopoothegorilla Apr 1, 2024
8b7af52
Merge branch 'jtw/step-3-04' into jtw/step-3-04-save-replacement-in-p…
poopoothegorilla Apr 1, 2024
b03e6fb
Merge branch 'jtw/step-3-04' into jtw/step-3-04-update-tx-fatal-error
poopoothegorilla Apr 1, 2024
661f877
Merge branch 'jtw/step-3-04' into jtw/step-3-04-save-confirmed-missin…
poopoothegorilla Apr 3, 2024
516c11a
Merge branch 'jtw/step-3-04' into jtw/step-3-04-delete-in-progress-at…
poopoothegorilla Apr 3, 2024
8ae9d72
address coments
poopoothegorilla Apr 3, 2024
3a93992
cleanup
poopoothegorilla Apr 3, 2024
d2e3152
Merge pull request #12235 from smartcontractkit/jtw/step-3-04-delete-…
poopoothegorilla Apr 3, 2024
8e8aea5
Merge branch 'jtw/step-3-04' into jtw/step-3-04-save-replacement-in-p…
poopoothegorilla Apr 3, 2024
9978e9b
address comments
poopoothegorilla Apr 3, 2024
a186281
Merge branch 'jtw/step-3-04' into jtw/step-3-04-save-confirmed-missin…
poopoothegorilla Apr 3, 2024
7de69a4
clean up
poopoothegorilla Apr 3, 2024
6d7923d
Merge branch 'jtw/step-3-04' into jtw/step-3-04-update-tx-fatal-error
poopoothegorilla Apr 3, 2024
493ffed
Merge pull request #12236 from smartcontractkit/jtw/step-3-04-save-re…
poopoothegorilla Apr 4, 2024
4a48dc4
check if transaction exists
poopoothegorilla Apr 4, 2024
33b085b
Merge branch 'jtw/step-3-04' into jtw/step-3-04-update-tx-fatal-error
poopoothegorilla Apr 4, 2024
09e6d61
Merge pull request #12226 from smartcontractkit/jtw/step-3-04-update-…
poopoothegorilla Apr 4, 2024
17fe719
Merge branch 'jtw/step-3-04' into jtw/step-3-04-save-confirmed-missin…
poopoothegorilla Apr 4, 2024
d0f6376
Merge pull request #12230 from smartcontractkit/jtw/step-3-04-save-co…
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
Prev Previous commit
Next Next commit
remove merge artifacts
  • Loading branch information
poopoothegorilla committed Mar 22, 2024
commit 3381426389457dc23ab2a33e93ac1bbf85474879
67 changes: 44 additions & 23 deletions core/chains/evm/txmgr/evm_inmemory_store_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,19 +22,10 @@ import (
"github.com/smartcontractkit/chainlink/v2/core/internal/testutils/pgtest"
)

<<<<<<< HEAD
func TestInMemoryStore_DeleteInProgressAttempt(t *testing.T) {
t.Parallel()

t.Run("successfully replace tx attempt", func(t *testing.T) {
=======
func TestInMemoryStore_MarkOldTxesMissingReceiptAsErrored(t *testing.T) {
t.Parallel()
blockNum := int64(10)
finalityDepth := uint32(2)

t.Run("successfully mark errored transaction", func(t *testing.T) {
>>>>>>> jtw/step-3-04
db := pgtest.NewSqlxDB(t)
_, dbcfg, evmcfg := evmtxmgr.MakeTestConfigs(t)
persistentStore := cltest.NewTestTxStore(t, db)
Expand All @@ -56,34 +47,22 @@ func TestInMemoryStore_MarkOldTxesMissingReceiptAsErrored(t *testing.T) {
require.NoError(t, err)

// Insert a transaction into persistent store
<<<<<<< HEAD
inTx := mustInsertInProgressEthTxWithAttempt(t, persistentStore, 1, fromAddress)
// Insert the transaction into the in-memory store
require.NoError(t, inMemoryStore.XXXTestInsertTx(fromAddress, &inTx))

oldAttempt := inTx.TxAttempts[0]
err = inMemoryStore.DeleteInProgressAttempt(ctx, oldAttempt)
=======
inTx := mustInsertConfirmedMissingReceiptEthTxWithLegacyAttempt(t, persistentStore, 1, 7, time.Now(), fromAddress)
// Insert the transaction into the in-memory store
require.NoError(t, inMemoryStore.XXXTestInsertTx(fromAddress, &inTx))

err = inMemoryStore.MarkOldTxesMissingReceiptAsErrored(ctx, blockNum, finalityDepth, chainID)
>>>>>>> jtw/step-3-04
require.NoError(t, err)

expTx, err := persistentStore.FindTxWithAttempts(ctx, inTx.ID)
require.NoError(t, err)
<<<<<<< HEAD
assert.Equal(t, 0, len(expTx.TxAttempts))
=======
>>>>>>> jtw/step-3-04

fn := func(tx *evmtxmgr.Tx) bool { return true }
actTxs := inMemoryStore.XXXTestFindTxs(nil, fn, inTx.ID)
require.Equal(t, 1, len(actTxs))
actTx := actTxs[0]
<<<<<<< HEAD
assertTxEqual(t, expTx, actTx)
})

Expand Down Expand Up @@ -130,12 +109,54 @@ func TestInMemoryStore_MarkOldTxesMissingReceiptAsErrored(t *testing.T) {
assert.Equal(t, expErr, actErr)
oldAttempt.ID = originalID
})
=======
})
}

func TestInMemoryStore_MarkOldTxesMissingReceiptAsErrored(t *testing.T) {
t.Parallel()
blockNum := int64(10)
finalityDepth := uint32(2)

t.Run("successfully mark errored transaction", func(t *testing.T) {
db := pgtest.NewSqlxDB(t)
_, dbcfg, evmcfg := evmtxmgr.MakeTestConfigs(t)
persistentStore := cltest.NewTestTxStore(t, db)
kst := cltest.NewKeyStore(t, db, dbcfg)
_, fromAddress := cltest.MustInsertRandomKey(t, kst.Eth())

ethClient := evmtest.NewEthClientMockWithDefaultChain(t)
lggr := logger.TestSugared(t)
chainID := ethClient.ConfiguredChainID()
ctx := testutils.Context(t)

inMemoryStore, err := commontxmgr.NewInMemoryStore[
*big.Int,
common.Address, common.Hash, common.Hash,
*evmtypes.Receipt,
evmtypes.Nonce,
evmgas.EvmFee,
](ctx, lggr, chainID, kst.Eth(), persistentStore, evmcfg.Transactions())
require.NoError(t, err)

// Insert a transaction into persistent store
inTx := mustInsertConfirmedMissingReceiptEthTxWithLegacyAttempt(t, persistentStore, 1, 7, time.Now(), fromAddress)
// Insert the transaction into the in-memory store
require.NoError(t, inMemoryStore.XXXTestInsertTx(fromAddress, &inTx))

err = inMemoryStore.MarkOldTxesMissingReceiptAsErrored(ctx, blockNum, finalityDepth, chainID)
require.NoError(t, err)

expTx, err := persistentStore.FindTxWithAttempts(ctx, inTx.ID)
require.NoError(t, err)

fn := func(tx *evmtxmgr.Tx) bool { return true }
actTxs := inMemoryStore.XXXTestFindTxs(nil, fn, inTx.ID)
require.Equal(t, 1, len(actTxs))
actTx := actTxs[0]

assertTxEqual(t, expTx, actTx)
assert.Equal(t, txmgrtypes.TxAttemptBroadcast, actTx.TxAttempts[0].State)
assert.Equal(t, commontxmgr.TxFatalError, actTx.State)
>>>>>>> jtw/step-3-04
})
}

Expand Down
Loading