-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathsimulation_in_mem_test.go
48 lines (41 loc) · 2.34 KB
/
simulation_in_mem_test.go
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
package simulation
import (
"testing"
"time"
"github.com/ten-protocol/go-ten/integration"
"github.com/ten-protocol/go-ten/integration/ethereummock"
"github.com/ten-protocol/go-ten/integration/simulation/network"
"github.com/ten-protocol/go-ten/integration/simulation/params"
)
// This test creates a network of in memory L1 and L2 nodes, then injects transactions, and finally checks the resulting output blockchain.
// Running it long enough with various parameters will test many corner cases without having to explicitly write individual tests for them.
// The unit of time is the "AvgBlockDuration" - which is the average time between L1 blocks, which are the carriers of rollups.
// Everything else is reported to this value. This number has to be adjusted in conjunction with the number of nodes. If it's too low,
// the CPU usage will be very high during the simulation which might give inconclusive results.
func TestInMemoryMonteCarloSimulation(t *testing.T) {
setupSimTestLog("in-mem")
// todo (#718) - try increasing this back to 7 once faster-finality model is optimised
numberOfNodes := 5
numberOfSimWallets := 10
wallets := params.NewSimWallets(numberOfSimWallets, numberOfNodes, integration.EthereumChainID, integration.TenChainID)
simParams := params.SimParams{
NumberOfNodes: numberOfNodes,
// todo (#718) - try reducing this back to 50 milliseconds once faster-finality model is optimised
AvgBlockDuration: 180 * time.Millisecond,
SimulationTime: 45 * time.Second,
L1EfficiencyThreshold: 0.2,
MgmtContractLib: ethereummock.NewMgmtContractLibMock(),
ERC20ContractLib: ethereummock.NewERC20ContractLibMock(),
BlobResolver: ethereummock.NewMockBlobResolver(),
Wallets: wallets,
StartPort: integration.TestPorts.TestInMemoryMonteCarloSimulationPort,
IsInMem: true,
L1TenData: ¶ms.L1TenData{},
ReceiptTimeout: 5 * time.Second,
StoppingDelay: 15 * time.Second,
NodeWithInboundP2PDisabled: 2,
L1BeaconPort: integration.TestPorts.TestInMemoryMonteCarloSimulationPort + integration.DefaultPrysmGatewayPortOffset,
}
simParams.AvgNetworkLatency = simParams.AvgBlockDuration / 15
testSimulation(t, network.NewBasicNetworkOfInMemoryNodes(), &simParams)
}