2020-07-01 12:13:17 +00:00
|
|
|
package testkit
|
2020-06-26 08:49:24 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"crypto/rand"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/libp2p/go-libp2p"
|
|
|
|
"github.com/libp2p/go-libp2p-core/crypto"
|
|
|
|
"github.com/libp2p/go-libp2p-core/host"
|
|
|
|
"github.com/libp2p/go-libp2p-pubsub-tracer/traced"
|
|
|
|
|
|
|
|
ma "github.com/multiformats/go-multiaddr"
|
|
|
|
)
|
|
|
|
|
|
|
|
type PubsubTracer struct {
|
2020-07-01 13:41:38 +00:00
|
|
|
t *TestEnvironment
|
2020-06-26 08:49:24 +00:00
|
|
|
host host.Host
|
|
|
|
traced *traced.TraceCollector
|
|
|
|
}
|
|
|
|
|
2020-07-01 13:41:38 +00:00
|
|
|
func PreparePubsubTracer(t *TestEnvironment) (*PubsubTracer, error) {
|
2020-06-26 08:49:24 +00:00
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
privk, _, err := crypto.GenerateEd25519Key(rand.Reader)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
tracedIP := t.NetClient.MustGetDataNetworkIP().String()
|
|
|
|
tracedAddr := fmt.Sprintf("/ip4/%s/tcp/4001", tracedIP)
|
|
|
|
|
|
|
|
host, err := libp2p.New(ctx,
|
|
|
|
libp2p.Identity(privk),
|
|
|
|
libp2p.ListenAddrStrings(tracedAddr),
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2020-06-26 10:14:28 +00:00
|
|
|
tracedDir := t.TestOutputsPath + "/traced.logs"
|
|
|
|
traced, err := traced.NewTraceCollector(host, tracedDir)
|
2020-06-26 08:49:24 +00:00
|
|
|
if err != nil {
|
|
|
|
host.Close()
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
tracedMultiaddrStr := fmt.Sprintf("%s/p2p/%s", tracedAddr, host.ID())
|
|
|
|
t.RecordMessage("I am %s", tracedMultiaddrStr)
|
|
|
|
|
2020-06-26 09:16:36 +00:00
|
|
|
_ = ma.StringCast(tracedMultiaddrStr)
|
2020-06-30 22:02:01 +00:00
|
|
|
tracedMsg := &PubsubTracerMsg{Multiaddr: tracedMultiaddrStr}
|
2020-07-01 12:13:17 +00:00
|
|
|
t.SyncClient.MustPublish(ctx, PubsubTracerTopic, tracedMsg)
|
2020-06-26 08:49:24 +00:00
|
|
|
|
|
|
|
t.RecordMessage("waiting for all nodes to be ready")
|
2020-07-01 12:13:17 +00:00
|
|
|
t.SyncClient.MustSignalAndWait(ctx, StateReady, t.TestInstanceCount)
|
2020-06-26 08:49:24 +00:00
|
|
|
|
2020-07-01 13:41:38 +00:00
|
|
|
tracer := &PubsubTracer{t: t, host: host, traced: traced}
|
|
|
|
return tracer, nil
|
2020-06-26 08:49:24 +00:00
|
|
|
}
|
|
|
|
|
2020-07-01 13:41:38 +00:00
|
|
|
func (tr *PubsubTracer) RunDefault() error {
|
|
|
|
tr.t.RecordMessage("running pubsub tracer")
|
2020-06-26 08:49:24 +00:00
|
|
|
|
2020-06-26 11:10:39 +00:00
|
|
|
defer func() {
|
2020-07-01 13:41:38 +00:00
|
|
|
err := tr.Stop()
|
2020-06-26 11:10:39 +00:00
|
|
|
if err != nil {
|
2020-07-01 13:41:38 +00:00
|
|
|
tr.t.RecordMessage("error stoping tracer: %s", err)
|
2020-06-26 11:10:39 +00:00
|
|
|
}
|
|
|
|
}()
|
2020-06-26 08:49:24 +00:00
|
|
|
|
2020-07-01 13:41:38 +00:00
|
|
|
tr.t.WaitUntilAllDone()
|
2020-06-26 08:49:24 +00:00
|
|
|
return nil
|
|
|
|
}
|
2020-07-01 13:41:38 +00:00
|
|
|
|
|
|
|
func (tr *PubsubTracer) Stop() error {
|
|
|
|
tr.traced.Stop()
|
|
|
|
return tr.host.Close()
|
|
|
|
}
|