mirror of
https://github.com/ipfs/kubo.git
synced 2025-05-17 23:16:11 +08:00

Also change existing 'Node' type to 'ProtoNode' and use that most everywhere for now. As we move forward with the integration we will try and use the Node interface in more places that we're currently using ProtoNode. License: MIT Signed-off-by: Jeromy <why@ipfs.io>
94 lines
2.0 KiB
Go
94 lines
2.0 KiB
Go
package testu
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"io"
|
|
"io/ioutil"
|
|
"testing"
|
|
|
|
imp "github.com/ipfs/go-ipfs/importer"
|
|
"github.com/ipfs/go-ipfs/importer/chunk"
|
|
mdag "github.com/ipfs/go-ipfs/merkledag"
|
|
mdagmock "github.com/ipfs/go-ipfs/merkledag/test"
|
|
ft "github.com/ipfs/go-ipfs/unixfs"
|
|
|
|
context "context"
|
|
u "gx/ipfs/Qmb912gdngC1UWwTkhuW8knyRbcWeu5kqkxBpveLmW8bSr/go-ipfs-util"
|
|
)
|
|
|
|
func SizeSplitterGen(size int64) chunk.SplitterGen {
|
|
return func(r io.Reader) chunk.Splitter {
|
|
return chunk.NewSizeSplitter(r, size)
|
|
}
|
|
}
|
|
|
|
func GetDAGServ() mdag.DAGService {
|
|
return mdagmock.Mock()
|
|
}
|
|
|
|
func GetNode(t testing.TB, dserv mdag.DAGService, data []byte) *mdag.ProtoNode {
|
|
in := bytes.NewReader(data)
|
|
node, err := imp.BuildTrickleDagFromReader(dserv, SizeSplitterGen(500)(in))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
return node
|
|
}
|
|
|
|
func GetEmptyNode(t testing.TB, dserv mdag.DAGService) *mdag.ProtoNode {
|
|
return GetNode(t, dserv, []byte{})
|
|
}
|
|
|
|
func GetRandomNode(t testing.TB, dserv mdag.DAGService, size int64) ([]byte, *mdag.ProtoNode) {
|
|
in := io.LimitReader(u.NewTimeSeededRand(), size)
|
|
buf, err := ioutil.ReadAll(in)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
node := GetNode(t, dserv, buf)
|
|
return buf, node
|
|
}
|
|
|
|
func ArrComp(a, b []byte) error {
|
|
if len(a) != len(b) {
|
|
return fmt.Errorf("Arrays differ in length. %d != %d", len(a), len(b))
|
|
}
|
|
for i, v := range a {
|
|
if v != b[i] {
|
|
return fmt.Errorf("Arrays differ at index: %d", i)
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func PrintDag(nd *mdag.ProtoNode, ds mdag.DAGService, indent int) {
|
|
pbd, err := ft.FromBytes(nd.Data())
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
for i := 0; i < indent; i++ {
|
|
fmt.Print(" ")
|
|
}
|
|
fmt.Printf("{size = %d, type = %s, children = %d", pbd.GetFilesize(), pbd.GetType().String(), len(pbd.GetBlocksizes()))
|
|
if len(nd.Links()) > 0 {
|
|
fmt.Println()
|
|
}
|
|
for _, lnk := range nd.Links() {
|
|
child, err := lnk.GetNode(context.Background(), ds)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
PrintDag(child.(*mdag.ProtoNode), ds, indent+1)
|
|
}
|
|
if len(nd.Links()) > 0 {
|
|
for i := 0; i < indent; i++ {
|
|
fmt.Print(" ")
|
|
}
|
|
}
|
|
fmt.Println("}")
|
|
}
|