mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-04 00:44:27 +00:00
6c4bf22723
* Update aggregated methods * Update aggregated methods * Use improved HasAttestation to check caches * Add back some validations * There's no need to save unaggregated att * Fixed all the tests * remove TODO for now * Raul feedback Co-authored-by: Preston Van Loon <preston@prysmaticlabs.com> Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
109 lines
3.5 KiB
Go
109 lines
3.5 KiB
Go
package attestations
|
|
|
|
import (
|
|
"context"
|
|
"reflect"
|
|
"sort"
|
|
"testing"
|
|
|
|
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)
|
|
}
|
|
|
|
sk := bls.RandKey()
|
|
sig := sk.Sign([]byte("dummy_test_data"), 0 /*domain*/)
|
|
|
|
atts := []*ethpb.Attestation{
|
|
{Data: ðpb.AttestationData{}, AggregationBits: bitfield.Bitlist{0b100001}, Signature: sig.Marshal()},
|
|
{Data: ðpb.AttestationData{}, AggregationBits: bitfield.Bitlist{0b100010}, Signature: sig.Marshal()},
|
|
{Data: ðpb.AttestationData{Slot: 1}, AggregationBits: bitfield.Bitlist{0b100001}, Signature: sig.Marshal()},
|
|
{Data: ðpb.AttestationData{Slot: 1}, AggregationBits: bitfield.Bitlist{0b100110}, Signature: sig.Marshal()},
|
|
{Data: ðpb.AttestationData{Slot: 2}, 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, s.pool.AggregatedAttestations()) {
|
|
t.Error("Did not aggregate attestations")
|
|
}
|
|
}
|