2020-07-03 14:37:54 +00:00
|
|
|
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"
|
2020-07-18 16:31:42 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/require"
|
2020-07-03 14:37:54 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
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)
|
2020-07-18 16:31:42 +00:00
|
|
|
require.NoError(b, err)
|
2020-07-03 14:37:54 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|