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 processors
import (
"encoding/json"
"testing"
"github.com/stretchr/testify/require"
"github.com/ethereum/go-ethereum/common"
ethTypes "github.com/ethereum/go-ethereum/core/types"
"github.com/ethereum-optimism/optimism/op-supervisor/supervisor/types"
)
func TestDecodeExecutingMessageLog(t *testing.T) {
data := `
{
"address": "0x4200000000000000000000000000000000000022",
"topics": [
"0x5c37832d2e8d10e346e55ad62071a6a2f9fa5130614ef2ec6617555c6f467ba7",
"0xc3f57e1f0dd62a4f77787d834029bfeaab8894022c47edbe13b044fb658c9190"
],
"data": "0x0000000000000000000000005fbdb2315678afecb367f032d93f642f64180aa3000000000000000000000000000000000000000000000000000000000000119d0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000006724d56300000000000000000000000000000000000000000000000000000000000dbc68",
"blockHash": "0x355b82e9db9105fe3e7b7ed1897878ecbba8be7f30f94aca9dc55b6296a624cf",
"blockNumber": "0x13a8",
"transactionHash": "0x6eb22bb67562ac6a8fdbf60d6227c0b1f3f9d1d15ead1b0de055358f4fb9fa69",
"transactionIndex": "0x2",
"logIndex": "0x0",
"removed": false
}
`
var logEvent ethTypes.Log
require.NoError(t, json.Unmarshal([]byte(data), &logEvent))
msg, err := DecodeExecutingMessageLog(&logEvent)
require.NoError(t, err)
require.NotNil(t, msg)
// struct Identifier {
// address origin;
// uint256 blockNumber;
// uint256 logIndex;
// uint256 timestamp;
// uint256 chainId;
// }
// function executeMessage(Identifier calldata _id,
// address _target, bytes calldata _message) external payable;
originAddr := common.HexToAddress("0x5fbdb2315678afecb367f032d93f642f64180aa3")
payloadHash := common.HexToHash("0xc3f57e1f0dd62a4f77787d834029bfeaab8894022c47edbe13b044fb658c9190")
logHash := types.PayloadHashToLogHash(payloadHash, originAddr)
require.Equal(t, logHash, msg.Hash)
require.Equal(t, uint64(4509), msg.BlockNum)
require.Equal(t, uint32(0), msg.LogIdx)
require.Equal(t, uint64(1730467171), msg.Timestamp)
require.Equal(t, types.ChainIndex(900200), msg.Chain)
}