mirror of
https://github.com/OffchainLabs/prysm.git
synced 2026-01-08 21:08:10 -05:00
* Update fastssz * Merge branch 'master' of github.com:prysmaticlabs/prysm into update-fssz * fmt * gaz * Merge refs/heads/master into update-fssz * goimports * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Fix * fix ethereumapis * fix again * kafka * fix gen file * fix compute signing root * gofmt * checkpoint progress * progress * checkpoint * progress * Fix build * checkpoint * helpers * Another test fixed * gaz * another test fix * gofmt * some fixes * Merge branch 'master' of github.com:prysmaticlabs/prysm into update-fssz * fix one test * Merge branch 'master' of github.com:prysmaticlabs/prysm into update-fssz * fill empty checkpoint roots * more padding * more padding * Fix //beacon-chain/rpc/debug:go_default_test * fix //beacon-chain/core/state:go_default_test * fix //beacon-chain/core/state:go_default_test * fix some htr errors * fix //slasher/rpc:go_default_test * Progress on //beacon-chain/core/blocks:go_default_test * Progress on //beacon-chain/core/blocks:go_default_test * Progress on //beacon-chain/core/blocks:go_default_test * fix //slasher/db/kv:go_default_test * progress * fix //beacon-chain/sync/initial-sync:go_raceon_test * gofmt and gaz * fix one more test, taking a break * Fix //beacon-chain/core/blocks:go_default_test * Complete beacon-chain/powchain * Do most of beacon-chain/rpc/beacon/ * Do most of beacon-chain/blockchain * fix //beacon-chain/operations/attestations/kv:go_default_test * Fix //beacon-chain/cache/depositcache:go_default_test * Fix //slasher/detection:go_default_test * Progress * fix //beacon-chain/rpc/validator:go_default_test * gofmt * fix //validator/client:go_default_test * fix * fix //beacon-chain/blockchain:go_raceoff_test * fix //beacon-chain/rpc/beacon:go_default_test * fix 1 of 4 shards in //beacon-chain/sync:go_default_test * Fix //beacon-chain/sync:go_default_test and gofmt * prevent panic * fix //beacon-chain/state/stategen:go_default_test * fix * Merge branch 'master' of github.com:prysmaticlabs/prysm into update-fssz * fix most tests * Self review, go mod tidy, run regen scripts * fix slasher * Update ethereumapis * disable spawn strategy override * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Remove extra line in imports * Remove extra line in imports * Gofmt * PR feedback from @nisdas
110 lines
3.9 KiB
Go
110 lines
3.9 KiB
Go
package blocks_test
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/blocks"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/helpers"
|
|
"github.com/prysmaticlabs/prysm/shared/bls"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/assert"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/require"
|
|
)
|
|
|
|
func TestProcessAttesterSlashings_RegressionSlashableIndices(t *testing.T) {
|
|
testutil.ResetCache()
|
|
beaconState, privKeys := testutil.DeterministicGenesisState(t, 5500)
|
|
for _, vv := range beaconState.Validators() {
|
|
vv.WithdrawableEpoch = 1 * 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: ðpb.AttestationData{
|
|
Source: ðpb.Checkpoint{Epoch: 0, Root: make([]byte, 32)},
|
|
Target: ðpb.Checkpoint{Epoch: 0, Root: root1[:]},
|
|
BeaconBlockRoot: make([]byte, 32),
|
|
},
|
|
AttestingIndices: setA,
|
|
Signature: make([]byte, 96),
|
|
}
|
|
domain, err := helpers.Domain(beaconState.Fork(), 0, params.BeaconConfig().DomainBeaconAttester, beaconState.GenesisValidatorRoot())
|
|
require.NoError(t, err)
|
|
signingRoot, err := helpers.ComputeSigningRoot(att1.Data, domain)
|
|
require.NoError(t, err, "Could not get signing root of beacon block header")
|
|
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: ðpb.AttestationData{
|
|
Source: ðpb.Checkpoint{Epoch: 0, Root: make([]byte, 32)},
|
|
Target: ðpb.Checkpoint{Epoch: 0, Root: root2[:]},
|
|
BeaconBlockRoot: make([]byte, 32),
|
|
},
|
|
AttestingIndices: setB,
|
|
Signature: make([]byte, 96),
|
|
}
|
|
signingRoot, err = helpers.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))
|
|
|
|
block := ðpb.BeaconBlock{
|
|
Body: ðpb.BeaconBlockBody{
|
|
AttesterSlashings: slashings,
|
|
},
|
|
}
|
|
|
|
newState, err := blocks.ProcessAttesterSlashings(context.Background(), beaconState, block.Body)
|
|
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)
|
|
}
|
|
}
|
|
}
|