-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoperations_validation_test.go
107 lines (95 loc) · 2.74 KB
/
operations_validation_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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
package mcms
import (
"encoding/json"
"errors"
"math/big"
"testing"
cselectors "github.com/smartcontractkit/chain-selectors"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/smartcontractkit/mcms/sdk/evm"
"github.com/smartcontractkit/mcms/types"
)
// TODO: Should go to EVM SDK. This should just tests the router function actuallty routes to the correct chain
func TestValidateAdditionalFields(t *testing.T) {
t.Parallel()
validEVMFields := evm.AdditionalFields{Value: big.NewInt(100)}
validEVMFieldsJSON, err := json.Marshal(validEVMFields)
require.NoError(t, err)
invalidEVMFields := evm.AdditionalFields{
Value: big.NewInt(-100),
}
invalidEVMFieldsJSON, err := json.Marshal(invalidEVMFields)
require.NoError(t, err)
validSolanaFields := evm.AdditionalFields{Value: big.NewInt(2)}
validSolanaFieldsJSON, err := json.Marshal(validSolanaFields)
require.NoError(t, err)
tests := []struct {
name string
operation types.Operation
expectedErr error
}{
{
name: "valid EVM fields",
operation: types.Operation{
ChainSelector: types.ChainSelector(cselectors.ETHEREUM_TESTNET_SEPOLIA.Selector),
Transaction: types.Transaction{
AdditionalFields: validEVMFieldsJSON,
},
},
expectedErr: nil,
},
{
name: "invalid EVM fields",
operation: types.Operation{
ChainSelector: types.ChainSelector(cselectors.ETHEREUM_TESTNET_SEPOLIA.Selector),
Transaction: types.Transaction{
AdditionalFields: invalidEVMFieldsJSON,
},
},
expectedErr: errors.New("invalid EVM value"),
},
{
name: "valid Solana fields",
operation: types.Operation{
ChainSelector: types.ChainSelector(cselectors.SOLANA_DEVNET.Selector),
Transaction: types.Transaction{
AdditionalFields: validSolanaFieldsJSON,
},
},
expectedErr: nil,
},
{
name: "unknown chain family",
operation: types.Operation{
ChainSelector: 999,
Transaction: types.Transaction{
AdditionalFields: nil,
},
},
expectedErr: errors.New("family not found for selector 999"),
},
{
name: "invalid JSON for EVM fields",
operation: types.Operation{
ChainSelector: types.ChainSelector(cselectors.ETHEREUM_TESTNET_SEPOLIA.Selector),
Transaction: types.Transaction{
AdditionalFields: []byte("invalid JSON"),
},
},
expectedErr: errors.New("failed to unmarshal EVM additional fields"),
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
t.Parallel()
err := ValidateAdditionalFields(tt.operation.Transaction.AdditionalFields, tt.operation.ChainSelector)
if tt.expectedErr != nil {
require.Error(t, err)
assert.Contains(t, err.Error(), tt.expectedErr.Error())
} else {
assert.NoError(t, err)
}
})
}
}