mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-10 04:51:20 +00:00
198 lines
5.5 KiB
Go
198 lines
5.5 KiB
Go
package handler
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"net/http/httptest"
|
|
"testing"
|
|
|
|
libcommon "github.com/ledgerwatch/erigon-lib/common"
|
|
"github.com/ledgerwatch/erigon/cl/clparams"
|
|
"github.com/ledgerwatch/erigon/cl/cltypes"
|
|
"github.com/ledgerwatch/erigon/cl/cltypes/solid"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestPoolAttesterSlashings(t *testing.T) {
|
|
attesterSlashing := &cltypes.AttesterSlashing{
|
|
Attestation_1: &cltypes.IndexedAttestation{
|
|
AttestingIndices: solid.NewRawUint64List(2048, []uint64{2, 3, 4, 5, 6}),
|
|
Data: solid.NewAttestationData(),
|
|
},
|
|
Attestation_2: &cltypes.IndexedAttestation{
|
|
AttestingIndices: solid.NewRawUint64List(2048, []uint64{2, 3, 4, 1, 6}),
|
|
Data: solid.NewAttestationData(),
|
|
},
|
|
}
|
|
// find server
|
|
_, _, _, _, _, handler, _, _, _ := setupTestingHandler(t, clparams.Phase0Version)
|
|
|
|
server := httptest.NewServer(handler.mux)
|
|
defer server.Close()
|
|
// json
|
|
req, err := json.Marshal(attesterSlashing)
|
|
require.NoError(t, err)
|
|
// post attester slashing
|
|
resp, err := server.Client().Post(server.URL+"/eth/v1/beacon/pool/attester_slashings", "application/json", bytes.NewBuffer(req))
|
|
require.NoError(t, err)
|
|
defer resp.Body.Close()
|
|
|
|
require.Equal(t, 200, resp.StatusCode)
|
|
// get attester slashings
|
|
resp, err = server.Client().Get(server.URL + "/eth/v1/beacon/pool/attester_slashings")
|
|
require.NoError(t, err)
|
|
defer resp.Body.Close()
|
|
|
|
require.Equal(t, 200, resp.StatusCode)
|
|
out := struct {
|
|
Data []*cltypes.AttesterSlashing `json:"data"`
|
|
}{
|
|
Data: []*cltypes.AttesterSlashing{
|
|
cltypes.NewAttesterSlashing(),
|
|
},
|
|
}
|
|
|
|
err = json.NewDecoder(resp.Body).Decode(&out)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 1, len(out.Data))
|
|
require.Equal(t, attesterSlashing, out.Data[0])
|
|
}
|
|
|
|
func TestPoolProposerSlashings(t *testing.T) {
|
|
proposerSlashing := &cltypes.ProposerSlashing{
|
|
Header1: &cltypes.SignedBeaconBlockHeader{
|
|
Header: &cltypes.BeaconBlockHeader{
|
|
Slot: 1,
|
|
ProposerIndex: 3,
|
|
},
|
|
},
|
|
Header2: &cltypes.SignedBeaconBlockHeader{
|
|
Header: &cltypes.BeaconBlockHeader{
|
|
Slot: 2,
|
|
ProposerIndex: 4,
|
|
},
|
|
},
|
|
}
|
|
// find server
|
|
_, _, _, _, _, handler, _, _, _ := setupTestingHandler(t, clparams.Phase0Version)
|
|
|
|
server := httptest.NewServer(handler.mux)
|
|
defer server.Close()
|
|
// json
|
|
req, err := json.Marshal(proposerSlashing)
|
|
require.NoError(t, err)
|
|
|
|
// post attester slashing
|
|
resp, err := server.Client().Post(server.URL+"/eth/v1/beacon/pool/proposer_slashings", "application/json", bytes.NewBuffer(req))
|
|
require.NoError(t, err)
|
|
defer resp.Body.Close()
|
|
|
|
require.Equal(t, 200, resp.StatusCode)
|
|
// get attester slashings
|
|
resp, err = server.Client().Get(server.URL + "/eth/v1/beacon/pool/proposer_slashings")
|
|
require.NoError(t, err)
|
|
defer resp.Body.Close()
|
|
|
|
require.Equal(t, 200, resp.StatusCode)
|
|
out := struct {
|
|
Data []*cltypes.ProposerSlashing `json:"data"`
|
|
}{
|
|
Data: []*cltypes.ProposerSlashing{},
|
|
}
|
|
|
|
err = json.NewDecoder(resp.Body).Decode(&out)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 1, len(out.Data))
|
|
require.Equal(t, proposerSlashing, out.Data[0])
|
|
}
|
|
|
|
func TestPoolVoluntaryExits(t *testing.T) {
|
|
voluntaryExit := &cltypes.SignedVoluntaryExit{
|
|
VoluntaryExit: &cltypes.VoluntaryExit{
|
|
Epoch: 1,
|
|
ValidatorIndex: 3,
|
|
},
|
|
}
|
|
// find server
|
|
_, _, _, _, _, handler, _, _, _ := setupTestingHandler(t, clparams.Phase0Version)
|
|
|
|
server := httptest.NewServer(handler.mux)
|
|
defer server.Close()
|
|
// json
|
|
req, err := json.Marshal(voluntaryExit)
|
|
require.NoError(t, err)
|
|
// post attester slashing
|
|
resp, err := server.Client().Post(server.URL+"/eth/v1/beacon/pool/voluntary_exits", "application/json", bytes.NewBuffer(req))
|
|
require.NoError(t, err)
|
|
defer resp.Body.Close()
|
|
|
|
require.Equal(t, 200, resp.StatusCode)
|
|
// get attester slashings
|
|
resp, err = server.Client().Get(server.URL + "/eth/v1/beacon/pool/voluntary_exits")
|
|
require.NoError(t, err)
|
|
defer resp.Body.Close()
|
|
|
|
require.Equal(t, 200, resp.StatusCode)
|
|
out := struct {
|
|
Data []*cltypes.SignedVoluntaryExit `json:"data"`
|
|
}{
|
|
Data: []*cltypes.SignedVoluntaryExit{},
|
|
}
|
|
|
|
err = json.NewDecoder(resp.Body).Decode(&out)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 1, len(out.Data))
|
|
require.Equal(t, voluntaryExit, out.Data[0])
|
|
}
|
|
|
|
func TestPoolBlsToExecutionChainges(t *testing.T) {
|
|
msg := []*cltypes.SignedBLSToExecutionChange{
|
|
{
|
|
Message: &cltypes.BLSToExecutionChange{
|
|
ValidatorIndex: 45,
|
|
},
|
|
Signature: libcommon.Bytes96{2},
|
|
},
|
|
{
|
|
Message: &cltypes.BLSToExecutionChange{
|
|
ValidatorIndex: 46,
|
|
},
|
|
},
|
|
}
|
|
// find server
|
|
_, _, _, _, _, handler, _, _, _ := setupTestingHandler(t, clparams.Phase0Version)
|
|
|
|
server := httptest.NewServer(handler.mux)
|
|
defer server.Close()
|
|
// json
|
|
req, err := json.Marshal(msg)
|
|
require.NoError(t, err)
|
|
// post attester slashing
|
|
resp, err := server.Client().Post(server.URL+"/eth/v1/beacon/pool/bls_to_execution_changes", "application/json", bytes.NewBuffer(req))
|
|
require.NoError(t, err)
|
|
defer resp.Body.Close()
|
|
|
|
require.Equal(t, 200, resp.StatusCode)
|
|
// get attester slashings
|
|
resp, err = server.Client().Get(server.URL + "/eth/v1/beacon/pool/bls_to_execution_changes")
|
|
require.NoError(t, err)
|
|
defer resp.Body.Close()
|
|
|
|
require.Equal(t, 200, resp.StatusCode)
|
|
out := struct {
|
|
Data []*cltypes.SignedBLSToExecutionChange `json:"data"`
|
|
}{
|
|
Data: []*cltypes.SignedBLSToExecutionChange{},
|
|
}
|
|
|
|
err = json.NewDecoder(resp.Body).Decode(&out)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 2, len(out.Data))
|
|
require.Equal(t, msg[0], out.Data[0])
|
|
require.Equal(t, msg[1], out.Data[1])
|
|
}
|