mirror of
https://github.com/aler9/gortsplib
synced 2025-10-05 07:06:58 +08:00
server: correctly close sessions in case of errors during SETUP
(https://github.com/aler9/rtsp-simple-server/issues/965)
This commit is contained in:
@@ -721,6 +721,10 @@ func TestServerSessionClose(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestServerSessionAutoClose(t *testing.T) {
|
func TestServerSessionAutoClose(t *testing.T) {
|
||||||
|
for _, ca := range []string{
|
||||||
|
"200", "400",
|
||||||
|
} {
|
||||||
|
t.Run(ca, func(t *testing.T) {
|
||||||
sessionClosed := make(chan struct{})
|
sessionClosed := make(chan struct{})
|
||||||
|
|
||||||
track, err := NewTrackH264(96, []byte{0x01, 0x02, 0x03, 0x04}, []byte{0x01, 0x02, 0x03, 0x04}, nil)
|
track, err := NewTrackH264(96, []byte{0x01, 0x02, 0x03, 0x04}, []byte{0x01, 0x02, 0x03, 0x04}, nil)
|
||||||
@@ -735,9 +739,15 @@ func TestServerSessionAutoClose(t *testing.T) {
|
|||||||
close(sessionClosed)
|
close(sessionClosed)
|
||||||
},
|
},
|
||||||
onSetup: func(ctx *ServerHandlerOnSetupCtx) (*base.Response, *ServerStream, error) {
|
onSetup: func(ctx *ServerHandlerOnSetupCtx) (*base.Response, *ServerStream, error) {
|
||||||
|
if ca == "200" {
|
||||||
return &base.Response{
|
return &base.Response{
|
||||||
StatusCode: base.StatusOK,
|
StatusCode: base.StatusOK,
|
||||||
}, stream, nil
|
}, stream, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return &base.Response{
|
||||||
|
StatusCode: base.StatusBadRequest,
|
||||||
|
}, nil, fmt.Errorf("error")
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
RTSPAddress: "localhost:8554",
|
RTSPAddress: "localhost:8554",
|
||||||
@@ -751,7 +761,7 @@ func TestServerSessionAutoClose(t *testing.T) {
|
|||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
br := bufio.NewReader(conn)
|
br := bufio.NewReader(conn)
|
||||||
|
|
||||||
res, err := writeReqReadRes(conn, br, base.Request{
|
_, err = writeReqReadRes(conn, br, base.Request{
|
||||||
Method: base.Setup,
|
Method: base.Setup,
|
||||||
URL: mustParseURL("rtsp://localhost:8554/teststream/trackID=0"),
|
URL: mustParseURL("rtsp://localhost:8554/teststream/trackID=0"),
|
||||||
Header: base.Header{
|
Header: base.Header{
|
||||||
@@ -771,11 +781,12 @@ func TestServerSessionAutoClose(t *testing.T) {
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, base.StatusOK, res.StatusCode)
|
|
||||||
|
|
||||||
conn.Close()
|
conn.Close()
|
||||||
|
|
||||||
<-sessionClosed
|
<-sessionClosed
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestServerErrorInvalidPath(t *testing.T) {
|
func TestServerErrorInvalidPath(t *testing.T) {
|
||||||
|
@@ -337,7 +337,8 @@ func (ss *ServerSession) runInner() error {
|
|||||||
|
|
||||||
res, err := ss.handleRequest(req.sc, req.req)
|
res, err := ss.handleRequest(req.sc, req.req)
|
||||||
|
|
||||||
var returnedSession *ServerSession
|
returnedSession := ss
|
||||||
|
|
||||||
if err == nil || err == errSwitchReadFunc {
|
if err == nil || err == errSwitchReadFunc {
|
||||||
// ANNOUNCE responses don't contain the session header.
|
// ANNOUNCE responses don't contain the session header.
|
||||||
if req.req.Method != base.Announce &&
|
if req.req.Method != base.Announce &&
|
||||||
@@ -364,9 +365,9 @@ func (ss *ServerSession) runInner() error {
|
|||||||
}.Write()
|
}.Write()
|
||||||
}
|
}
|
||||||
|
|
||||||
// after a TEARDOWN, session must be unpaired with the connection.
|
// after a TEARDOWN, session must be unpaired with the connection
|
||||||
if req.req.Method != base.Teardown {
|
if req.req.Method == base.Teardown {
|
||||||
returnedSession = ss
|
returnedSession = nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user