mirror of
https://github.com/aler9/gortsplib
synced 2025-10-02 14:02:16 +08:00
add *Server argument to NewServerStream()
This commit is contained in:
@@ -2,7 +2,6 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"log"
|
"log"
|
||||||
"sync"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/bluenviron/gortsplib/v4"
|
"github.com/bluenviron/gortsplib/v4"
|
||||||
@@ -18,12 +17,13 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type client struct {
|
type client struct {
|
||||||
mutex sync.RWMutex
|
s *server
|
||||||
stream *gortsplib.ServerStream
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func newClient() *client {
|
func newClient(s *server) *client {
|
||||||
c := &client{}
|
c := &client{
|
||||||
|
s: s,
|
||||||
|
}
|
||||||
|
|
||||||
// start a separated routine
|
// start a separated routine
|
||||||
go c.run()
|
go c.run()
|
||||||
@@ -40,12 +40,6 @@ func (c *client) run() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) getStream() *gortsplib.ServerStream {
|
|
||||||
c.mutex.RLock()
|
|
||||||
defer c.mutex.RUnlock()
|
|
||||||
return c.stream
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *client) read() error {
|
func (c *client) read() error {
|
||||||
rc := gortsplib.Client{}
|
rc := gortsplib.Client{}
|
||||||
|
|
||||||
@@ -74,24 +68,11 @@ func (c *client) read() error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// create a server stream
|
stream := c.s.setStreamReady(medias)
|
||||||
stream := gortsplib.NewServerStream(medias)
|
defer c.s.setStreamUnready()
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
log.Printf("stream is ready and can be read from the server at rtsp://localhost:8554/stream\n")
|
log.Printf("stream is ready and can be read from the server at rtsp://localhost:8554/stream\n")
|
||||||
|
|
||||||
// make stream available by using getStream()
|
|
||||||
c.mutex.Lock()
|
|
||||||
c.stream = stream
|
|
||||||
c.mutex.Unlock()
|
|
||||||
|
|
||||||
defer func() {
|
|
||||||
// remove stream from getStream()
|
|
||||||
c.mutex.Lock()
|
|
||||||
c.stream = nil
|
|
||||||
c.mutex.Unlock()
|
|
||||||
}()
|
|
||||||
|
|
||||||
// called when a RTP packet arrives
|
// called when a RTP packet arrives
|
||||||
rc.OnPacketRTPAny(func(medi *media.Media, forma formats.Format, pkt *rtp.Packet) {
|
rc.OnPacketRTPAny(func(medi *media.Media, forma formats.Format, pkt *rtp.Packet) {
|
||||||
// route incoming packets to the server stream
|
// route incoming packets to the server stream
|
||||||
|
@@ -1,14 +1,21 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
|
import "log"
|
||||||
|
|
||||||
// This example shows how to
|
// This example shows how to
|
||||||
// 1. read an existing stream from an external server or camera, with a client
|
// 1. create a server that allow to serve a stream.
|
||||||
// 2. create a server that allow to proxy that stream
|
// 2. create a client, read an existing stream from an external server or camera,
|
||||||
|
// pass the stream to the server in order to serve it.
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
// allocate the client
|
|
||||||
c := newClient()
|
|
||||||
|
|
||||||
// allocate the server.
|
// allocate the server.
|
||||||
// give server access to the method client.getStream().
|
s := newServer()
|
||||||
newServer(c.getStream)
|
|
||||||
|
// allocate the client.
|
||||||
|
// give client access to the server.
|
||||||
|
newClient(s)
|
||||||
|
|
||||||
|
// start server and wait until a fatal error
|
||||||
|
log.Printf("server is ready")
|
||||||
|
s.s.StartAndWait()
|
||||||
}
|
}
|
||||||
|
@@ -2,24 +2,24 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"log"
|
"log"
|
||||||
|
"sync"
|
||||||
|
|
||||||
"github.com/bluenviron/gortsplib/v4"
|
"github.com/bluenviron/gortsplib/v4"
|
||||||
"github.com/bluenviron/gortsplib/v4/pkg/base"
|
"github.com/bluenviron/gortsplib/v4/pkg/base"
|
||||||
|
"github.com/bluenviron/gortsplib/v4/pkg/media"
|
||||||
)
|
)
|
||||||
|
|
||||||
type server struct {
|
type server struct {
|
||||||
getStream func() *gortsplib.ServerStream
|
s *gortsplib.Server
|
||||||
|
mutex sync.Mutex
|
||||||
|
stream *gortsplib.ServerStream
|
||||||
}
|
}
|
||||||
|
|
||||||
func newServer(
|
func newServer() *server {
|
||||||
getStream func() *gortsplib.ServerStream,
|
s := &server{}
|
||||||
) *server {
|
|
||||||
s := &server{
|
|
||||||
getStream: getStream,
|
|
||||||
}
|
|
||||||
|
|
||||||
// configure the server
|
// configure the server
|
||||||
rs := &gortsplib.Server{
|
s.s = &gortsplib.Server{
|
||||||
Handler: s,
|
Handler: s,
|
||||||
RTSPAddress: ":8554",
|
RTSPAddress: ":8554",
|
||||||
UDPRTPAddress: ":8000",
|
UDPRTPAddress: ":8000",
|
||||||
@@ -29,9 +29,7 @@ func newServer(
|
|||||||
MulticastRTCPPort: 8003,
|
MulticastRTCPPort: 8003,
|
||||||
}
|
}
|
||||||
|
|
||||||
// start server and wait until a fatal error
|
return s
|
||||||
log.Printf("server is ready")
|
|
||||||
panic(rs.StartAndWait())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// called when a connection is opened.
|
// called when a connection is opened.
|
||||||
@@ -58,10 +56,11 @@ func (s *server) OnSessionClose(ctx *gortsplib.ServerHandlerOnSessionCloseCtx) {
|
|||||||
func (s *server) OnDescribe(ctx *gortsplib.ServerHandlerOnDescribeCtx) (*base.Response, *gortsplib.ServerStream, error) {
|
func (s *server) OnDescribe(ctx *gortsplib.ServerHandlerOnDescribeCtx) (*base.Response, *gortsplib.ServerStream, error) {
|
||||||
log.Printf("describe request")
|
log.Printf("describe request")
|
||||||
|
|
||||||
stream := s.getStream()
|
s.mutex.Lock()
|
||||||
|
defer s.mutex.Unlock()
|
||||||
|
|
||||||
// stream is not available yet
|
// stream is not available yet
|
||||||
if stream == nil {
|
if s.stream == nil {
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
StatusCode: base.StatusNotFound,
|
StatusCode: base.StatusNotFound,
|
||||||
}, nil, nil
|
}, nil, nil
|
||||||
@@ -69,17 +68,18 @@ func (s *server) OnDescribe(ctx *gortsplib.ServerHandlerOnDescribeCtx) (*base.Re
|
|||||||
|
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
StatusCode: base.StatusOK,
|
StatusCode: base.StatusOK,
|
||||||
}, stream, nil
|
}, s.stream, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// called when receiving a SETUP request.
|
// called when receiving a SETUP request.
|
||||||
func (s *server) OnSetup(ctx *gortsplib.ServerHandlerOnSetupCtx) (*base.Response, *gortsplib.ServerStream, error) {
|
func (s *server) OnSetup(ctx *gortsplib.ServerHandlerOnSetupCtx) (*base.Response, *gortsplib.ServerStream, error) {
|
||||||
log.Printf("setup request")
|
log.Printf("setup request")
|
||||||
|
|
||||||
stream := s.getStream()
|
s.mutex.Lock()
|
||||||
|
defer s.mutex.Unlock()
|
||||||
|
|
||||||
// stream is not available yet
|
// stream is not available yet
|
||||||
if stream == nil {
|
if s.stream == nil {
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
StatusCode: base.StatusNotFound,
|
StatusCode: base.StatusNotFound,
|
||||||
}, nil, nil
|
}, nil, nil
|
||||||
@@ -87,7 +87,7 @@ func (s *server) OnSetup(ctx *gortsplib.ServerHandlerOnSetupCtx) (*base.Response
|
|||||||
|
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
StatusCode: base.StatusOK,
|
StatusCode: base.StatusOK,
|
||||||
}, stream, nil
|
}, s.stream, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// called when receiving a PLAY request.
|
// called when receiving a PLAY request.
|
||||||
@@ -98,3 +98,17 @@ func (s *server) OnPlay(ctx *gortsplib.ServerHandlerOnPlayCtx) (*base.Response,
|
|||||||
StatusCode: base.StatusOK,
|
StatusCode: base.StatusOK,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *server) setStreamReady(medias media.Medias) *gortsplib.ServerStream {
|
||||||
|
s.mutex.Lock()
|
||||||
|
defer s.mutex.Unlock()
|
||||||
|
s.stream = gortsplib.NewServerStream(s.s, medias)
|
||||||
|
return s.stream
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *server) setStreamUnready() {
|
||||||
|
s.mutex.Lock()
|
||||||
|
defer s.mutex.Unlock()
|
||||||
|
s.stream.Close()
|
||||||
|
s.stream = nil
|
||||||
|
}
|
||||||
|
@@ -88,7 +88,7 @@ func (sh *serverHandler) OnAnnounce(ctx *gortsplib.ServerHandlerOnAnnounceCtx) (
|
|||||||
}
|
}
|
||||||
|
|
||||||
// create the stream and save the publisher
|
// create the stream and save the publisher
|
||||||
sh.stream = gortsplib.NewServerStream(ctx.Medias)
|
sh.stream = gortsplib.NewServerStream(ctx.Server, ctx.Medias)
|
||||||
sh.publisher = ctx.Session
|
sh.publisher = ctx.Session
|
||||||
|
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
|
@@ -87,7 +87,7 @@ func (sh *serverHandler) OnAnnounce(ctx *gortsplib.ServerHandlerOnAnnounceCtx) (
|
|||||||
}
|
}
|
||||||
|
|
||||||
// create the stream and save the publisher
|
// create the stream and save the publisher
|
||||||
sh.stream = gortsplib.NewServerStream(ctx.Medias)
|
sh.stream = gortsplib.NewServerStream(ctx.Server, ctx.Medias)
|
||||||
sh.publisher = ctx.Session
|
sh.publisher = ctx.Session
|
||||||
|
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
|
@@ -328,7 +328,7 @@ func TestServerRecordRead(t *testing.T) {
|
|||||||
}, fmt.Errorf("someone is already publishing")
|
}, fmt.Errorf("someone is already publishing")
|
||||||
}
|
}
|
||||||
|
|
||||||
stream = gortsplib.NewServerStream(ctx.Medias)
|
stream = gortsplib.NewServerStream(ctx.Server, ctx.Medias)
|
||||||
publisher = ctx.Session
|
publisher = ctx.Session
|
||||||
|
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
|
@@ -222,13 +222,7 @@ func TestServerPlayPath(t *testing.T) {
|
|||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run(ca.name, func(t *testing.T) {
|
t.Run(ca.name, func(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{
|
var stream *ServerStream
|
||||||
testH264Media,
|
|
||||||
testH264Media,
|
|
||||||
testH264Media,
|
|
||||||
testH264Media,
|
|
||||||
})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -259,6 +253,14 @@ func TestServerPlayPath(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{
|
||||||
|
testH264Media,
|
||||||
|
testH264Media,
|
||||||
|
testH264Media,
|
||||||
|
testH264Media,
|
||||||
|
})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -298,15 +300,9 @@ func TestServerPlaySetupErrors(t *testing.T) {
|
|||||||
"closed stream",
|
"closed stream",
|
||||||
} {
|
} {
|
||||||
t.Run(ca, func(t *testing.T) {
|
t.Run(ca, func(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
nconnClosed := make(chan struct{})
|
nconnClosed := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
if ca == "closed stream" {
|
|
||||||
stream.Close()
|
|
||||||
} else {
|
|
||||||
defer stream.Close()
|
|
||||||
}
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
onConnClose: func(ctx *ServerHandlerOnConnCloseCtx) {
|
onConnClose: func(ctx *ServerHandlerOnConnCloseCtx) {
|
||||||
@@ -340,6 +336,13 @@ func TestServerPlaySetupErrors(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
if ca == "closed stream" {
|
||||||
|
stream.Close()
|
||||||
|
} else {
|
||||||
|
defer stream.Close()
|
||||||
|
}
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -421,8 +424,7 @@ func TestServerPlaySetupErrors(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerPlaySetupErrorSameUDPPortsAndIP(t *testing.T) {
|
func TestServerPlaySetupErrorSameUDPPortsAndIP(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
first := int32(1)
|
first := int32(1)
|
||||||
errorRecv := make(chan struct{})
|
errorRecv := make(chan struct{})
|
||||||
|
|
||||||
@@ -460,6 +462,9 @@ func TestServerPlaySetupErrorSameUDPPortsAndIP(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
for i := 0; i < 2; i++ {
|
for i := 0; i < 2; i++ {
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
@@ -509,15 +514,12 @@ func TestServerPlay(t *testing.T) {
|
|||||||
"multicast",
|
"multicast",
|
||||||
} {
|
} {
|
||||||
t.Run(transport, func(t *testing.T) {
|
t.Run(transport, func(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
nconnOpened := make(chan struct{})
|
nconnOpened := make(chan struct{})
|
||||||
nconnClosed := make(chan struct{})
|
nconnClosed := make(chan struct{})
|
||||||
sessionOpened := make(chan struct{})
|
sessionOpened := make(chan struct{})
|
||||||
sessionClosed := make(chan struct{})
|
sessionClosed := make(chan struct{})
|
||||||
framesReceived := make(chan struct{})
|
framesReceived := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
counter := uint64(0)
|
counter := uint64(0)
|
||||||
|
|
||||||
listenIP := multicastCapableIP(t)
|
listenIP := multicastCapableIP(t)
|
||||||
@@ -609,6 +611,9 @@ func TestServerPlay(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", listenIP+":8554")
|
nconn, err := net.Dial("tcp", listenIP+":8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
@@ -838,11 +843,9 @@ func TestServerPlayDecodeErrors(t *testing.T) {
|
|||||||
{"tcp", "rtcp too big"},
|
{"tcp", "rtcp too big"},
|
||||||
} {
|
} {
|
||||||
t.Run(ca.proto+" "+ca.name, func(t *testing.T) {
|
t.Run(ca.proto+" "+ca.name, func(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
errorRecv := make(chan struct{})
|
errorRecv := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
onDescribe: func(ctx *ServerHandlerOnDescribeCtx) (*base.Response, *ServerStream, error) {
|
onDescribe: func(ctx *ServerHandlerOnDescribeCtx) (*base.Response, *ServerStream, error) {
|
||||||
@@ -886,6 +889,9 @@ func TestServerPlayDecodeErrors(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -969,8 +975,7 @@ func TestServerPlayDecodeErrors(t *testing.T) {
|
|||||||
func TestServerPlayRTCPReport(t *testing.T) {
|
func TestServerPlayRTCPReport(t *testing.T) {
|
||||||
for _, ca := range []string{"udp", "tcp"} {
|
for _, ca := range []string{"udp", "tcp"} {
|
||||||
t.Run(ca, func(t *testing.T) {
|
t.Run(ca, func(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -1000,6 +1005,9 @@ func TestServerPlayRTCPReport(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -1092,9 +1100,7 @@ func TestServerPlayRTCPReport(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerPlayVLCMulticast(t *testing.T) {
|
func TestServerPlayVLCMulticast(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
listenIP := multicastCapableIP(t)
|
listenIP := multicastCapableIP(t)
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
@@ -1115,6 +1121,9 @@ func TestServerPlayVLCMulticast(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", listenIP+":8554")
|
nconn, err := net.Dial("tcp", listenIP+":8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
conn := conn.NewConn(nconn)
|
conn := conn.NewConn(nconn)
|
||||||
@@ -1138,12 +1147,10 @@ func TestServerPlayVLCMulticast(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerPlayTCPResponseBeforeFrames(t *testing.T) {
|
func TestServerPlayTCPResponseBeforeFrames(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
writerDone := make(chan struct{})
|
writerDone := make(chan struct{})
|
||||||
writerTerminate := make(chan struct{})
|
writerTerminate := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
RTSPAddress: "localhost:8554",
|
RTSPAddress: "localhost:8554",
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -1195,6 +1202,9 @@ func TestServerPlayTCPResponseBeforeFrames(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -1226,8 +1236,7 @@ func TestServerPlayTCPResponseBeforeFrames(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerPlayPlayPlay(t *testing.T) {
|
func TestServerPlayPlayPlay(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -1256,6 +1265,9 @@ func TestServerPlayPlayPlay(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -1285,13 +1297,11 @@ func TestServerPlayPlayPlay(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerPlayPlayPausePlay(t *testing.T) {
|
func TestServerPlayPlayPausePlay(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
writerStarted := false
|
writerStarted := false
|
||||||
writerDone := make(chan struct{})
|
writerDone := make(chan struct{})
|
||||||
writerTerminate := make(chan struct{})
|
writerTerminate := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
onConnClose: func(ctx *ServerHandlerOnConnCloseCtx) {
|
onConnClose: func(ctx *ServerHandlerOnConnCloseCtx) {
|
||||||
@@ -1346,6 +1356,9 @@ func TestServerPlayPlayPausePlay(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -1376,12 +1389,10 @@ func TestServerPlayPlayPausePlay(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerPlayPlayPausePause(t *testing.T) {
|
func TestServerPlayPlayPausePause(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
writerDone := make(chan struct{})
|
writerDone := make(chan struct{})
|
||||||
writerTerminate := make(chan struct{})
|
writerTerminate := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
onConnClose: func(ctx *ServerHandlerOnConnCloseCtx) {
|
onConnClose: func(ctx *ServerHandlerOnConnCloseCtx) {
|
||||||
@@ -1433,6 +1444,9 @@ func TestServerPlayPlayPausePause(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -1471,11 +1485,9 @@ func TestServerPlayTimeout(t *testing.T) {
|
|||||||
// there's no timeout when reading with TCP
|
// there's no timeout when reading with TCP
|
||||||
} {
|
} {
|
||||||
t.Run(transport, func(t *testing.T) {
|
t.Run(transport, func(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
sessionClosed := make(chan struct{})
|
sessionClosed := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
onSessionClose: func(ctx *ServerHandlerOnSessionCloseCtx) {
|
onSessionClose: func(ctx *ServerHandlerOnSessionCloseCtx) {
|
||||||
@@ -1518,6 +1530,9 @@ func TestServerPlayTimeout(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -1562,12 +1577,10 @@ func TestServerPlayWithoutTeardown(t *testing.T) {
|
|||||||
"tcp",
|
"tcp",
|
||||||
} {
|
} {
|
||||||
t.Run(transport, func(t *testing.T) {
|
t.Run(transport, func(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
nconnClosed := make(chan struct{})
|
nconnClosed := make(chan struct{})
|
||||||
sessionClosed := make(chan struct{})
|
sessionClosed := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
onConnClose: func(ctx *ServerHandlerOnConnCloseCtx) {
|
onConnClose: func(ctx *ServerHandlerOnConnCloseCtx) {
|
||||||
@@ -1606,6 +1619,9 @@ func TestServerPlayWithoutTeardown(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -1647,8 +1663,7 @@ func TestServerPlayWithoutTeardown(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerPlayUDPChangeConn(t *testing.T) {
|
func TestServerPlayUDPChangeConn(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -1682,6 +1697,9 @@ func TestServerPlayUDPChangeConn(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
sxID := ""
|
sxID := ""
|
||||||
|
|
||||||
func() {
|
func() {
|
||||||
@@ -1734,8 +1752,7 @@ func TestServerPlayUDPChangeConn(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerPlayPartialMedias(t *testing.T) {
|
func TestServerPlayPartialMedias(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media, testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -1770,6 +1787,9 @@ func TestServerPlayPartialMedias(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media, testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -1864,17 +1884,7 @@ func TestServerPlayAdditionalInfos(t *testing.T) {
|
|||||||
err := forma.Init()
|
err := forma.Init()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{
|
var stream *ServerStream
|
||||||
&media.Media{
|
|
||||||
Type: "application",
|
|
||||||
Formats: []formats.Format{forma},
|
|
||||||
},
|
|
||||||
&media.Media{
|
|
||||||
Type: "application",
|
|
||||||
Formats: []formats.Format{forma},
|
|
||||||
},
|
|
||||||
})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -1901,6 +1911,18 @@ func TestServerPlayAdditionalInfos(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{
|
||||||
|
&media.Media{
|
||||||
|
Type: "application",
|
||||||
|
Formats: []formats.Format{forma},
|
||||||
|
},
|
||||||
|
&media.Media{
|
||||||
|
Type: "application",
|
||||||
|
Formats: []formats.Format{forma},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
err = stream.WritePacketRTP(stream.Medias()[0], &rtp.Packet{
|
err = stream.WritePacketRTP(stream.Medias()[0], &rtp.Packet{
|
||||||
Header: rtp.Header{
|
Header: rtp.Header{
|
||||||
Version: 2,
|
Version: 2,
|
||||||
@@ -1979,17 +2001,7 @@ func TestServerPlayNoInterleavedIDs(t *testing.T) {
|
|||||||
err := forma.Init()
|
err := forma.Init()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{
|
var stream *ServerStream
|
||||||
&media.Media{
|
|
||||||
Type: "application",
|
|
||||||
Formats: []formats.Format{forma},
|
|
||||||
},
|
|
||||||
&media.Media{
|
|
||||||
Type: "application",
|
|
||||||
Formats: []formats.Format{forma},
|
|
||||||
},
|
|
||||||
})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -2016,6 +2028,18 @@ func TestServerPlayNoInterleavedIDs(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{
|
||||||
|
&media.Media{
|
||||||
|
Type: "application",
|
||||||
|
Formats: []formats.Format{forma},
|
||||||
|
},
|
||||||
|
&media.Media{
|
||||||
|
Type: "application",
|
||||||
|
Formats: []formats.Format{forma},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
|
@@ -223,7 +223,7 @@ func TestServerRecordPath(t *testing.T) {
|
|||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
onAnnounce: func(ctx *ServerHandlerOnAnnounceCtx) (*base.Response, error) {
|
onAnnounce: func(ctx *ServerHandlerOnAnnounceCtx) (*base.Response, error) {
|
||||||
// make sure that media URLs are not overridden by NewServerStream()
|
// make sure that media URLs are not overridden by NewServerStream()
|
||||||
stream := NewServerStream(ctx.Medias)
|
stream := NewServerStream(ctx.Server, ctx.Medias)
|
||||||
defer stream.Close()
|
defer stream.Close()
|
||||||
|
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
|
@@ -19,10 +19,10 @@ import (
|
|||||||
// - allocating multicast listeners
|
// - allocating multicast listeners
|
||||||
// - gathering infos about the stream in order to generate SSRC and RTP-Info
|
// - gathering infos about the stream in order to generate SSRC and RTP-Info
|
||||||
type ServerStream struct {
|
type ServerStream struct {
|
||||||
|
s *Server
|
||||||
medias media.Medias
|
medias media.Medias
|
||||||
|
|
||||||
mutex sync.RWMutex
|
mutex sync.RWMutex
|
||||||
s *Server
|
|
||||||
activeUnicastReaders map[*ServerSession]struct{}
|
activeUnicastReaders map[*ServerSession]struct{}
|
||||||
readers map[*ServerSession]struct{}
|
readers map[*ServerSession]struct{}
|
||||||
streamMedias map[*media.Media]*serverStreamMedia
|
streamMedias map[*media.Media]*serverStreamMedia
|
||||||
@@ -30,8 +30,9 @@ type ServerStream struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// NewServerStream allocates a ServerStream.
|
// NewServerStream allocates a ServerStream.
|
||||||
func NewServerStream(medias media.Medias) *ServerStream {
|
func NewServerStream(s *Server, medias media.Medias) *ServerStream {
|
||||||
st := &ServerStream{
|
st := &ServerStream{
|
||||||
|
s: s,
|
||||||
medias: medias,
|
medias: medias,
|
||||||
activeUnicastReaders: make(map[*ServerSession]struct{}),
|
activeUnicastReaders: make(map[*ServerSession]struct{}),
|
||||||
readers: make(map[*ServerSession]struct{}),
|
readers: make(map[*ServerSession]struct{}),
|
||||||
@@ -42,10 +43,6 @@ func NewServerStream(medias media.Medias) *ServerStream {
|
|||||||
st.streamMedias[medi] = newServerStreamMedia(st, medi, i)
|
st.streamMedias[medi] = newServerStreamMedia(st, medi, i)
|
||||||
}
|
}
|
||||||
|
|
||||||
return st
|
|
||||||
}
|
|
||||||
|
|
||||||
func (st *ServerStream) initializeServerDependentPart() {
|
|
||||||
if !st.s.DisableRTCPSenderReports {
|
if !st.s.DisableRTCPSenderReports {
|
||||||
for _, ssm := range st.streamMedias {
|
for _, ssm := range st.streamMedias {
|
||||||
for _, tr := range ssm.formats {
|
for _, tr := range ssm.formats {
|
||||||
@@ -53,6 +50,8 @@ func (st *ServerStream) initializeServerDependentPart() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return st
|
||||||
}
|
}
|
||||||
|
|
||||||
// Close closes a ServerStream.
|
// Close closes a ServerStream.
|
||||||
@@ -156,11 +155,6 @@ func (st *ServerStream) readerAdd(
|
|||||||
return fmt.Errorf("stream is closed")
|
return fmt.Errorf("stream is closed")
|
||||||
}
|
}
|
||||||
|
|
||||||
if st.s == nil {
|
|
||||||
st.s = ss.s
|
|
||||||
st.initializeServerDependentPart()
|
|
||||||
}
|
|
||||||
|
|
||||||
switch transport {
|
switch transport {
|
||||||
case TransportUDP:
|
case TransportUDP:
|
||||||
// check whether UDP ports and IP are already assigned to another reader
|
// check whether UDP ports and IP are already assigned to another reader
|
||||||
|
@@ -342,11 +342,10 @@ func (s *testServerErrMethodNotImplemented) OnSetup(
|
|||||||
func TestServerErrorMethodNotImplemented(t *testing.T) {
|
func TestServerErrorMethodNotImplemented(t *testing.T) {
|
||||||
for _, ca := range []string{"outside session", "inside session"} {
|
for _, ca := range []string{"outside session", "inside session"} {
|
||||||
t.Run(ca, func(t *testing.T) {
|
t.Run(ca, func(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
h := &testServerErrMethodNotImplemented{}
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerErrMethodNotImplemented{stream},
|
Handler: h,
|
||||||
RTSPAddress: "localhost:8554",
|
RTSPAddress: "localhost:8554",
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -354,6 +353,11 @@ func TestServerErrorMethodNotImplemented(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream := NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
|
h.stream = stream
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -416,8 +420,7 @@ func TestServerErrorMethodNotImplemented(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerErrorTCPTwoConnOneSession(t *testing.T) {
|
func TestServerErrorTCPTwoConnOneSession(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -449,6 +452,9 @@ func TestServerErrorTCPTwoConnOneSession(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn1, err := net.Dial("tcp", "localhost:8554")
|
nconn1, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn1.Close()
|
defer nconn1.Close()
|
||||||
@@ -507,8 +513,7 @@ func TestServerErrorTCPTwoConnOneSession(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerErrorTCPOneConnTwoSessions(t *testing.T) {
|
func TestServerErrorTCPOneConnTwoSessions(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -540,6 +545,9 @@ func TestServerErrorTCPOneConnTwoSessions(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -590,8 +598,7 @@ func TestServerErrorTCPOneConnTwoSessions(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerSetupMultipleTransports(t *testing.T) {
|
func TestServerSetupMultipleTransports(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -613,6 +620,9 @@ func TestServerSetupMultipleTransports(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -674,9 +684,7 @@ func TestServerSetupMultipleTransports(t *testing.T) {
|
|||||||
func TestServerGetSetParameter(t *testing.T) {
|
func TestServerGetSetParameter(t *testing.T) {
|
||||||
for _, ca := range []string{"inside session", "outside session"} {
|
for _, ca := range []string{"inside session", "outside session"} {
|
||||||
t.Run(ca, func(t *testing.T) {
|
t.Run(ca, func(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
var params []byte
|
var params []byte
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
@@ -723,6 +731,9 @@ func TestServerGetSetParameter(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -840,9 +851,7 @@ func TestServerErrorInvalidSession(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerSessionClose(t *testing.T) {
|
func TestServerSessionClose(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
var session *ServerSession
|
var session *ServerSession
|
||||||
connClosed := make(chan struct{})
|
connClosed := make(chan struct{})
|
||||||
|
|
||||||
@@ -872,6 +881,9 @@ func TestServerSessionClose(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
@@ -918,11 +930,9 @@ func TestServerSessionAutoClose(t *testing.T) {
|
|||||||
"200", "400",
|
"200", "400",
|
||||||
} {
|
} {
|
||||||
t.Run(ca, func(t *testing.T) {
|
t.Run(ca, func(t *testing.T) {
|
||||||
|
var stream *ServerStream
|
||||||
sessionClosed := make(chan struct{})
|
sessionClosed := make(chan struct{})
|
||||||
|
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
onSessionClose: func(ctx *ServerHandlerOnSessionCloseCtx) {
|
onSessionClose: func(ctx *ServerHandlerOnSessionCloseCtx) {
|
||||||
@@ -952,6 +962,9 @@ func TestServerSessionAutoClose(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
conn := conn.NewConn(nconn)
|
conn := conn.NewConn(nconn)
|
||||||
@@ -995,8 +1008,7 @@ func TestServerSessionAutoClose(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerSessionTeardown(t *testing.T) {
|
func TestServerSessionTeardown(t *testing.T) {
|
||||||
stream := NewServerStream(media.Medias{testH264Media})
|
var stream *ServerStream
|
||||||
defer stream.Close()
|
|
||||||
|
|
||||||
s := &Server{
|
s := &Server{
|
||||||
Handler: &testServerHandler{
|
Handler: &testServerHandler{
|
||||||
@@ -1018,6 +1030,9 @@ func TestServerSessionTeardown(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
|
stream = NewServerStream(s, media.Medias{testH264Media})
|
||||||
|
defer stream.Close()
|
||||||
|
|
||||||
nconn, err := net.Dial("tcp", "localhost:8554")
|
nconn, err := net.Dial("tcp", "localhost:8554")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
defer nconn.Close()
|
defer nconn.Close()
|
||||||
|
Reference in New Issue
Block a user