2018-09-02 19:03:02 +08:00
|
|
|
package pstoreds
|
2018-08-30 20:44:50 +08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2021-10-23 00:01:08 +08:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2018-09-08 01:46:23 +08:00
|
|
|
ds "github.com/ipfs/go-datastore"
|
2018-09-11 21:13:14 +08:00
|
|
|
badger "github.com/ipfs/go-ds-badger"
|
2018-10-04 17:50:45 +08:00
|
|
|
leveldb "github.com/ipfs/go-ds-leveldb"
|
2018-09-11 02:59:27 +08:00
|
|
|
|
2019-05-31 21:51:16 +08:00
|
|
|
pstore "github.com/libp2p/go-libp2p-core/peerstore"
|
2018-09-08 01:46:23 +08:00
|
|
|
pt "github.com/libp2p/go-libp2p-peerstore/test"
|
2018-08-30 20:44:50 +08:00
|
|
|
)
|
|
|
|
|
2018-12-04 01:29:28 +08:00
|
|
|
type datastoreFactory func(tb testing.TB) (ds.Batching, func())
|
2018-09-11 02:59:27 +08:00
|
|
|
|
2018-10-04 17:50:45 +08:00
|
|
|
var dstores = map[string]datastoreFactory{
|
2021-07-17 01:58:29 +08:00
|
|
|
//"Badger": badgerStore,
|
|
|
|
"Leveldb": leveldbStore,
|
2018-09-11 02:59:27 +08:00
|
|
|
}
|
|
|
|
|
2018-10-04 17:50:45 +08:00
|
|
|
func TestDsPeerstore(t *testing.T) {
|
|
|
|
for name, dsFactory := range dstores {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
pt.TestPeerstore(t, peerstoreFactory(t, dsFactory, DefaultOpts()))
|
|
|
|
})
|
2021-10-23 00:01:08 +08:00
|
|
|
|
|
|
|
t.Run("protobook limits", func(t *testing.T) {
|
|
|
|
const limit = 10
|
|
|
|
opts := DefaultOpts()
|
|
|
|
opts.MaxProtocols = limit
|
|
|
|
ds, close := dsFactory(t)
|
|
|
|
defer close()
|
|
|
|
ps, err := NewPeerstore(context.Background(), ds, opts)
|
|
|
|
require.NoError(t, err)
|
|
|
|
defer ps.Close()
|
|
|
|
pt.TestPeerstoreProtoStoreLimits(t, ps, limit)
|
|
|
|
})
|
2018-09-11 02:59:27 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-04 17:50:45 +08:00
|
|
|
func TestDsAddrBook(t *testing.T) {
|
|
|
|
for name, dsFactory := range dstores {
|
2018-10-29 18:14:51 +08:00
|
|
|
t.Run(name+" Cacheful", func(t *testing.T) {
|
|
|
|
opts := DefaultOpts()
|
2018-11-28 09:29:09 +08:00
|
|
|
opts.GCPurgeInterval = 1 * time.Second
|
2018-10-29 18:14:51 +08:00
|
|
|
opts.CacheSize = 1024
|
2018-09-11 02:59:27 +08:00
|
|
|
|
2018-10-29 18:14:51 +08:00
|
|
|
pt.TestAddrBook(t, addressBookFactory(t, dsFactory, opts))
|
|
|
|
})
|
2018-09-11 02:59:27 +08:00
|
|
|
|
2018-10-29 18:14:51 +08:00
|
|
|
t.Run(name+" Cacheless", func(t *testing.T) {
|
|
|
|
opts := DefaultOpts()
|
2018-11-28 09:29:09 +08:00
|
|
|
opts.GCPurgeInterval = 1 * time.Second
|
2018-10-29 18:14:51 +08:00
|
|
|
opts.CacheSize = 0
|
2018-09-11 02:59:27 +08:00
|
|
|
|
2018-10-29 18:14:51 +08:00
|
|
|
pt.TestAddrBook(t, addressBookFactory(t, dsFactory, opts))
|
2018-10-04 17:50:45 +08:00
|
|
|
})
|
2018-09-11 02:59:27 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-04 17:50:45 +08:00
|
|
|
func TestDsKeyBook(t *testing.T) {
|
|
|
|
for name, dsFactory := range dstores {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
pt.TestKeyBook(t, keyBookFactory(t, dsFactory, DefaultOpts()))
|
|
|
|
})
|
2018-09-11 02:59:27 +08:00
|
|
|
}
|
2018-09-28 21:04:52 +08:00
|
|
|
}
|
|
|
|
|
2018-10-29 18:17:10 +08:00
|
|
|
func BenchmarkDsKeyBook(b *testing.B) {
|
|
|
|
for name, dsFactory := range dstores {
|
|
|
|
b.Run(name, func(b *testing.B) {
|
|
|
|
pt.BenchmarkKeyBook(b, keyBookFactory(b, dsFactory, DefaultOpts()))
|
|
|
|
})
|
|
|
|
}
|
2018-09-28 21:04:52 +08:00
|
|
|
}
|
|
|
|
|
2018-10-04 17:50:45 +08:00
|
|
|
func BenchmarkDsPeerstore(b *testing.B) {
|
2018-09-04 21:52:26 +08:00
|
|
|
caching := DefaultOpts()
|
|
|
|
caching.CacheSize = 1024
|
|
|
|
|
|
|
|
cacheless := DefaultOpts()
|
|
|
|
cacheless.CacheSize = 0
|
|
|
|
|
2018-10-04 17:50:45 +08:00
|
|
|
for name, dsFactory := range dstores {
|
|
|
|
b.Run(name, func(b *testing.B) {
|
|
|
|
pt.BenchmarkPeerstore(b, peerstoreFactory(b, dsFactory, caching), "Caching")
|
2018-10-29 18:14:51 +08:00
|
|
|
})
|
|
|
|
b.Run(name, func(b *testing.B) {
|
2018-10-04 17:50:45 +08:00
|
|
|
pt.BenchmarkPeerstore(b, peerstoreFactory(b, dsFactory, cacheless), "Cacheless")
|
|
|
|
})
|
|
|
|
}
|
2018-09-04 21:52:26 +08:00
|
|
|
}
|
|
|
|
|
2021-07-17 01:58:29 +08:00
|
|
|
// Doesn't work on 32bit because badger.
|
|
|
|
//lint:ignore U1000 disabled for now
|
2018-12-04 01:29:28 +08:00
|
|
|
func badgerStore(tb testing.TB) (ds.Batching, func()) {
|
2018-08-30 20:44:50 +08:00
|
|
|
dataPath, err := ioutil.TempDir(os.TempDir(), "badger")
|
|
|
|
if err != nil {
|
2018-10-04 17:50:45 +08:00
|
|
|
tb.Fatal(err)
|
2018-08-30 20:44:50 +08:00
|
|
|
}
|
2018-09-28 21:04:52 +08:00
|
|
|
store, err := badger.NewDatastore(dataPath, nil)
|
2018-08-30 20:44:50 +08:00
|
|
|
if err != nil {
|
2018-10-04 17:50:45 +08:00
|
|
|
tb.Fatal(err)
|
2018-08-30 20:44:50 +08:00
|
|
|
}
|
|
|
|
closer := func() {
|
2018-09-28 21:04:52 +08:00
|
|
|
store.Close()
|
2018-08-30 20:44:50 +08:00
|
|
|
os.RemoveAll(dataPath)
|
|
|
|
}
|
2018-09-28 21:04:52 +08:00
|
|
|
return store, closer
|
2018-08-30 20:44:50 +08:00
|
|
|
}
|
|
|
|
|
2021-07-17 01:58:29 +08:00
|
|
|
func leveldbStore(tb testing.TB) (ds.Batching, func()) {
|
2021-07-21 08:18:43 +08:00
|
|
|
// Intentionally test in-memory because disks suck, especially in CI.
|
|
|
|
store, err := leveldb.NewDatastore("", nil)
|
2018-10-04 17:50:45 +08:00
|
|
|
if err != nil {
|
|
|
|
tb.Fatal(err)
|
|
|
|
}
|
|
|
|
closer := func() {
|
|
|
|
store.Close()
|
|
|
|
}
|
|
|
|
return store, closer
|
|
|
|
}
|
|
|
|
|
|
|
|
func peerstoreFactory(tb testing.TB, storeFactory datastoreFactory, opts Options) pt.PeerstoreFactory {
|
2018-09-08 01:46:23 +08:00
|
|
|
return func() (pstore.Peerstore, func()) {
|
2019-02-19 19:45:32 +08:00
|
|
|
store, storeCloseFn := storeFactory(tb)
|
2018-09-19 01:01:10 +08:00
|
|
|
ps, err := NewPeerstore(context.Background(), store, opts)
|
2018-08-30 20:44:50 +08:00
|
|
|
if err != nil {
|
|
|
|
tb.Fatal(err)
|
|
|
|
}
|
2019-02-19 19:45:32 +08:00
|
|
|
closer := func() {
|
|
|
|
ps.Close()
|
|
|
|
storeCloseFn()
|
|
|
|
}
|
|
|
|
return ps, closer
|
2018-08-30 20:44:50 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-04 17:50:45 +08:00
|
|
|
func addressBookFactory(tb testing.TB, storeFactory datastoreFactory, opts Options) pt.AddrBookFactory {
|
2018-09-11 21:13:14 +08:00
|
|
|
return func() (pstore.AddrBook, func()) {
|
2018-10-04 17:50:45 +08:00
|
|
|
store, closeFunc := storeFactory(tb)
|
2018-09-19 01:01:10 +08:00
|
|
|
ab, err := NewAddrBook(context.Background(), store, opts)
|
2018-08-30 20:44:50 +08:00
|
|
|
if err != nil {
|
2018-09-04 21:52:26 +08:00
|
|
|
tb.Fatal(err)
|
2018-08-30 20:44:50 +08:00
|
|
|
}
|
2019-02-19 19:45:32 +08:00
|
|
|
closer := func() {
|
2018-11-13 06:28:12 +08:00
|
|
|
ab.Close()
|
|
|
|
closeFunc()
|
|
|
|
}
|
2019-02-19 19:45:32 +08:00
|
|
|
return ab, closer
|
2018-09-04 21:52:26 +08:00
|
|
|
}
|
2018-08-30 22:24:06 +08:00
|
|
|
}
|
2018-09-28 21:04:52 +08:00
|
|
|
|
2018-10-04 17:50:45 +08:00
|
|
|
func keyBookFactory(tb testing.TB, storeFactory datastoreFactory, opts Options) pt.KeyBookFactory {
|
2018-09-28 21:04:52 +08:00
|
|
|
return func() (pstore.KeyBook, func()) {
|
2019-02-19 19:45:32 +08:00
|
|
|
store, storeCloseFn := storeFactory(tb)
|
2018-10-04 17:50:45 +08:00
|
|
|
kb, err := NewKeyBook(context.Background(), store, opts)
|
|
|
|
if err != nil {
|
|
|
|
tb.Fatal(err)
|
|
|
|
}
|
2019-02-19 19:45:32 +08:00
|
|
|
return kb, storeCloseFn
|
2018-09-28 21:04:52 +08:00
|
|
|
}
|
|
|
|
}
|