-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathwriter_test.go
More file actions
58 lines (46 loc) · 1.58 KB
/
writer_test.go
File metadata and controls
58 lines (46 loc) · 1.58 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package sender
import (
"context"
"testing"
"github.com/sei-protocol/sei-load/config"
"github.com/sei-protocol/sei-load/generator"
"github.com/sei-protocol/sei-load/generator/scenarios"
"github.com/sei-protocol/sei-load/types"
"github.com/stretchr/testify/require"
)
func TestTxsWriter_Flush(t *testing.T) {
// two evm transfer txs
writer := NewTxsWriter(42000, "/tmp", 1, 1)
loadConfig := &config.LoadConfig{
ChainID: 7777,
}
sharedAccounts := types.NewAccountPool(&types.AccountConfig{
Accounts: types.GenerateAccounts(10),
NewAccountRate: 0.0,
})
evmScenario := scenarios.CreateScenario(config.Scenario{
Name: "EVMTransfer",
Weight: 1,
})
evmScenario.Deploy(loadConfig, sharedAccounts.NextAccount())
generator := generator.NewScenarioGenerator(sharedAccounts, evmScenario)
txs := generator.GenerateN(3)
err := writer.Send(context.Background(), txs[0])
require.NoError(t, err)
require.Equal(t, uint64(1), writer.nextHeight)
require.Equal(t, uint64(21000), writer.bufferGas)
require.Len(t, writer.txBuffer, 1)
require.Equal(t, txs[0], writer.txBuffer[0])
err = writer.Send(context.Background(), txs[1])
require.NoError(t, err)
require.Equal(t, uint64(1), writer.nextHeight)
require.Equal(t, uint64(42000), writer.bufferGas)
require.Len(t, writer.txBuffer, 2)
require.Equal(t, txs[1], writer.txBuffer[1])
err = writer.Send(context.Background(), txs[2])
require.NoError(t, err)
// now should be flushed and have the new tx
require.Equal(t, uint64(2), writer.nextHeight)
require.Equal(t, uint64(21000), writer.bufferGas)
require.Len(t, writer.txBuffer, 1)
}