mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-17 23:38:46 +00:00
a24546152b
* Use fastssz when available * fix tests * fix most tests * Merge branch 'master' into faster-hash-proto * Merge refs/heads/master into faster-hash-proto * Merge refs/heads/master into faster-hash-proto * Merge refs/heads/master into faster-hash-proto * fix last test * Merge branch 'faster-hash-proto' of github.com:prysmaticlabs/prysm into faster-hash-proto-2 * lint * fix last test * fix again * Update beacon-chain/cache/checkpoint_state_test.go Co-Authored-By: terence tsao <terence@prysmaticlabs.com> * Merge refs/heads/master into faster-hash-proto
128 lines
3.8 KiB
Go
128 lines
3.8 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"
|
|
"gopkg.in/d4l3k/messagediff.v1"
|
|
)
|
|
|
|
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*/)
|
|
|
|
data := ðpb.AttestationData{
|
|
Source: ðpb.Checkpoint{},
|
|
Target: ðpb.Checkpoint{},
|
|
}
|
|
attsToBeAggregated := []*ethpb.Attestation{
|
|
{Data: data, AggregationBits: bitfield.Bitlist{0b110001}, Signature: sig.Marshal()},
|
|
{Data: data, AggregationBits: bitfield.Bitlist{0b100010}, Signature: sig.Marshal()},
|
|
{Data: data, 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)
|
|
}
|
|
got := s.pool.AggregatedAttestations()
|
|
if !reflect.DeepEqual(wanted, got) {
|
|
diff, _ := messagediff.PrettyDiff(got[0], wanted[0])
|
|
t.Log(diff)
|
|
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")
|
|
}
|
|
}
|