mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-16 14:58:46 +00:00
211d9bc0b9
* fix build from source * clean up * update again * change everything * workaround for now * fix versioning * all passing now * fix build issues * clean up * revert use of MulVerify * gaz * stub * Apply suggestions from code review Co-authored-by: Preston Van Loon <preston@prysmaticlabs.com> * fix all * fix test * todo * fix stub * revert back * make deep source happy * Update shared/bls/herumi/public_key.go * Update shared/bls/blst/signature.go * Update shared/bls/blst/signature_test.go * imports * move iface to common, export errors * rm iface build Co-authored-by: Preston Van Loon <preston@prysmaticlabs.com> Co-authored-by: terence tsao <terence@prysmaticlabs.com>
104 lines
2.9 KiB
Go
104 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/common"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/require"
|
|
)
|
|
|
|
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 []common.Signature) common.Signature {
|
|
return sigs[0]
|
|
}
|
|
signatureFromBytes = func(sig []byte) (common.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(64, bitlistLen),
|
|
want: []bitfield.Bitlist{
|
|
aggtesting.BitlistWithAllBitsSet(64),
|
|
},
|
|
},
|
|
{
|
|
name: "64 attestations with 8 random bits set",
|
|
inputs: aggtesting.BitlistsWithMultipleBitSet(b, 64, bitlistLen, 8),
|
|
want: []bitfield.Bitlist{
|
|
aggtesting.BitlistWithAllBitsSet(64),
|
|
},
|
|
},
|
|
{
|
|
name: "64 attestations with 16 random bits set",
|
|
inputs: aggtesting.BitlistsWithMultipleBitSet(b, 64, bitlistLen, 16),
|
|
want: []bitfield.Bitlist{
|
|
aggtesting.BitlistWithAllBitsSet(64),
|
|
},
|
|
},
|
|
{
|
|
name: "64 attestations with 32 random bits set",
|
|
inputs: aggtesting.BitlistsWithMultipleBitSet(b, 64, bitlistLen, 32),
|
|
want: []bitfield.Bitlist{
|
|
aggtesting.BitlistWithAllBitsSet(64),
|
|
},
|
|
},
|
|
{
|
|
name: "128 attestations with single bit set",
|
|
inputs: aggtesting.BitlistsWithSingleBitSet(128, bitlistLen),
|
|
want: []bitfield.Bitlist{
|
|
aggtesting.BitlistWithAllBitsSet(128),
|
|
},
|
|
},
|
|
{
|
|
name: "256 attestations with single bit set",
|
|
inputs: aggtesting.BitlistsWithSingleBitSet(256, bitlistLen),
|
|
want: []bitfield.Bitlist{
|
|
aggtesting.BitlistWithAllBitsSet(256),
|
|
},
|
|
},
|
|
{
|
|
name: "512 attestations with single bit set",
|
|
inputs: aggtesting.BitlistsWithSingleBitSet(512, bitlistLen),
|
|
want: []bitfield.Bitlist{
|
|
aggtesting.BitlistWithAllBitsSet(512),
|
|
},
|
|
},
|
|
{
|
|
name: "1024 attestations with single bit set",
|
|
inputs: aggtesting.BitlistsWithSingleBitSet(1024, bitlistLen),
|
|
want: []bitfield.Bitlist{
|
|
aggtesting.BitlistWithAllBitsSet(1024),
|
|
},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
b.Run(tt.name, func(b *testing.B) {
|
|
atts := aggtesting.MakeAttestationsFromBitlists(tt.inputs)
|
|
b.ResetTimer()
|
|
for i := 0; i < b.N; i++ {
|
|
_, err := Aggregate(atts)
|
|
require.NoError(b, err)
|
|
}
|
|
})
|
|
}
|
|
}
|