mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2024-12-25 21:07:18 +00:00
5aac06f04e
* begin move * use same import path * imports * regen protos * regen * no rename * generate ssz * gaz * fmt * edit build file * imports * modify * remove generated files * remove protos * edit imports in prysm * beacon chain all builds * edit script * add generated pbs * add replace rules * license for ethereumapis protos * change visibility * fmt * update build files to gaz ignore * use proper form * edit imports * wrap block * revert scripts * revert go mod
43 lines
1.5 KiB
Go
43 lines
1.5 KiB
Go
package blockchain
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
eth "github.com/prysmaticlabs/prysm/proto/eth/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/require"
|
|
)
|
|
|
|
func TestReportEpochMetrics_BadHeadState(t *testing.T) {
|
|
s, err := testutil.NewBeaconState()
|
|
require.NoError(t, err)
|
|
h, err := testutil.NewBeaconState()
|
|
require.NoError(t, err)
|
|
require.NoError(t, h.SetValidators(nil))
|
|
err = reportEpochMetrics(context.Background(), s, h)
|
|
require.ErrorContains(t, "failed to initialize precompute: nil validators in state", err)
|
|
}
|
|
|
|
func TestReportEpochMetrics_BadAttestation(t *testing.T) {
|
|
s, err := testutil.NewBeaconState()
|
|
require.NoError(t, err)
|
|
h, err := testutil.NewBeaconState()
|
|
require.NoError(t, err)
|
|
require.NoError(t, h.AppendCurrentEpochAttestations(&pb.PendingAttestation{InclusionDelay: 0}))
|
|
err = reportEpochMetrics(context.Background(), s, h)
|
|
require.ErrorContains(t, "attestation with inclusion delay of 0", err)
|
|
}
|
|
|
|
func TestReportEpochMetrics_SlashedValidatorOutOfBound(t *testing.T) {
|
|
h, _ := testutil.DeterministicGenesisState(t, 1)
|
|
v, err := h.ValidatorAtIndex(0)
|
|
require.NoError(t, err)
|
|
v.Slashed = true
|
|
require.NoError(t, h.UpdateValidatorAtIndex(0, v))
|
|
require.NoError(t, h.AppendCurrentEpochAttestations(&pb.PendingAttestation{InclusionDelay: 1, Data: testutil.HydrateAttestationData(ð.AttestationData{})}))
|
|
err = reportEpochMetrics(context.Background(), h, h)
|
|
require.ErrorContains(t, "slot 0 out of bounds", err)
|
|
}
|