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
121 lines
5.1 KiB
Go
121 lines
5.1 KiB
Go
package altair_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/OffchainLabs/go-bitfield"
|
|
"github.com/OffchainLabs/prysm/v7/beacon-chain/core/altair"
|
|
"github.com/OffchainLabs/prysm/v7/beacon-chain/core/helpers"
|
|
"github.com/OffchainLabs/prysm/v7/beacon-chain/core/time"
|
|
"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/proto/prysm/v1alpha1/attestation"
|
|
"github.com/OffchainLabs/prysm/v7/testing/require"
|
|
"github.com/OffchainLabs/prysm/v7/testing/util"
|
|
)
|
|
|
|
func TestTranslateParticipation(t *testing.T) {
|
|
ctx := t.Context()
|
|
s, _ := util.DeterministicGenesisStateAltair(t, 64)
|
|
require.NoError(t, s.SetSlot(s.Slot()+params.BeaconConfig().MinAttestationInclusionDelay))
|
|
|
|
var err error
|
|
newState, err := altair.TranslateParticipation(ctx, s, nil)
|
|
require.NoError(t, err)
|
|
participation, err := newState.PreviousEpochParticipation()
|
|
require.NoError(t, err)
|
|
require.DeepSSZEqual(t, make([]byte, 64), participation)
|
|
|
|
aggBits := bitfield.NewBitlist(2)
|
|
aggBits.SetBitAt(0, true)
|
|
aggBits.SetBitAt(1, true)
|
|
r, err := helpers.BlockRootAtSlot(s, 0)
|
|
require.NoError(t, err)
|
|
var pendingAtts []*ethpb.PendingAttestation
|
|
for i := range 3 {
|
|
pendingAtts = append(pendingAtts, ðpb.PendingAttestation{
|
|
Data: ðpb.AttestationData{
|
|
CommitteeIndex: primitives.CommitteeIndex(i),
|
|
BeaconBlockRoot: r,
|
|
Source: ðpb.Checkpoint{Epoch: 0, Root: make([]byte, 32)},
|
|
Target: ðpb.Checkpoint{Epoch: 0, Root: make([]byte, 32)},
|
|
},
|
|
AggregationBits: aggBits,
|
|
InclusionDelay: 1,
|
|
})
|
|
}
|
|
|
|
newState, err = altair.TranslateParticipation(ctx, newState, pendingAtts)
|
|
require.NoError(t, err)
|
|
participation, err = newState.PreviousEpochParticipation()
|
|
require.NoError(t, err)
|
|
require.DeepNotSSZEqual(t, make([]byte, 64), participation)
|
|
|
|
committee, err := helpers.BeaconCommitteeFromState(ctx, s, pendingAtts[0].Data.Slot, pendingAtts[0].Data.CommitteeIndex)
|
|
require.NoError(t, err)
|
|
indices, err := attestation.AttestingIndices(pendingAtts[0], committee)
|
|
require.NoError(t, err)
|
|
for _, index := range indices {
|
|
has, err := altair.HasValidatorFlag(participation[index], params.BeaconConfig().TimelySourceFlagIndex)
|
|
require.NoError(t, err)
|
|
require.Equal(t, true, has)
|
|
has, err = altair.HasValidatorFlag(participation[index], params.BeaconConfig().TimelyTargetFlagIndex)
|
|
require.NoError(t, err)
|
|
require.Equal(t, true, has)
|
|
has, err = altair.HasValidatorFlag(participation[index], params.BeaconConfig().TimelyHeadFlagIndex)
|
|
require.NoError(t, err)
|
|
require.Equal(t, true, has)
|
|
}
|
|
}
|
|
|
|
func TestUpgradeToAltair(t *testing.T) {
|
|
st, _ := util.DeterministicGenesisState(t, params.BeaconConfig().MaxValidatorsPerCommittee)
|
|
preForkState := st.Copy()
|
|
aState, err := altair.UpgradeToAltair(t.Context(), st)
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, preForkState.GenesisTime(), aState.GenesisTime())
|
|
require.DeepSSZEqual(t, preForkState.GenesisValidatorsRoot(), aState.GenesisValidatorsRoot())
|
|
require.Equal(t, preForkState.Slot(), aState.Slot())
|
|
require.DeepSSZEqual(t, preForkState.LatestBlockHeader(), aState.LatestBlockHeader())
|
|
require.DeepSSZEqual(t, preForkState.BlockRoots(), aState.BlockRoots())
|
|
require.DeepSSZEqual(t, preForkState.StateRoots(), aState.StateRoots())
|
|
r1 := preForkState.HistoricalRoots()
|
|
r2 := aState.HistoricalRoots()
|
|
require.DeepSSZEqual(t, r1, r2)
|
|
require.DeepSSZEqual(t, preForkState.Eth1Data(), aState.Eth1Data())
|
|
require.DeepSSZEqual(t, preForkState.Eth1DataVotes(), aState.Eth1DataVotes())
|
|
require.DeepSSZEqual(t, preForkState.Eth1DepositIndex(), aState.Eth1DepositIndex())
|
|
require.DeepSSZEqual(t, preForkState.Validators(), aState.Validators())
|
|
require.DeepSSZEqual(t, preForkState.Balances(), aState.Balances())
|
|
require.DeepSSZEqual(t, preForkState.RandaoMixes(), aState.RandaoMixes())
|
|
require.DeepSSZEqual(t, preForkState.Slashings(), aState.Slashings())
|
|
require.DeepSSZEqual(t, preForkState.JustificationBits(), aState.JustificationBits())
|
|
require.DeepSSZEqual(t, preForkState.PreviousJustifiedCheckpoint(), aState.PreviousJustifiedCheckpoint())
|
|
require.DeepSSZEqual(t, preForkState.CurrentJustifiedCheckpoint(), aState.CurrentJustifiedCheckpoint())
|
|
require.DeepSSZEqual(t, preForkState.FinalizedCheckpoint(), aState.FinalizedCheckpoint())
|
|
numValidators := aState.NumValidators()
|
|
p, err := aState.PreviousEpochParticipation()
|
|
require.NoError(t, err)
|
|
require.DeepSSZEqual(t, make([]byte, numValidators), p)
|
|
p, err = aState.CurrentEpochParticipation()
|
|
require.NoError(t, err)
|
|
require.DeepSSZEqual(t, make([]byte, numValidators), p)
|
|
s, err := aState.InactivityScores()
|
|
require.NoError(t, err)
|
|
require.DeepSSZEqual(t, make([]uint64, numValidators), s)
|
|
|
|
f := aState.Fork()
|
|
require.DeepSSZEqual(t, ðpb.Fork{
|
|
PreviousVersion: st.Fork().CurrentVersion,
|
|
CurrentVersion: params.BeaconConfig().AltairForkVersion,
|
|
Epoch: time.CurrentEpoch(st),
|
|
}, f)
|
|
csc, err := aState.CurrentSyncCommittee()
|
|
require.NoError(t, err)
|
|
nsc, err := aState.NextSyncCommittee()
|
|
require.NoError(t, err)
|
|
require.DeepSSZEqual(t, nsc, csc)
|
|
}
|