mirror of
https://github.com/OffchainLabs/prysm.git
synced 2026-01-08 21:08:10 -05:00
* v3 import renamings * tidy * fmt * rev * Update beacon-chain/core/epoch/precompute/reward_penalty_test.go * Update beacon-chain/core/helpers/validators_test.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/iface/BUILD.bazel * Update beacon-chain/db/kv/kv.go * Update beacon-chain/db/kv/state.go * Update beacon-chain/rpc/prysm/v1alpha1/validator/attester_test.go * Update beacon-chain/rpc/prysm/v1alpha1/validator/attester_test.go * Update beacon-chain/sync/initial-sync/service.go * fix deps * fix bad replacements * fix bad replacements * change back * gohashtree version * fix deps Co-authored-by: Nishant Das <nishdas93@gmail.com> Co-authored-by: Potuz <potuz@prysmaticlabs.com>
107 lines
3.9 KiB
Go
107 lines
3.9 KiB
Go
package blocks_test
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/beacon-chain/core/blocks"
|
|
"github.com/prysmaticlabs/prysm/v3/beacon-chain/core/signing"
|
|
v "github.com/prysmaticlabs/prysm/v3/beacon-chain/core/validators"
|
|
"github.com/prysmaticlabs/prysm/v3/config/params"
|
|
types "github.com/prysmaticlabs/prysm/v3/consensus-types/primitives"
|
|
"github.com/prysmaticlabs/prysm/v3/crypto/bls"
|
|
ethpb "github.com/prysmaticlabs/prysm/v3/proto/prysm/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/assert"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/require"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/util"
|
|
)
|
|
|
|
func TestProcessAttesterSlashings_RegressionSlashableIndices(t *testing.T) {
|
|
|
|
beaconState, privKeys := util.DeterministicGenesisState(t, 5500)
|
|
for _, vv := range beaconState.Validators() {
|
|
vv.WithdrawableEpoch = types.Epoch(params.BeaconConfig().SlotsPerEpoch)
|
|
}
|
|
// This set of indices is very similar to the one from our sapphire testnet
|
|
// when close to 100 validators were incorrectly slashed. The set is from 0 -5500,
|
|
// instead of 55000 as it would take too long to generate a state.
|
|
setA := []uint64{21, 92, 236, 244, 281, 321, 510, 524,
|
|
538, 682, 828, 858, 913, 920, 922, 959, 1176, 1207,
|
|
1222, 1229, 1354, 1394, 1436, 1454, 1510, 1550,
|
|
1552, 1576, 1645, 1704, 1842, 1967, 2076, 2111, 2134, 2307,
|
|
2343, 2354, 2417, 2524, 2532, 2555, 2740, 2749, 2759, 2762,
|
|
2800, 2809, 2824, 2987, 3110, 3125, 3559, 3583, 3599, 3608,
|
|
3657, 3685, 3723, 3756, 3759, 3761, 3820, 3826, 3979, 4030,
|
|
4141, 4170, 4205, 4247, 4257, 4479, 4492, 4569, 5091,
|
|
}
|
|
// Only 2800 is the slashable index.
|
|
setB := []uint64{1361, 1438, 2383, 2800}
|
|
expectedSlashedVal := 2800
|
|
|
|
root1 := [32]byte{'d', 'o', 'u', 'b', 'l', 'e', '1'}
|
|
att1 := ðpb.IndexedAttestation{
|
|
Data: util.HydrateAttestationData(ðpb.AttestationData{Target: ðpb.Checkpoint{Epoch: 0, Root: root1[:]}}),
|
|
AttestingIndices: setA,
|
|
Signature: make([]byte, 96),
|
|
}
|
|
domain, err := signing.Domain(beaconState.Fork(), 0, params.BeaconConfig().DomainBeaconAttester, beaconState.GenesisValidatorsRoot())
|
|
require.NoError(t, err)
|
|
signingRoot, err := signing.ComputeSigningRoot(att1.Data, domain)
|
|
require.NoError(t, err, "Could not get signing root of beacon block header")
|
|
var aggSigs []bls.Signature
|
|
for _, index := range setA {
|
|
sig := privKeys[index].Sign(signingRoot[:])
|
|
aggSigs = append(aggSigs, sig)
|
|
}
|
|
aggregateSig := bls.AggregateSignatures(aggSigs)
|
|
att1.Signature = aggregateSig.Marshal()
|
|
|
|
root2 := [32]byte{'d', 'o', 'u', 'b', 'l', 'e', '2'}
|
|
att2 := ðpb.IndexedAttestation{
|
|
Data: util.HydrateAttestationData(ðpb.AttestationData{
|
|
Target: ðpb.Checkpoint{Root: root2[:]},
|
|
}),
|
|
AttestingIndices: setB,
|
|
Signature: make([]byte, 96),
|
|
}
|
|
signingRoot, err = signing.ComputeSigningRoot(att2.Data, domain)
|
|
assert.NoError(t, err, "Could not get signing root of beacon block header")
|
|
aggSigs = []bls.Signature{}
|
|
for _, index := range setB {
|
|
sig := privKeys[index].Sign(signingRoot[:])
|
|
aggSigs = append(aggSigs, sig)
|
|
}
|
|
aggregateSig = bls.AggregateSignatures(aggSigs)
|
|
att2.Signature = aggregateSig.Marshal()
|
|
|
|
slashings := []*ethpb.AttesterSlashing{
|
|
{
|
|
Attestation_1: att1,
|
|
Attestation_2: att2,
|
|
},
|
|
}
|
|
|
|
currentSlot := 2 * params.BeaconConfig().SlotsPerEpoch
|
|
require.NoError(t, beaconState.SetSlot(currentSlot))
|
|
|
|
b := util.NewBeaconBlock()
|
|
b.Block = ðpb.BeaconBlock{
|
|
Body: ðpb.BeaconBlockBody{
|
|
AttesterSlashings: slashings,
|
|
},
|
|
}
|
|
|
|
newState, err := blocks.ProcessAttesterSlashings(context.Background(), beaconState, b.Block.Body.AttesterSlashings, v.SlashValidator)
|
|
require.NoError(t, err)
|
|
newRegistry := newState.Validators()
|
|
if !newRegistry[expectedSlashedVal].Slashed {
|
|
t.Errorf("Validator with index %d was not slashed despite performing a double vote", expectedSlashedVal)
|
|
}
|
|
|
|
for idx, val := range newRegistry {
|
|
if val.Slashed && idx != expectedSlashedVal {
|
|
t.Errorf("validator with index: %d was unintentionally slashed", idx)
|
|
}
|
|
}
|
|
}
|