aboutsummaryrefslogtreecommitdiffstats
path: root/core/transaction_pool_test.go
diff options
context:
space:
mode:
authorJeffrey Wilcke <geffobscura@gmail.com>2015-09-18 17:59:21 +0800
committerJeffrey Wilcke <geffobscura@gmail.com>2015-09-18 17:59:21 +0800
commitb60a27627b32dd0e76269732b834ece1fe7d5c3a (patch)
treee43414be9c8c3aa122ba9934cfece0ef4e730eb6 /core/transaction_pool_test.go
parent985b5f29ed18eac6a36d569edbde6dcfde8d1ab0 (diff)
downloaddexon-b60a27627b32dd0e76269732b834ece1fe7d5c3a.tar
dexon-b60a27627b32dd0e76269732b834ece1fe7d5c3a.tar.gz
dexon-b60a27627b32dd0e76269732b834ece1fe7d5c3a.tar.bz2
dexon-b60a27627b32dd0e76269732b834ece1fe7d5c3a.tar.lz
dexon-b60a27627b32dd0e76269732b834ece1fe7d5c3a.tar.xz
dexon-b60a27627b32dd0e76269732b834ece1fe7d5c3a.tar.zst
dexon-b60a27627b32dd0e76269732b834ece1fe7d5c3a.zip
core: transaction nonce recovery fix
When the transaction state recovery kicked in it assigned the last (incorrect) nonce to the pending state which caused transactions with the same nonce to occur. Added test for nonce recovery
Diffstat (limited to 'core/transaction_pool_test.go')
-rw-r--r--core/transaction_pool_test.go19
1 files changed, 19 insertions, 0 deletions
diff --git a/core/transaction_pool_test.go b/core/transaction_pool_test.go
index 7d0984740..d9267cc43 100644
--- a/core/transaction_pool_test.go
+++ b/core/transaction_pool_test.go
@@ -219,3 +219,22 @@ func TestMissingNonce(t *testing.T) {
t.Error("expected 1 queued transaction, got", len(pool.queue[addr]))
}
}
+
+func TestNonceRecovery(t *testing.T) {
+ const n = 10
+ pool, key := setupTxPool()
+ addr := crypto.PubkeyToAddress(key.PublicKey)
+ pool.currentState().SetNonce(addr, n)
+ pool.currentState().AddBalance(addr, big.NewInt(100000000000000))
+ pool.resetState()
+ tx := transaction(n, big.NewInt(100000), key)
+ if err := pool.Add(tx); err != nil {
+ t.Error(err)
+ }
+ // simulate some weird re-order of transactions and missing nonce(s)
+ pool.currentState().SetNonce(addr, n-1)
+ pool.resetState()
+ if fn := pool.pendingState.GetNonce(addr); fn != n+1 {
+ t.Errorf("expected nonce to be %d, got %d", n+1, fn)
+ }
+}