mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-07 10:12:19 +00:00
0ed8246e28
* Release flag to aggregate attestations in fork choice. * Merge refs/heads/master into aggregate-atts-in-fc * fix test * Merge branch 'aggregate-atts-in-fc' of github.com:prysmaticlabs/prysm into aggregate-atts-in-fc * Merge refs/heads/master into aggregate-atts-in-fc
120 lines
3.7 KiB
Go
120 lines
3.7 KiB
Go
package attestations
|
|
|
|
import (
|
|
"context"
|
|
"reflect"
|
|
"sort"
|
|
"testing"
|
|
|
|
"github.com/gogo/protobuf/proto"
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
"github.com/prysmaticlabs/go-bitfield"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/helpers"
|
|
"github.com/prysmaticlabs/prysm/shared/bls"
|
|
)
|
|
|
|
func TestAggregateAttestations_SingleAttestation(t *testing.T) {
|
|
s, err := NewService(context.Background(), &Config{Pool: NewPool()})
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
sk := bls.RandKey()
|
|
sig := sk.Sign([]byte("dummy_test_data"), 0 /*domain*/)
|
|
|
|
unaggregatedAtts := []*ethpb.Attestation{
|
|
{Data: ðpb.AttestationData{}, AggregationBits: bitfield.Bitlist{0b100001}, Signature: sig.Marshal()},
|
|
}
|
|
|
|
if err := s.aggregateAttestations(context.Background(), unaggregatedAtts); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if len(s.pool.AggregatedAttestations()) != 0 {
|
|
t.Error("Nothing should be aggregated")
|
|
}
|
|
|
|
if len(s.pool.UnaggregatedAttestations()) != 0 {
|
|
t.Error("Unaggregated pool should be empty")
|
|
}
|
|
}
|
|
|
|
func TestAggregateAttestations_MultipleAttestationsSameRoot(t *testing.T) {
|
|
s, err := NewService(context.Background(), &Config{Pool: NewPool()})
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
sk := bls.RandKey()
|
|
sig := sk.Sign([]byte("dummy_test_data"), 0 /*domain*/)
|
|
|
|
attsToBeAggregated := []*ethpb.Attestation{
|
|
{Data: ðpb.AttestationData{}, AggregationBits: bitfield.Bitlist{0b110001}, Signature: sig.Marshal()},
|
|
{Data: ðpb.AttestationData{}, AggregationBits: bitfield.Bitlist{0b100010}, Signature: sig.Marshal()},
|
|
{Data: ðpb.AttestationData{}, AggregationBits: bitfield.Bitlist{0b101100}, Signature: sig.Marshal()},
|
|
}
|
|
|
|
if err := s.aggregateAttestations(context.Background(), attsToBeAggregated); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if len(s.pool.UnaggregatedAttestations()) != 0 {
|
|
t.Error("Nothing should be unaggregated")
|
|
}
|
|
|
|
wanted, err := helpers.AggregateAttestations(attsToBeAggregated)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if !reflect.DeepEqual(wanted, s.pool.AggregatedAttestations()) {
|
|
t.Error("Did not aggregate attestations")
|
|
}
|
|
}
|
|
|
|
func TestAggregateAttestations_MultipleAttestationsDifferentRoots(t *testing.T) {
|
|
s, err := NewService(context.Background(), &Config{Pool: NewPool()})
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
mockRoot := [32]byte{}
|
|
d := ðpb.AttestationData{
|
|
BeaconBlockRoot: mockRoot[:],
|
|
Source: ðpb.Checkpoint{Root: mockRoot[:]},
|
|
Target: ðpb.Checkpoint{Root: mockRoot[:]},
|
|
}
|
|
d1 := proto.Clone(d).(*ethpb.AttestationData)
|
|
d1.Slot = 1
|
|
d2 := proto.Clone(d).(*ethpb.AttestationData)
|
|
d2.Slot = 2
|
|
|
|
sk := bls.RandKey()
|
|
sig := sk.Sign([]byte("dummy_test_data"), 0 /*domain*/)
|
|
|
|
atts := []*ethpb.Attestation{
|
|
{Data: d, AggregationBits: bitfield.Bitlist{0b100001}, Signature: sig.Marshal()},
|
|
{Data: d, AggregationBits: bitfield.Bitlist{0b100010}, Signature: sig.Marshal()},
|
|
{Data: d1, AggregationBits: bitfield.Bitlist{0b100001}, Signature: sig.Marshal()},
|
|
{Data: d1, AggregationBits: bitfield.Bitlist{0b100110}, Signature: sig.Marshal()},
|
|
{Data: d2, AggregationBits: bitfield.Bitlist{0b100100}, Signature: sig.Marshal()},
|
|
}
|
|
|
|
if err := s.aggregateAttestations(context.Background(), atts); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if len(s.pool.UnaggregatedAttestations()) != 0 {
|
|
t.Error("Unaggregated att pool did not clean up")
|
|
}
|
|
|
|
received := s.pool.AggregatedAttestations()
|
|
sort.Slice(received, func(i, j int) bool {
|
|
return received[i].Data.Slot < received[j].Data.Slot
|
|
})
|
|
att1, _ := helpers.AggregateAttestations([]*ethpb.Attestation{atts[0], atts[1]})
|
|
att2, _ := helpers.AggregateAttestations([]*ethpb.Attestation{atts[2], atts[3]})
|
|
wanted := append(att1, att2...)
|
|
if !reflect.DeepEqual(wanted, received) {
|
|
t.Error("Did not aggregate attestations")
|
|
}
|
|
}
|