mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-11 20:20:05 +00:00
105 lines
2.9 KiB
Go
105 lines
2.9 KiB
Go
|
package attestations
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/prysmaticlabs/go-bitfield"
|
||
|
aggtesting "github.com/prysmaticlabs/prysm/shared/aggregation/testing"
|
||
|
"github.com/prysmaticlabs/prysm/shared/bls"
|
||
|
"github.com/prysmaticlabs/prysm/shared/bls/iface"
|
||
|
"github.com/prysmaticlabs/prysm/shared/params"
|
||
|
)
|
||
|
|
||
|
func BenchmarkAggregateAttestations_Aggregate(b *testing.B) {
|
||
|
// Override expensive BLS aggregation method with cheap no-op such that this benchmark profiles
|
||
|
// the logic of aggregation selection rather than BLS logic.
|
||
|
aggregateSignatures = func(sigs []iface.Signature) iface.Signature {
|
||
|
return sigs[0]
|
||
|
}
|
||
|
signatureFromBytes = func(sig []byte) (iface.Signature, error) {
|
||
|
return bls.NewAggregateSignature(), nil
|
||
|
}
|
||
|
defer func() {
|
||
|
aggregateSignatures = bls.AggregateSignatures
|
||
|
signatureFromBytes = bls.SignatureFromBytes
|
||
|
}()
|
||
|
|
||
|
bitlistLen := params.BeaconConfig().MaxValidatorsPerCommittee
|
||
|
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
inputs []bitfield.Bitlist
|
||
|
want []bitfield.Bitlist
|
||
|
}{
|
||
|
{
|
||
|
name: "64 attestations with single bit set",
|
||
|
inputs: aggtesting.BitlistsWithSingleBitSet(b, 64, bitlistLen),
|
||
|
want: []bitfield.Bitlist{
|
||
|
aggtesting.BitlistWithAllBitsSet(b, 64),
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "64 attestations with 8 random bits set",
|
||
|
inputs: aggtesting.BitlistsWithMultipleBitSet(b, 64, bitlistLen, 8),
|
||
|
want: []bitfield.Bitlist{
|
||
|
aggtesting.BitlistWithAllBitsSet(b, 64),
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "64 attestations with 16 random bits set",
|
||
|
inputs: aggtesting.BitlistsWithMultipleBitSet(b, 64, bitlistLen, 16),
|
||
|
want: []bitfield.Bitlist{
|
||
|
aggtesting.BitlistWithAllBitsSet(b, 64),
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "64 attestations with 32 random bits set",
|
||
|
inputs: aggtesting.BitlistsWithMultipleBitSet(b, 64, bitlistLen, 32),
|
||
|
want: []bitfield.Bitlist{
|
||
|
aggtesting.BitlistWithAllBitsSet(b, 64),
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "128 attestations with single bit set",
|
||
|
inputs: aggtesting.BitlistsWithSingleBitSet(b, 128, bitlistLen),
|
||
|
want: []bitfield.Bitlist{
|
||
|
aggtesting.BitlistWithAllBitsSet(b, 128),
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "256 attestations with single bit set",
|
||
|
inputs: aggtesting.BitlistsWithSingleBitSet(b, 256, bitlistLen),
|
||
|
want: []bitfield.Bitlist{
|
||
|
aggtesting.BitlistWithAllBitsSet(b, 256),
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "512 attestations with single bit set",
|
||
|
inputs: aggtesting.BitlistsWithSingleBitSet(b, 512, bitlistLen),
|
||
|
want: []bitfield.Bitlist{
|
||
|
aggtesting.BitlistWithAllBitsSet(b, 512),
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "1024 attestations with single bit set",
|
||
|
inputs: aggtesting.BitlistsWithSingleBitSet(b, 1024, bitlistLen),
|
||
|
want: []bitfield.Bitlist{
|
||
|
aggtesting.BitlistWithAllBitsSet(b, 1024),
|
||
|
},
|
||
|
},
|
||
|
}
|
||
|
|
||
|
for _, tt := range tests {
|
||
|
b.Run(tt.name, func(b *testing.B) {
|
||
|
atts := aggtesting.MakeAttestationsFromBitlists(b, tt.inputs)
|
||
|
b.ResetTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
_, err := Aggregate(atts)
|
||
|
if err != nil {
|
||
|
b.Fatal(err)
|
||
|
}
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|