2021-09-01 04:07:20 +00:00
|
|
|
package sync
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
pubsub "github.com/libp2p/go-libp2p-pubsub"
|
2022-08-16 12:20:13 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/v3/beacon-chain/p2p"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/beacon-chain/p2p/encoder"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/network/forks"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/testing/assert"
|
2021-09-01 04:07:20 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestSubTopicHandler_CRUD(t *testing.T) {
|
|
|
|
h := newSubTopicHandler()
|
|
|
|
// Non-existent topic
|
|
|
|
assert.Equal(t, false, h.topicExists("junk"))
|
|
|
|
assert.Equal(t, false, h.digestExists([4]byte{}))
|
|
|
|
|
2021-09-17 19:20:50 +00:00
|
|
|
digest, err := forks.CreateForkDigest(time.Now(), make([]byte, 32))
|
2021-09-01 04:07:20 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
enc := encoder.SszNetworkEncoder{}
|
|
|
|
|
|
|
|
// Valid topic added in.
|
|
|
|
topic := fmt.Sprintf(p2p.BlockSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.addTopic(topic, new(pubsub.Subscription))
|
|
|
|
assert.Equal(t, true, h.topicExists(topic))
|
|
|
|
assert.Equal(t, true, h.digestExists(digest))
|
|
|
|
assert.Equal(t, 1, len(h.allTopics()))
|
|
|
|
|
|
|
|
h.removeTopic(topic)
|
|
|
|
assert.Equal(t, false, h.topicExists(topic))
|
|
|
|
assert.Equal(t, false, h.digestExists(digest))
|
|
|
|
assert.Equal(t, 0, len(h.allTopics()))
|
|
|
|
|
|
|
|
h = newSubTopicHandler()
|
|
|
|
// Multiple Topics added in.
|
|
|
|
topic = fmt.Sprintf(p2p.BlockSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.addTopic(topic, new(pubsub.Subscription))
|
|
|
|
assert.Equal(t, true, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.ExitSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.addTopic(topic, new(pubsub.Subscription))
|
|
|
|
assert.Equal(t, true, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.ProposerSlashingSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.addTopic(topic, new(pubsub.Subscription))
|
|
|
|
assert.Equal(t, true, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.AttesterSlashingSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.addTopic(topic, new(pubsub.Subscription))
|
|
|
|
assert.Equal(t, true, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.AggregateAndProofSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.addTopic(topic, new(pubsub.Subscription))
|
|
|
|
assert.Equal(t, true, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.SyncContributionAndProofSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.addTopic(topic, new(pubsub.Subscription))
|
|
|
|
assert.Equal(t, true, h.topicExists(topic))
|
|
|
|
|
|
|
|
assert.Equal(t, 6, len(h.allTopics()))
|
|
|
|
|
|
|
|
// Remove multiple topics
|
|
|
|
topic = fmt.Sprintf(p2p.AttesterSlashingSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.removeTopic(topic)
|
|
|
|
assert.Equal(t, false, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.ExitSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.removeTopic(topic)
|
|
|
|
assert.Equal(t, false, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.ProposerSlashingSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.removeTopic(topic)
|
|
|
|
assert.Equal(t, false, h.topicExists(topic))
|
|
|
|
|
|
|
|
assert.Equal(t, true, h.digestExists(digest))
|
|
|
|
assert.Equal(t, 3, len(h.allTopics()))
|
|
|
|
|
|
|
|
// Remove remaining topics.
|
|
|
|
topic = fmt.Sprintf(p2p.BlockSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.removeTopic(topic)
|
|
|
|
assert.Equal(t, false, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.AggregateAndProofSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.removeTopic(topic)
|
|
|
|
assert.Equal(t, false, h.topicExists(topic))
|
|
|
|
|
|
|
|
topic = fmt.Sprintf(p2p.SyncContributionAndProofSubnetTopicFormat, digest) + enc.ProtocolSuffix()
|
|
|
|
h.removeTopic(topic)
|
|
|
|
assert.Equal(t, false, h.topicExists(topic))
|
|
|
|
|
|
|
|
assert.Equal(t, false, h.digestExists(digest))
|
|
|
|
assert.Equal(t, 0, len(h.allTopics()))
|
|
|
|
}
|