add *Server argument to NewServerStream()

This commit is contained in:
aler9
2023-08-12 20:19:29 +02:00
parent ca87733ded
commit 68d4bf8da0
10 changed files with 191 additions and 156 deletions

View File

@@ -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

View File

@@ -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()
} }

View File

@@ -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
}

View File

@@ -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{

View File

@@ -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{

View File

@@ -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{

View File

@@ -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()

View File

@@ -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{

View File

@@ -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

View File

@@ -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()