mirror of
https://github.com/ipfs/kubo.git
synced 2026-02-22 10:57:42 +08:00
139 lines
4.2 KiB
Go
139 lines
4.2 KiB
Go
package cli
|
|
|
|
import (
|
|
"sort"
|
|
"sync"
|
|
"testing"
|
|
|
|
"github.com/ipfs/kubo/test/cli/harness"
|
|
"github.com/ipfs/kubo/test/cli/testutils"
|
|
"github.com/libp2p/go-libp2p/core/peer"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestLegacyDHT(t *testing.T) {
|
|
t.Parallel()
|
|
nodes := harness.NewT(t).NewNodes(5).Init()
|
|
nodes.ForEachPar(func(node *harness.Node) {
|
|
node.IPFS("config", "Routing.Type", "dht")
|
|
})
|
|
nodes.StartDaemons().Connect()
|
|
|
|
t.Run("ipfs dht findpeer", func(t *testing.T) {
|
|
t.Parallel()
|
|
res := nodes[1].RunIPFS("dht", "findpeer", nodes[0].PeerID().String())
|
|
assert.Equal(t, 0, res.ExitCode())
|
|
|
|
swarmAddr := nodes[0].SwarmAddrsWithoutPeerIDs()[0]
|
|
require.Equal(t, swarmAddr.String(), res.Stdout.Trimmed())
|
|
})
|
|
|
|
t.Run("ipfs dht get <key>", func(t *testing.T) {
|
|
t.Parallel()
|
|
hash := nodes[2].IPFSAddStr("hello world")
|
|
nodes[2].IPFS("name", "publish", "/ipfs/"+hash)
|
|
|
|
res := nodes[1].IPFS("dht", "get", "/ipns/"+nodes[2].PeerID().String())
|
|
assert.Contains(t, res.Stdout.String(), "/ipfs/"+hash)
|
|
|
|
t.Run("put round trips (#3124)", func(t *testing.T) {
|
|
t.Parallel()
|
|
nodes[0].WriteBytes("get_result", res.Stdout.Bytes())
|
|
res := nodes[0].IPFS("dht", "put", "/ipns/"+nodes[2].PeerID().String(), "get_result")
|
|
assert.Greater(t, len(res.Stdout.Lines()), 0, "should put to at least one node")
|
|
})
|
|
|
|
t.Run("put with bad keys fails (issue #5113, #4611)", func(t *testing.T) {
|
|
t.Parallel()
|
|
keys := []string{"foo", "/pk/foo", "/ipns/foo"}
|
|
for _, key := range keys {
|
|
key := key
|
|
t.Run(key, func(t *testing.T) {
|
|
t.Parallel()
|
|
res := nodes[0].RunIPFS("dht", "put", key)
|
|
assert.Equal(t, 1, res.ExitCode())
|
|
assert.Contains(t, res.Stderr.String(), "invalid")
|
|
assert.Empty(t, res.Stdout.String())
|
|
})
|
|
}
|
|
})
|
|
|
|
t.Run("get with bad keys (issue #4611)", func(t *testing.T) {
|
|
for _, key := range []string{"foo", "/pk/foo"} {
|
|
key := key
|
|
t.Run(key, func(t *testing.T) {
|
|
t.Parallel()
|
|
res := nodes[0].RunIPFS("dht", "get", key)
|
|
assert.Equal(t, 1, res.ExitCode())
|
|
assert.Contains(t, res.Stderr.String(), "invalid")
|
|
assert.Empty(t, res.Stdout.String())
|
|
})
|
|
}
|
|
})
|
|
})
|
|
|
|
t.Run("ipfs dht findprovs", func(t *testing.T) {
|
|
t.Parallel()
|
|
hash := nodes[3].IPFSAddStr("some stuff")
|
|
res := nodes[4].IPFS("dht", "findprovs", hash)
|
|
assert.Equal(t, nodes[3].PeerID().String(), res.Stdout.Trimmed())
|
|
})
|
|
|
|
t.Run("ipfs dht query <peerID>", func(t *testing.T) {
|
|
t.Parallel()
|
|
t.Run("normal DHT configuration", func(t *testing.T) {
|
|
t.Parallel()
|
|
hash := nodes[0].IPFSAddStr("some other stuff")
|
|
peerCounts := map[string]int{}
|
|
peerCountsMut := sync.Mutex{}
|
|
harness.Nodes(nodes).ForEachPar(func(node *harness.Node) {
|
|
res := node.IPFS("dht", "query", hash)
|
|
closestPeer := res.Stdout.Lines()[0]
|
|
// check that it's a valid peer ID
|
|
_, err := peer.Decode(closestPeer)
|
|
require.NoError(t, err)
|
|
|
|
peerCountsMut.Lock()
|
|
peerCounts[closestPeer]++
|
|
peerCountsMut.Unlock()
|
|
})
|
|
// 4 nodes should see the same peer ID
|
|
// 1 node (the closest) should see a different one
|
|
var counts []int
|
|
for _, count := range peerCounts {
|
|
counts = append(counts, count)
|
|
}
|
|
sort.IntSlice(counts).Sort()
|
|
assert.Equal(t, []int{1, 4}, counts)
|
|
})
|
|
|
|
})
|
|
|
|
t.Run("dht commands fail when offline", func(t *testing.T) {
|
|
t.Parallel()
|
|
node := harness.NewT(t).NewNode().Init()
|
|
|
|
// these cannot be run in parallel due to repo locking (seems like a bug)
|
|
|
|
t.Run("dht findprovs", func(t *testing.T) {
|
|
res := node.RunIPFS("dht", "findprovs", testutils.CIDEmptyDir)
|
|
assert.Equal(t, 1, res.ExitCode())
|
|
assert.Contains(t, res.Stderr.String(), "this command must be run in online mode")
|
|
})
|
|
|
|
t.Run("dht findpeer", func(t *testing.T) {
|
|
res := node.RunIPFS("dht", "findpeer", testutils.CIDEmptyDir)
|
|
assert.Equal(t, 1, res.ExitCode())
|
|
assert.Contains(t, res.Stderr.String(), "this command must be run in online mode")
|
|
})
|
|
|
|
t.Run("dht put", func(t *testing.T) {
|
|
node.WriteBytes("foo", []byte("foo"))
|
|
res := node.RunIPFS("dht", "put", "/ipns/"+node.PeerID().String(), "foo")
|
|
assert.Equal(t, 1, res.ExitCode())
|
|
assert.Contains(t, res.Stderr.String(), "this action must be run in online mode")
|
|
})
|
|
})
|
|
}
|