5
5
"testing"
6
6
"time"
7
7
8
+ "github.com/ethereum/go-ethereum/core"
9
+
8
10
apiv1 "github.com/attestantio/go-builder-client/api/v1"
9
11
"github.com/attestantio/go-eth2-client/spec/bellatrix"
10
12
"github.com/attestantio/go-eth2-client/spec/phase0"
@@ -21,6 +23,13 @@ import (
21
23
)
22
24
23
25
func TestOnPayloadAttributes (t * testing.T ) {
26
+ const (
27
+ validatorDesiredGasLimit = 30_000_000
28
+ payloadAttributeGasLimit = 0
29
+ parentBlockGasLimit = 29_000_000
30
+ )
31
+ expectedGasLimit := core .CalcGasLimit (parentBlockGasLimit , validatorDesiredGasLimit )
32
+
24
33
vsk , err := bls .SecretKeyFromBytes (hexutil .MustDecode ("0x370bb8c1a6e62b2882f6ec76762a67b39609002076b95aae5b023997cf9b2dc9" ))
25
34
require .NoError (t , err )
26
35
validator := & ValidatorPrivateData {
@@ -38,7 +47,7 @@ func TestOnPayloadAttributes(t *testing.T) {
38
47
gvsVd : ValidatorData {
39
48
Pubkey : PubkeyHex (testBeacon .validator .Pk .String ()),
40
49
FeeRecipient : feeRecipient ,
41
- GasLimit : 10 ,
50
+ GasLimit : validatorDesiredGasLimit ,
42
51
},
43
52
}
44
53
@@ -54,14 +63,14 @@ func TestOnPayloadAttributes(t *testing.T) {
54
63
ReceiptsRoot : common.Hash {0x08 , 0x20 },
55
64
LogsBloom : types.Bloom {}.Bytes (),
56
65
Number : uint64 (10 ),
57
- GasLimit : uint64 ( 50 ) ,
66
+ GasLimit : expectedGasLimit ,
58
67
GasUsed : uint64 (100 ),
59
68
Timestamp : uint64 (105 ),
60
69
ExtraData : hexutil .MustDecode ("0x0042fafc" ),
61
70
62
71
BaseFeePerGas : big .NewInt (16 ),
63
72
64
- BlockHash : common .HexToHash ("0xca4147f0d4150183ece9155068f34ee3c375448814e4ca557d482b1d40ee5407 " ),
73
+ BlockHash : common .HexToHash ("0x68e516c8827b589fcb749a9e672aa16b9643437459508c467f66a9ed1de66a6c " ),
65
74
Transactions : [][]byte {},
66
75
}
67
76
@@ -72,7 +81,7 @@ func TestOnPayloadAttributes(t *testing.T) {
72
81
Timestamp : hexutil .Uint64 (104 ),
73
82
Random : common.Hash {0x05 , 0x10 },
74
83
SuggestedFeeRecipient : common.Address {0x04 , 0x10 },
75
- GasLimit : uint64 (21 ),
84
+ GasLimit : uint64 (payloadAttributeGasLimit ),
76
85
Slot : uint64 (25 ),
77
86
}
78
87
@@ -99,6 +108,7 @@ func TestOnPayloadAttributes(t *testing.T) {
99
108
time .Sleep (time .Second * 3 )
100
109
101
110
require .NotNil (t , testRelay .submittedMsg )
111
+
102
112
expectedProposerPubkey , err := utils .HexToPubkey (testBeacon .validator .Pk .String ())
103
113
require .NoError (t , err )
104
114
@@ -108,11 +118,11 @@ func TestOnPayloadAttributes(t *testing.T) {
108
118
BuilderPubkey : builder .builderPublicKey ,
109
119
ProposerPubkey : expectedProposerPubkey ,
110
120
ProposerFeeRecipient : feeRecipient ,
111
- GasLimit : uint64 ( 50 ) ,
121
+ GasLimit : expectedGasLimit ,
112
122
GasUsed : uint64 (100 ),
113
123
Value : & uint256.Int {0x0a },
114
124
}
115
- copy (expectedMessage .BlockHash [:], hexutil .MustDecode ("0xca4147f0d4150183ece9155068f34ee3c375448814e4ca557d482b1d40ee5407 " )[:])
125
+ copy (expectedMessage .BlockHash [:], hexutil .MustDecode ("0x68e516c8827b589fcb749a9e672aa16b9643437459508c467f66a9ed1de66a6c " )[:])
116
126
require .Equal (t , expectedMessage , * testRelay .submittedMsg .Message )
117
127
118
128
expectedExecutionPayload := bellatrix.ExecutionPayload {
@@ -134,7 +144,7 @@ func TestOnPayloadAttributes(t *testing.T) {
134
144
135
145
require .Equal (t , expectedExecutionPayload , * testRelay .submittedMsg .ExecutionPayload )
136
146
137
- expectedSignature , err := utils .HexToSignature ("0xad09f171b1da05636acfc86778c319af69e39c79515d44bdfed616ba2ef677ffd4d155d87b3363c6bae651ce1e92786216b75f1ac91dd65f3b1d1902bf8485e742170732dd82ffdf4decb0151eeb7926dd053efa9794b2ebed1a203e62bb13e9 " )
147
+ expectedSignature , err := utils .HexToSignature ("0x8d1dc346d469b0678ee72baa559315433af0966d2d05dad0de9ce60ff5e4954d4e28a85643496df279494d105bc4a771034fefcdd83d71df5f1b81c9369942b20d6d574b544a93588f6182ba8b09585eb1cf3e1b6551ccbd9e76a4db8eb579fe " )
138
148
139
149
require .NoError (t , err )
140
150
require .Equal (t , expectedSignature , testRelay .submittedMsg .Signature )
@@ -150,7 +160,7 @@ func TestOnPayloadAttributes(t *testing.T) {
150
160
151
161
// Change the hash, expect to get the block
152
162
testExecutableData .ExtraData = hexutil .MustDecode ("0x0042fafd" )
153
- testExecutableData .BlockHash = common .HexToHash ("0x0579b1aaca5c079c91e5774bac72c7f9bc2ddf2b126e9c632be68a1cb8f3fc71 " )
163
+ testExecutableData .BlockHash = common .HexToHash ("0x6a259b9a148da3cc0bf139eaa89292fa9f7b136cfeddad17f7cb0ae33e0c3df9 " )
154
164
testBlock , err = engine .ExecutableDataToBlock (* testExecutableData )
155
165
testEthService .testBlockValue = big .NewInt (10 )
156
166
require .NoError (t , err )
0 commit comments