forked from ethereum-optimism/optimism
-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathcheck_scripts_test.go
82 lines (71 loc) · 2.72 KB
/
check_scripts_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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
package op_e2e
import (
"context"
"testing"
"github.com/ethereum/go-ethereum/common/hexutil"
"github.com/ethereum/go-ethereum/log"
"github.com/stretchr/testify/require"
fjordChecks "github.com/ethereum-optimism/optimism/op-chain-ops/cmd/check-fjord/checks"
"github.com/ethereum-optimism/optimism/op-service/testlog"
)
// TestCheckFjordScript ensures the op-chain-ops/cmd/check-fjord script runs successfully
// against a test chain with the fjord hardfork activated/unactivated
func TestCheckFjordScript(t *testing.T) {
InitParallel(t)
genesisActivation := hexutil.Uint64(0)
tests := []struct {
name string
fjordActivation *hexutil.Uint64
expectErr bool
}{
{
name: "fjord_activated",
fjordActivation: &genesisActivation,
expectErr: false,
},
{
name: "fjord_unactivated",
fjordActivation: nil,
expectErr: true,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
InitParallel(t)
log := testlog.Logger(t, log.LevelInfo)
cfg := DefaultSystemConfig(t)
cfg.DeployConfig.L1CancunTimeOffset = &genesisActivation
cfg.DeployConfig.L2GenesisRegolithTimeOffset = &genesisActivation
cfg.DeployConfig.L2GenesisCanyonTimeOffset = &genesisActivation
cfg.DeployConfig.L2GenesisDeltaTimeOffset = &genesisActivation
cfg.DeployConfig.L2GenesisEcotoneTimeOffset = &genesisActivation
cfg.DeployConfig.L2GenesisFjordTimeOffset = tt.fjordActivation
sys, err := cfg.Start(t)
require.NoError(t, err, "Error starting up system")
defer sys.Close()
checkFjordConfig := &fjordChecks.CheckFjordConfig{
Log: log,
L2: sys.Clients["sequencer"],
Key: sys.Cfg.Secrets.Alice,
Addr: sys.Cfg.Secrets.Addresses().Alice,
}
if tt.expectErr {
err = fjordChecks.CheckRIP7212(context.Background(), checkFjordConfig)
require.Error(t, err, "expected error for CheckRIP7212")
err = fjordChecks.CheckGasPriceOracle(context.Background(), checkFjordConfig)
require.Error(t, err, "expected error for CheckGasPriceOracle")
err = fjordChecks.CheckTxEmpty(context.Background(), checkFjordConfig)
require.Error(t, err, "expected error for CheckTxEmpty")
err = fjordChecks.CheckTxAllZero(context.Background(), checkFjordConfig)
require.Error(t, err, "expected error for CheckTxAllZero")
err = fjordChecks.CheckTxAll42(context.Background(), checkFjordConfig)
require.Error(t, err, "expected error for CheckTxAll42")
err = fjordChecks.CheckTxRandom(context.Background(), checkFjordConfig)
require.Error(t, err, "expected error for CheckTxRandom")
} else {
err = fjordChecks.CheckAll(context.Background(), checkFjordConfig)
require.NoError(t, err, "should not error on CheckAll")
}
})
}
}