-
Notifications
You must be signed in to change notification settings - Fork 165
/
Copy pathcandidate_relay_test.go
86 lines (71 loc) · 1.97 KB
/
candidate_relay_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
// SPDX-FileCopyrightText: 2023 The Pion community <https://pion.ly>
// SPDX-License-Identifier: MIT
//go:build !js
// +build !js
package ice
import (
"net"
"strconv"
"testing"
"time"
"github.com/pion/stun/v3"
"github.com/pion/transport/v3/test"
"github.com/pion/turn/v4"
"github.com/stretchr/testify/require"
)
func optimisticAuthHandler(string, string, net.Addr) (key []byte, ok bool) {
return turn.GenerateAuthKey("username", "pion.ly", "password"), true
}
func TestRelayOnlyConnection(t *testing.T) {
// Limit runtime in case of deadlocks
defer test.TimeOut(time.Second * 30).Stop()
defer test.CheckRoutines(t)()
serverPort := randomPort(t)
serverListener, err := net.ListenPacket("udp", localhostIPStr+":"+strconv.Itoa(serverPort))
require.NoError(t, err)
server, err := turn.NewServer(turn.ServerConfig{
Realm: "pion.ly",
AuthHandler: optimisticAuthHandler,
PacketConnConfigs: []turn.PacketConnConfig{
{
PacketConn: serverListener,
RelayAddressGenerator: &turn.RelayAddressGeneratorNone{Address: localhostIPStr + ""},
},
},
})
require.NoError(t, err)
defer func() {
require.NoError(t, server.Close())
}()
cfg := &AgentConfig{
NetworkTypes: supportedNetworkTypes(),
Urls: []*stun.URI{
{
Scheme: stun.SchemeTypeTURN,
Host: localhostIPStr + "",
Username: "username",
Password: "password",
Port: serverPort,
Proto: stun.ProtoTypeUDP,
},
},
CandidateTypes: []CandidateType{CandidateTypeRelay},
}
aAgent, err := NewAgent(cfg)
require.NoError(t, err)
defer func() {
require.NoError(t, aAgent.Close())
}()
aNotifier, aConnected := onConnected()
require.NoError(t, aAgent.OnConnectionStateChange(aNotifier))
bAgent, err := NewAgent(cfg)
require.NoError(t, err)
defer func() {
require.NoError(t, bAgent.Close())
}()
bNotifier, bConnected := onConnected()
require.NoError(t, bAgent.OnConnectionStateChange(bNotifier))
connect(aAgent, bAgent)
<-aConnected
<-bConnected
}