From be2b0edea2f4acea0aa32aae83abcb5aebf82541 Mon Sep 17 00:00:00 2001 From: allnil Date: Thu, 1 Feb 2024 20:57:28 +0000 Subject: [PATCH] add a simple test for privateKeyGen precompile --- suave/e2e/workflow_test.go | 40 ++++++++++++++++++++++++++++++++++++-- 1 file changed, 38 insertions(+), 2 deletions(-) diff --git a/suave/e2e/workflow_test.go b/suave/e2e/workflow_test.go index 1f2b8c963..41f40e9d9 100644 --- a/suave/e2e/workflow_test.go +++ b/suave/e2e/workflow_test.go @@ -315,6 +315,39 @@ func TestSignMessagePrecompile(t *testing.T) { require.Equal(t, crypto.PubkeyToAddress(sk.PublicKey), crypto.PubkeyToAddress(*pubKeyRecovered)) } +func TestPrivateKeyGeneratePrecompile(t *testing.T) { + fr := newFramework(t) + defer fr.Close() + + // function privateKeyGen() string + args, err := artifacts.SuaveAbi.Methods["privateKeyGen"].Inputs.Pack() + require.NoError(t, err) + + gas := hexutil.Uint64(1000000) + var callResult hexutil.Bytes + err = fr.suethSrv.RPCNode().Call(&callResult, "eth_call", setTxArgsDefaults(ethapi.TransactionArgs{ + To: &privateKeyGen, + Gas: &gas, + IsConfidential: true, + Data: (*hexutil.Bytes)(&args), + }), "latest") + requireNoRpcError(t, err) + + // Unpack the call result to get the result of privateKeyGen call + unpackedCallResult, err := artifacts.SuaveAbi.Methods["privateKeyGen"].Outputs.Unpack(callResult) + require.NoError(t, err) + + // Get the generated private key + skGenerated := unpackedCallResult[0].(string) + require.NoError(t, err) + + // Some tests on key validity + skBytes, err := hex.DecodeString(skGenerated) + require.NoError(t, err) + _, err = crypto.ToECDSA(skBytes) + require.NoError(t, err) +} + type HintEvent struct { BidId [16]uint8 `abi:"dataId"` Hint []byte `abi:"hint"` @@ -1479,11 +1512,14 @@ var ( fetchBidsAddress = common.HexToAddress("0x42030001") fillMevShareBundleAddress = common.HexToAddress("0x43200001") - signEthTransaction = common.HexToAddress("0x40100001") - signMessage = common.HexToAddress("0x40100003") + signEthTransaction = common.HexToAddress("0x40100001") + signMessage = common.HexToAddress("0x40100003") + simulateBundleAddress = common.HexToAddress("0x42100000") buildEthBlockAddress = common.HexToAddress("0x42100001") + privateKeyGen = common.HexToAddress("0x53200003") + /* contracts */ newBundleBidAddress = common.HexToAddress("0x642300000") newBlockBidAddress = common.HexToAddress("0x642310000")