提交 0794d5b4 作者: Jeromy

a little cleanup

上级 069966d5
...@@ -2,6 +2,7 @@ package commands ...@@ -2,6 +2,7 @@ package commands
import ( import (
"bytes" "bytes"
"errors"
"fmt" "fmt"
"io" "io"
"time" "time"
...@@ -13,6 +14,8 @@ import ( ...@@ -13,6 +14,8 @@ import (
context "github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/go.net/context" context "github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/go.net/context"
) )
const kPingTimeout = 10 * time.Second
type PingResult struct { type PingResult struct {
Success bool Success bool
Time time.Duration Time time.Duration
...@@ -30,7 +33,7 @@ send pings, wait for pongs, and print out round-trip latency information. ...@@ -30,7 +33,7 @@ send pings, wait for pongs, and print out round-trip latency information.
`, `,
}, },
Arguments: []cmds.Argument{ Arguments: []cmds.Argument{
cmds.StringArg("peer-id", true, true, "ID of peer to ping"), cmds.StringArg("count", false, true, "Number of pings to perform"),
}, },
Marshalers: cmds.MarshalerMap{ Marshalers: cmds.MarshalerMap{
cmds.Text: func(res cmds.Response) (io.Reader, error) { cmds.Text: func(res cmds.Response) (io.Reader, error) {
...@@ -66,15 +69,32 @@ send pings, wait for pongs, and print out round-trip latency information. ...@@ -66,15 +69,32 @@ send pings, wait for pongs, and print out round-trip latency information.
return nil, err return nil, err
} }
// Must be online!
if !n.OnlineMode() { if !n.OnlineMode() {
return nil, errNotOnline return nil, errNotOnline
} }
peerID, err := peer.IDB58Decode("QmaCpDMGvV2BGHeYERUEnRQAwe3N8SzbUtfsmvsqQLuvuJ") if len(req.Arguments()) == 0 {
return nil, errors.New("no peer specified!")
}
// Set up number of pings
numPings := 10
val, found, err := req.Option("count").Int()
if err != nil { if err != nil {
return nil, err return nil, err
} }
const kPingTimeout = 10 * time.Second if found {
numPings = val
}
// One argument of input required, must be base58 encoded peerID
peerID, err := peer.IDB58Decode(req.Arguments()[0])
if err != nil {
return nil, err
}
// Make sure we can find the node in question
ctx, _ := context.WithTimeout(context.Background(), kPingTimeout) ctx, _ := context.WithTimeout(context.Background(), kPingTimeout)
p, err := n.Routing.FindPeer(ctx, peerID) p, err := n.Routing.FindPeer(ctx, peerID)
if err != nil { if err != nil {
...@@ -85,11 +105,12 @@ send pings, wait for pongs, and print out round-trip latency information. ...@@ -85,11 +105,12 @@ send pings, wait for pongs, and print out round-trip latency information.
go func() { go func() {
defer close(outChan) defer close(outChan)
for i := 0; i < 10; i++ { for i := 0; i < numPings; i++ {
ctx, _ = context.WithTimeout(context.Background(), kPingTimeout) ctx, _ = context.WithTimeout(context.Background(), kPingTimeout)
before := time.Now() before := time.Now()
err := n.Routing.Ping(ctx, p.ID) err := n.Routing.Ping(ctx, p.ID)
if err != nil { if err != nil {
log.Errorf("Ping error: %s", err)
outChan <- &PingResult{} outChan <- &PingResult{}
break break
} }
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论