mirror of
https://github.com/status-im/go-waku.git
synced 2025-01-17 17:20:59 +00:00
9f45d271ac
* feat: support peermanager serviceslots and update store protocol to use serviceslots * fix: lint errors in test code * fix: error in nix build due to vendor sha change * fix: set host in peermanager even if relay is disabled * chore: fix codeclimate issues * chore: using common filterPeer function to avoid duplication * feat:use service slots in other service protocols * chore: fix codeclimate issues * chore: move AddPeer to peermanager * Apply suggestions from code review Co-authored-by: richΛrd <info@richardramos.me> * chore:address review comments * feat: implement RemovePeer #638 * chore: fix test failure * Support for multiple slots for service peers Adding discovered peers also moved to peer manager --------- Co-authored-by: richΛrd <info@richardramos.me>
61 lines
1.4 KiB
Go
61 lines
1.4 KiB
Go
package node
|
|
|
|
import (
|
|
"net"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
"github.com/multiformats/go-multiaddr"
|
|
"github.com/stretchr/testify/require"
|
|
"github.com/waku-org/go-waku/tests"
|
|
"github.com/waku-org/go-waku/waku/persistence"
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/store"
|
|
)
|
|
|
|
func TestWakuOptions(t *testing.T) {
|
|
connStatusChan := make(chan ConnStatus, 100)
|
|
|
|
key, err := tests.RandomHex(32)
|
|
require.NoError(t, err)
|
|
|
|
prvKey, err := crypto.HexToECDSA(key)
|
|
require.NoError(t, err)
|
|
|
|
hostAddr, _ := net.ResolveTCPAddr("tcp", "0.0.0.0:0")
|
|
|
|
addr, err := multiaddr.NewMultiaddr("/ip4/0.0.0.0/tcp/4000/ws")
|
|
require.NoError(t, err)
|
|
|
|
storeFactory := func(w *WakuNode) store.Store {
|
|
return store.NewWakuStore(w.opts.messageProvider, w.peermanager, w.timesource, w.log)
|
|
}
|
|
|
|
options := []WakuNodeOption{
|
|
WithHostAddress(hostAddr),
|
|
WithAdvertiseAddresses(addr),
|
|
WithMultiaddress(addr),
|
|
WithPrivateKey(prvKey),
|
|
WithLibP2POptions(),
|
|
WithWakuRelay(),
|
|
WithLegacyWakuFilter(true),
|
|
WithDiscoveryV5(123, nil, false),
|
|
WithWakuStore(),
|
|
WithMessageProvider(&persistence.DBStore{}),
|
|
WithLightPush(),
|
|
WithKeepAlive(time.Hour),
|
|
WithConnectionStatusChannel(connStatusChan),
|
|
WithWakuStoreFactory(storeFactory),
|
|
}
|
|
|
|
params := new(WakuNodeParameters)
|
|
|
|
for _, opt := range options {
|
|
require.NoError(t, opt(params))
|
|
}
|
|
|
|
require.NotNil(t, params.multiAddr)
|
|
require.NotNil(t, params.privKey)
|
|
require.NotNil(t, params.connStatusC)
|
|
}
|