mirror of
https://github.com/OffchainLabs/prysm.git
synced 2026-01-08 21:08:10 -05:00
* Ran gopls modernize to fix everything go run golang.org/x/tools/gopls/internal/analysis/modernize/cmd/modernize@latest -fix -test ./... * Override rules_go provided dependency for golang.org/x/tools to v0.38.0. To update this, checked out rules_go, then ran `bazel run //go/tools/releaser -- upgrade-dep -mirror=false org_golang_x_tools` and copied the patches. * Fix buildtag violations and ignore buildtag violations in external * Introduce modernize analyzer package. * Add modernize "any" analyzer. * Fix violations of any analyzer * Add modernize "appendclipped" analyzer. * Fix violations of appendclipped * Add modernize "bloop" analyzer. * Add modernize "fmtappendf" analyzer. * Add modernize "forvar" analyzer. * Add modernize "mapsloop" analyzer. * Add modernize "minmax" analyzer. * Fix violations of minmax analyzer * Add modernize "omitzero" analyzer. * Add modernize "rangeint" analyzer. * Fix violations of rangeint. * Add modernize "reflecttypefor" analyzer. * Fix violations of reflecttypefor analyzer. * Add modernize "slicescontains" analyzer. * Add modernize "slicessort" analyzer. * Add modernize "slicesdelete" analyzer. This is disabled by default for now. See https://go.dev/issue/73686. * Add modernize "stringscutprefix" analyzer. * Add modernize "stringsbuilder" analyzer. * Fix violations of stringsbuilder analyzer. * Add modernize "stringsseq" analyzer. * Add modernize "testingcontext" analyzer. * Add modernize "waitgroup" analyzer. * Changelog fragment * gofmt * gazelle * Add modernize "newexpr" analyzer. * Disable newexpr until go1.26 * Add more details in WORKSPACE on how to update the override * @nalepae feedback on min() * gofmt * Fix violations of forvar
98 lines
3.5 KiB
Go
98 lines
3.5 KiB
Go
package state_native
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/OffchainLabs/prysm/v7/beacon-chain/state/state-native/types"
|
|
"github.com/OffchainLabs/prysm/v7/config/params"
|
|
"github.com/OffchainLabs/prysm/v7/consensus-types/primitives"
|
|
ethpb "github.com/OffchainLabs/prysm/v7/proto/prysm/v1alpha1"
|
|
"github.com/OffchainLabs/prysm/v7/testing/assert"
|
|
"github.com/OffchainLabs/prysm/v7/testing/require"
|
|
)
|
|
|
|
func TestBeaconState_RotateAttestations(t *testing.T) {
|
|
st, err := InitializeFromProtoPhase0(ðpb.BeaconState{
|
|
Slot: 1,
|
|
CurrentEpochAttestations: []*ethpb.PendingAttestation{{Data: ðpb.AttestationData{Slot: 456}}},
|
|
PreviousEpochAttestations: []*ethpb.PendingAttestation{{Data: ðpb.AttestationData{Slot: 123}}},
|
|
})
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, st.RotateAttestations())
|
|
s, ok := st.(*BeaconState)
|
|
require.Equal(t, true, ok)
|
|
require.Equal(t, 0, len(s.currentEpochAttestationsVal()))
|
|
require.Equal(t, primitives.Slot(456), s.previousEpochAttestationsVal()[0].Data.Slot)
|
|
}
|
|
|
|
func TestAppendBeyondIndicesLimit(t *testing.T) {
|
|
zeroHash := params.BeaconConfig().ZeroHash
|
|
mockblockRoots := make([][]byte, params.BeaconConfig().SlotsPerHistoricalRoot)
|
|
for i := range mockblockRoots {
|
|
mockblockRoots[i] = zeroHash[:]
|
|
}
|
|
|
|
mockstateRoots := make([][]byte, params.BeaconConfig().SlotsPerHistoricalRoot)
|
|
for i := range mockstateRoots {
|
|
mockstateRoots[i] = zeroHash[:]
|
|
}
|
|
mockrandaoMixes := make([][]byte, params.BeaconConfig().EpochsPerHistoricalVector)
|
|
for i := range mockrandaoMixes {
|
|
mockrandaoMixes[i] = zeroHash[:]
|
|
}
|
|
st, err := InitializeFromProtoPhase0(ðpb.BeaconState{
|
|
Slot: 1,
|
|
CurrentEpochAttestations: []*ethpb.PendingAttestation{{Data: ðpb.AttestationData{Slot: 456}}},
|
|
PreviousEpochAttestations: []*ethpb.PendingAttestation{{Data: ðpb.AttestationData{Slot: 123}}},
|
|
Validators: []*ethpb.Validator{},
|
|
Eth1Data: ðpb.Eth1Data{},
|
|
BlockRoots: mockblockRoots,
|
|
StateRoots: mockstateRoots,
|
|
RandaoMixes: mockrandaoMixes,
|
|
})
|
|
require.NoError(t, err)
|
|
_, err = st.HashTreeRoot(t.Context())
|
|
require.NoError(t, err)
|
|
s, ok := st.(*BeaconState)
|
|
require.Equal(t, true, ok)
|
|
for i := types.FieldIndex(0); i < types.FieldIndex(params.BeaconConfig().BeaconStateFieldCount); i++ {
|
|
s.dirtyFields[i] = true
|
|
}
|
|
_, err = st.HashTreeRoot(t.Context())
|
|
require.NoError(t, err)
|
|
for range 10 {
|
|
assert.NoError(t, st.AppendValidator(ðpb.Validator{}))
|
|
}
|
|
assert.Equal(t, false, s.rebuildTrie[types.Validators])
|
|
assert.NotEqual(t, len(s.dirtyIndices[types.Validators]), 0)
|
|
|
|
for range indicesLimit {
|
|
assert.NoError(t, st.AppendValidator(ðpb.Validator{}))
|
|
}
|
|
assert.Equal(t, true, s.rebuildTrie[types.Validators])
|
|
assert.Equal(t, len(s.dirtyIndices[types.Validators]), 0)
|
|
}
|
|
|
|
func BenchmarkAppendPreviousEpochAttestations(b *testing.B) {
|
|
st, err := InitializeFromProtoPhase0(ðpb.BeaconState{})
|
|
require.NoError(b, err)
|
|
|
|
max := params.BeaconConfig().PreviousEpochAttestationsLength()
|
|
if max < 2 {
|
|
b.Fatalf("previous epoch attestations length is less than 2: %d", max)
|
|
}
|
|
|
|
for i := uint64(0); i < max-2; i++ {
|
|
err := st.AppendPreviousEpochAttestations(ðpb.PendingAttestation{Data: ðpb.AttestationData{Slot: primitives.Slot(i)}})
|
|
require.NoError(b, err)
|
|
}
|
|
|
|
ref := st.Copy()
|
|
for i := 0; b.Loop(); i++ {
|
|
err := ref.AppendPreviousEpochAttestations(ðpb.PendingAttestation{Data: ðpb.AttestationData{Slot: primitives.Slot(i)}})
|
|
require.NoError(b, err)
|
|
ref = st.Copy()
|
|
}
|
|
}
|