Files
prysm/validator/client/beacon-api/sync_committee_selections_test.go
Bastin 92bd211e4d upgrade v6 to v7 (#15989)
* upgrade v6 to v7

* changelog

* update-go-ssz
2025-11-06 16:16:23 +00:00

130 lines
3.2 KiB
Go

package beacon_api
import (
"bytes"
"encoding/json"
"testing"
"github.com/OffchainLabs/prysm/v7/testing/require"
"github.com/OffchainLabs/prysm/v7/validator/client/beacon-api/mock"
testhelpers "github.com/OffchainLabs/prysm/v7/validator/client/beacon-api/test-helpers"
"github.com/OffchainLabs/prysm/v7/validator/client/iface"
"github.com/pkg/errors"
"go.uber.org/mock/gomock"
)
func TestGetAggregatedSyncSelections(t *testing.T) {
testcases := []struct {
name string
req []iface.SyncCommitteeSelection
res []iface.SyncCommitteeSelection
endpointError error
expectedErrorMessage string
}{
{
name: "valid",
req: []iface.SyncCommitteeSelection{
{
SelectionProof: testhelpers.FillByteSlice(96, 82),
Slot: 75,
ValidatorIndex: 76,
SubcommitteeIndex: 77,
},
},
res: []iface.SyncCommitteeSelection{
{
SelectionProof: testhelpers.FillByteSlice(96, 100),
Slot: 75,
ValidatorIndex: 76,
SubcommitteeIndex: 77,
},
},
},
{
name: "endpoint error",
req: []iface.SyncCommitteeSelection{
{
SelectionProof: testhelpers.FillByteSlice(96, 82),
Slot: 75,
ValidatorIndex: 76,
SubcommitteeIndex: 77,
},
},
endpointError: errors.New("bad request"),
expectedErrorMessage: "bad request",
},
{
name: "no response error",
req: []iface.SyncCommitteeSelection{
{
SelectionProof: testhelpers.FillByteSlice(96, 82),
Slot: 75,
ValidatorIndex: 76,
SubcommitteeIndex: 77,
},
},
expectedErrorMessage: "no aggregated sync selections returned",
},
{
name: "mismatch response",
req: []iface.SyncCommitteeSelection{
{
SelectionProof: testhelpers.FillByteSlice(96, 82),
Slot: 75,
ValidatorIndex: 76,
SubcommitteeIndex: 77,
},
{
SelectionProof: testhelpers.FillByteSlice(96, 100),
Slot: 75,
ValidatorIndex: 76,
SubcommitteeIndex: 78,
},
},
res: []iface.SyncCommitteeSelection{
{
SelectionProof: testhelpers.FillByteSlice(96, 100),
Slot: 75,
ValidatorIndex: 76,
SubcommitteeIndex: 77,
},
},
expectedErrorMessage: "mismatching number of sync selections",
},
}
for _, test := range testcases {
t.Run(test.name, func(t *testing.T) {
ctrl := gomock.NewController(t)
jsonRestHandler := mock.NewMockJsonRestHandler(ctrl)
reqBody, err := json.Marshal(test.req)
require.NoError(t, err)
ctx := t.Context()
jsonRestHandler.EXPECT().Post(
gomock.Any(),
"/eth/v1/validator/sync_committee_selections",
nil,
bytes.NewBuffer(reqBody),
&aggregatedSyncSelectionResponse{},
).SetArg(
4,
aggregatedSyncSelectionResponse{Data: test.res},
).Return(
test.endpointError,
).Times(1)
validatorClient := &beaconApiValidatorClient{jsonRestHandler: jsonRestHandler}
res, err := validatorClient.AggregatedSyncSelections(ctx, test.req)
if test.expectedErrorMessage != "" {
require.ErrorContains(t, test.expectedErrorMessage, err)
return
}
require.NoError(t, err)
require.DeepEqual(t, test.res, res)
})
}
}