From e5efd28998148e39598bfc40414d8d116ad750c2 Mon Sep 17 00:00:00 2001 From: Ferran Borreguero Date: Thu, 23 Nov 2023 10:52:23 +0100 Subject: [PATCH] Fix json encoding/decoding of computational requests --- core/types/transaction_marshalling.go | 18 +++++++++--------- suave/e2e/workflow_test.go | 7 ++++++- 2 files changed, 15 insertions(+), 10 deletions(-) diff --git a/core/types/transaction_marshalling.go b/core/types/transaction_marshalling.go index 09d8b4aff5..1855b2e6b3 100644 --- a/core/types/transaction_marshalling.go +++ b/core/types/transaction_marshalling.go @@ -45,7 +45,7 @@ type txJSON struct { KettleAddress *common.Address `json:"kettleAddress,omitempty"` ConfidentialInputsHash *common.Hash `json:"confidentialInputsHash,omitempty"` ConfidentialInputs *hexutil.Bytes `json:"confidentialInputs,omitempty"` - Wrapped *json.RawMessage `json:"wrapped,omitempty"` + RequestRecord *json.RawMessage `json:"requestRecord,omitempty"` ConfidentialComputeResult *hexutil.Bytes `json:"confidentialComputeResult,omitempty"` V *hexutil.Big `json:"v"` R *hexutil.Big `json:"r"` @@ -148,12 +148,12 @@ func (tx *Transaction) MarshalJSON() ([]byte, error) { enc.S = (*hexutil.Big)(itx.S) case *SuaveTransaction: - wrapped, err := NewTx(&itx.ConfidentialComputeRequest).MarshalJSON() + requestRecord, err := NewTx(&itx.ConfidentialComputeRequest).MarshalJSON() if err != nil { return nil, err } - enc.Wrapped = (*json.RawMessage)(&wrapped) + enc.RequestRecord = (*json.RawMessage)(&requestRecord) enc.ChainID = (*hexutil.Big)(itx.ChainID) enc.ConfidentialComputeResult = (*hexutil.Bytes)(&itx.ConfidentialComputeResult) @@ -396,7 +396,7 @@ func (tx *Transaction) UnmarshalJSON(input []byte) error { } case ConfidentialComputeRecordTxType: - var itx ConfidentialComputeRequest + var itx ConfidentialComputeRecord inner = &itx if dec.KettleAddress == nil { @@ -521,17 +521,17 @@ func (tx *Transaction) UnmarshalJSON(input []byte) error { var itx SuaveTransaction inner = &itx - if dec.Wrapped == nil { - return errors.New("missing required field 'wrapped' in transaction") + if dec.RequestRecord == nil { + return errors.New("missing required field 'requestRecord' in transaction") } - var wrappedTx Transaction - err := wrappedTx.UnmarshalJSON(([]byte)(*dec.Wrapped)) + var requestRecord Transaction + err := requestRecord.UnmarshalJSON(([]byte)(*dec.RequestRecord)) if err != nil { return err } - ccr, ok := CastTxInner[*ConfidentialComputeRecord](&wrappedTx) + ccr, ok := CastTxInner[*ConfidentialComputeRecord](&requestRecord) if !ok { return errors.New("wrapped tx not a ConfidentialComputeRecord") } diff --git a/suave/e2e/workflow_test.go b/suave/e2e/workflow_test.go index eb6980d5ce..8c4e97dd57 100644 --- a/suave/e2e/workflow_test.go +++ b/suave/e2e/workflow_test.go @@ -1081,9 +1081,14 @@ func TestE2EPrecompile_Call(t *testing.T) { sourceContract := sdk.GetContract(contractAddr, exampleCallSourceContract.Abi, clt) expectedNum := big.NewInt(101) - _, err := sourceContract.SendTransaction("callTarget", []interface{}{contractAddr, expectedNum}, nil) + res, err := sourceContract.SendTransaction("callTarget", []interface{}{contractAddr, expectedNum}, nil) require.NoError(t, err) + // make sure we can retrieve the transaction + tx, _, err := ethclient.NewClient(fr.suethSrv.RPCNode()).TransactionByHash(context.Background(), res.Hash()) + require.NoError(t, err) + require.Equal(t, tx.Type(), uint8(types.SuaveTxType)) + incorrectNum := big.NewInt(102) _, err = sourceContract.SendTransaction("callTarget", []interface{}{contractAddr, incorrectNum}, nil) require.Error(t, err)