package kademlia
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
var debug = false
|
|
|
|
func TestCountZeros(t *testing.T) {
|
|
zeroes := []byte{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
|
|
assert.Equal(t, 0, kBucketByDistance(zeroes))
|
|
|
|
b := []byte{0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff}
|
|
assert.Equal(t, 20, len(b))
|
|
assert.Equal(t, 159, kBucketByDistance(b))
|
|
b[19] = 0x00
|
|
assert.Equal(t, 159, kBucketByDistance(b))
|
|
|
|
b[0] = 0x0f
|
|
assert.Equal(t, 159-4, kBucketByDistance(b))
|
|
|
|
b[0] = 0x0c
|
|
assert.Equal(t, 159-4, kBucketByDistance(b))
|
|
|
|
b[0] = 0x00
|
|
b[1] = 0x00
|
|
b[2] = 0x0f
|
|
assert.Equal(t, 159-20, kBucketByDistance(b))
|
|
|
|
b[2] = 0x07
|
|
assert.Equal(t, 159-21, kBucketByDistance(b))
|
|
|
|
b[2] = 0x03
|
|
assert.Equal(t, 159-22, kBucketByDistance(b))
|
|
}
|
|
|
|
func TestKBucket(t *testing.T) {
|
|
idA, err := IDFromString("0fd85ddddf15aeec2d5d8b01b013dbca030a18d7")
|
|
assert.Nil(t, err)
|
|
kademlia := NewKademliaTable(idA)
|
|
|
|
d := kademlia.KBucket(kademlia.ID)
|
|
assert.Equal(t, 0, d) // same node should have distance 0
|
|
|
|
idB, err := IDFromString("c48d8b53dbefb609ed4e94d386dd5b22efcb2c5b")
|
|
assert.Nil(t, err)
|
|
|
|
d = kademlia.KBucket(idB)
|
|
assert.Equal(t, 159, d)
|
|
}
|
|
|
|
func prepareTestListedNodes() []ListedNode {
|
|
lnIDs := []string{
|
|
"c48d8b53dbefb609ed4e94d386dd5b22efcb2c5b",
|
|
"420bfebd44fc62615253224328f40f29c9b225fa",
|
|
"6272bb67b1661abfa07d1d32cd9b810e531d42cd",
|
|
"07db608db033384895e48098a1bbe25266387463",
|
|
"c19c3285ab9ada4b420050ae1a204640b2bed508",
|
|
"f8971d5da24517c8cc5a316fb0658de8906c4155",
|
|
"04122a5f2dec42284147b1847ec1bc41ecd78626",
|
|
"407a90870d7b482a271446c85fda940ce78a4c7a",
|
|
"5ebe4539e7a33721a8623f7ebfab62600aa503e7",
|
|
"fc44a42879ef3a74d6bd8303bc3e4e205a92acf9",
|
|
"fc44a42879ef3a74d6bd8303bc3e4e205a92acf9",
|
|
"10c86f96ebaa1685a46a6417e6faa2ef34a68976",
|
|
"243c81515196a5b0e2d4675e73f0da3eead12793",
|
|
"0fd85ddddf15aeec2d5d8b01b013dbca030a18d7",
|
|
"0fd85ddddf15aeec2d5d8b01b013dbca030a18d5",
|
|
"0fd85ddddf15aeec2d5d8b01b013dbca030a18d0",
|
|
"0fd85ddddf15aeec2d5d8b01b013dbca030a1800",
|
|
"0750931c40a52a2facd220a02851f7d34f95e1fa",
|
|
"ebfba615ac50bcd0f5c2420741d032e885abf576",
|
|
}
|
|
var lns []ListedNode
|
|
for i := 0; i < len(lnIDs); i++ {
|
|
idI, err := IDFromString(lnIDs[i])
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
lnI := ListedNode{
|
|
ID: idI,
|
|
Addr: "",
|
|
}
|
|
lns = append(lns, lnI)
|
|
}
|
|
return lns
|
|
}
|
|
|
|
func TestMoveToBottom(t *testing.T) {
|
|
lns := prepareTestListedNodes()
|
|
movedElem := lns[3]
|
|
assert.NotEqual(t, movedElem, lns[len(lns)-1])
|
|
lns = moveToBottom(lns, 3)
|
|
assert.Equal(t, movedElem, lns[len(lns)-1])
|
|
}
|
|
|
|
func TestUpdate(t *testing.T) {
|
|
idA, err := IDFromString("0fd85ddddf15aeec2d5d8b01b013dbca030a18d7")
|
|
assert.Nil(t, err)
|
|
kademlia := NewKademliaTable(idA)
|
|
|
|
lns := prepareTestListedNodes()
|
|
for _, lnI := range lns {
|
|
kademlia.Update(lnI)
|
|
}
|
|
|
|
if debug {
|
|
fmt.Println(kademlia)
|
|
}
|
|
|
|
assert.Equal(t, len(kademlia.KBuckets[0]), 1)
|
|
assert.Equal(t, len(kademlia.KBuckets[1]), 1)
|
|
assert.Equal(t, len(kademlia.KBuckets[158]), 4)
|
|
assert.Equal(t, len(kademlia.KBuckets[159]), 5)
|
|
}
|