| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 | 
							- package nebula
 
- import (
 
- 	"net/netip"
 
- 	"testing"
 
- 	"time"
 
- 	"github.com/slackhq/nebula/cert"
 
- 	"github.com/slackhq/nebula/header"
 
- 	"github.com/slackhq/nebula/test"
 
- 	"github.com/slackhq/nebula/udp"
 
- 	"github.com/stretchr/testify/assert"
 
- )
 
- func Test_NewHandshakeManagerVpnIp(t *testing.T) {
 
- 	l := test.NewLogger()
 
- 	localrange := netip.MustParsePrefix("10.1.1.1/24")
 
- 	ip := netip.MustParseAddr("172.1.1.2")
 
- 	preferredRanges := []netip.Prefix{localrange}
 
- 	mainHM := newHostMap(l)
 
- 	mainHM.preferredRanges.Store(&preferredRanges)
 
- 	lh := newTestLighthouse()
 
- 	cs := &CertState{
 
- 		initiatingVersion: cert.Version1,
 
- 		privateKey:        []byte{},
 
- 		v1Cert:            &dummyCert{version: cert.Version1},
 
- 		v1HandshakeBytes:  []byte{},
 
- 	}
 
- 	blah := NewHandshakeManager(l, mainHM, lh, &udp.NoopConn{}, defaultHandshakeConfig)
 
- 	blah.f = &Interface{handshakeManager: blah, pki: &PKI{}, l: l}
 
- 	blah.f.pki.cs.Store(cs)
 
- 	now := time.Now()
 
- 	blah.NextOutboundHandshakeTimerTick(now)
 
- 	i := blah.StartHandshake(ip, nil)
 
- 	i2 := blah.StartHandshake(ip, nil)
 
- 	assert.Same(t, i, i2)
 
- 	i.remotes = NewRemoteList([]netip.Addr{}, nil)
 
- 	// Adding something to pending should not affect the main hostmap
 
- 	assert.Empty(t, mainHM.Hosts)
 
- 	// Confirm they are in the pending index list
 
- 	assert.Contains(t, blah.vpnIps, ip)
 
- 	// Jump ahead `HandshakeRetries` ticks, offset by one to get the sleep logic right
 
- 	for i := 1; i <= DefaultHandshakeRetries+1; i++ {
 
- 		now = now.Add(time.Duration(i) * DefaultHandshakeTryInterval)
 
- 		blah.NextOutboundHandshakeTimerTick(now)
 
- 	}
 
- 	// Confirm they are still in the pending index list
 
- 	assert.Contains(t, blah.vpnIps, ip)
 
- 	// Tick 1 more time, a minute will certainly flush it out
 
- 	blah.NextOutboundHandshakeTimerTick(now.Add(time.Minute))
 
- 	// Confirm they have been removed
 
- 	assert.NotContains(t, blah.vpnIps, ip)
 
- }
 
- func testCountTimerWheelEntries(tw *LockingTimerWheel[netip.Addr]) (c int) {
 
- 	for _, i := range tw.t.wheel {
 
- 		n := i.Head
 
- 		for n != nil {
 
- 			c++
 
- 			n = n.Next
 
- 		}
 
- 	}
 
- 	return c
 
- }
 
- type mockEncWriter struct {
 
- }
 
- func (mw *mockEncWriter) SendMessageToVpnAddr(_ header.MessageType, _ header.MessageSubType, _ netip.Addr, _, _, _ []byte) {
 
- 	return
 
- }
 
- func (mw *mockEncWriter) SendVia(_ *HostInfo, _ *Relay, _, _, _ []byte, _ bool) {
 
- 	return
 
- }
 
- func (mw *mockEncWriter) SendMessageToHostInfo(_ header.MessageType, _ header.MessageSubType, _ *HostInfo, _, _, _ []byte) {
 
- 	return
 
- }
 
- func (mw *mockEncWriter) Handshake(_ netip.Addr) {}
 
- func (mw *mockEncWriter) GetHostInfo(_ netip.Addr) *HostInfo {
 
- 	return nil
 
- }
 
- func (mw *mockEncWriter) GetCertState() *CertState {
 
- 	return &CertState{initiatingVersion: cert.Version2}
 
- }
 
 
  |