2021-08-12 09:48:47 +00:00
|
|
|
package core
|
|
|
|
|
|
|
|
import (
|
2022-11-11 10:59:52 +00:00
|
|
|
"crypto/tls"
|
2022-11-02 17:25:49 +00:00
|
|
|
"net"
|
2023-05-18 17:16:07 +00:00
|
|
|
"net/http"
|
2022-11-02 17:25:49 +00:00
|
|
|
"net/url"
|
2021-08-12 09:48:47 +00:00
|
|
|
"os"
|
|
|
|
"testing"
|
2023-05-18 18:05:35 +00:00
|
|
|
"time"
|
2021-08-12 09:48:47 +00:00
|
|
|
|
2023-08-26 16:54:28 +00:00
|
|
|
"github.com/bluenviron/gortsplib/v4"
|
|
|
|
"github.com/bluenviron/gortsplib/v4/pkg/description"
|
|
|
|
"github.com/bluenviron/gortsplib/v4/pkg/format"
|
2021-08-12 09:48:47 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
2022-11-02 17:25:49 +00:00
|
|
|
|
2023-05-16 14:14:20 +00:00
|
|
|
"github.com/bluenviron/mediamtx/internal/rtmp"
|
2021-08-12 09:48:47 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestMetrics(t *testing.T) {
|
|
|
|
serverCertFpath, err := writeTempFile(serverCert)
|
|
|
|
require.NoError(t, err)
|
|
|
|
defer os.Remove(serverCertFpath)
|
|
|
|
|
|
|
|
serverKeyFpath, err := writeTempFile(serverKey)
|
|
|
|
require.NoError(t, err)
|
|
|
|
defer os.Remove(serverKeyFpath)
|
|
|
|
|
2023-04-13 16:15:13 +00:00
|
|
|
p, ok := newInstance("hlsAlwaysRemux: yes\n" +
|
|
|
|
"metrics: yes\n" +
|
2022-12-15 23:50:47 +00:00
|
|
|
"webrtcServerCert: " + serverCertFpath + "\n" +
|
|
|
|
"webrtcServerKey: " + serverKeyFpath + "\n" +
|
2021-08-12 09:48:47 +00:00
|
|
|
"encryption: optional\n" +
|
|
|
|
"serverCert: " + serverCertFpath + "\n" +
|
2021-11-06 11:51:38 +00:00
|
|
|
"serverKey: " + serverKeyFpath + "\n" +
|
|
|
|
"paths:\n" +
|
|
|
|
" all:\n")
|
2021-08-12 09:48:47 +00:00
|
|
|
require.Equal(t, true, ok)
|
2022-11-02 17:25:49 +00:00
|
|
|
defer p.Close()
|
2021-08-12 09:48:47 +00:00
|
|
|
|
2023-05-18 17:16:07 +00:00
|
|
|
hc := &http.Client{Transport: &http.Transport{}}
|
|
|
|
|
|
|
|
bo := httpPullFile(t, hc, "http://localhost:9998/metrics")
|
2023-04-11 18:47:29 +00:00
|
|
|
|
|
|
|
require.Equal(t, `paths 0
|
|
|
|
hls_muxers 0
|
|
|
|
hls_muxers_bytes_sent 0
|
|
|
|
rtsp_conns 0
|
|
|
|
rtsp_conns_bytes_received 0
|
|
|
|
rtsp_conns_bytes_sent 0
|
|
|
|
rtsp_sessions 0
|
|
|
|
rtsp_sessions_bytes_received 0
|
|
|
|
rtsp_sessions_bytes_sent 0
|
|
|
|
rtsps_conns 0
|
|
|
|
rtsps_conns_bytes_received 0
|
|
|
|
rtsps_conns_bytes_sent 0
|
|
|
|
rtsps_sessions 0
|
|
|
|
rtsps_sessions_bytes_received 0
|
|
|
|
rtsps_sessions_bytes_sent 0
|
|
|
|
rtmp_conns 0
|
|
|
|
rtmp_conns_bytes_received 0
|
|
|
|
rtmp_conns_bytes_sent 0
|
2023-05-16 13:59:37 +00:00
|
|
|
webrtc_sessions 0
|
|
|
|
webrtc_sessions_bytes_received 0
|
|
|
|
webrtc_sessions_bytes_sent 0
|
2023-04-11 18:47:29 +00:00
|
|
|
`, string(bo))
|
|
|
|
|
2022-12-13 19:54:17 +00:00
|
|
|
medi := testMediaH264
|
2021-08-12 09:48:47 +00:00
|
|
|
|
2021-11-12 21:29:56 +00:00
|
|
|
source := gortsplib.Client{}
|
2022-12-13 19:54:17 +00:00
|
|
|
err = source.StartRecording("rtsp://localhost:8554/rtsp_path",
|
2023-08-26 16:54:28 +00:00
|
|
|
&description.Session{Medias: []*description.Media{medi}})
|
2021-08-12 09:48:47 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
defer source.Close()
|
|
|
|
|
2022-11-11 10:59:52 +00:00
|
|
|
source2 := gortsplib.Client{TLSConfig: &tls.Config{InsecureSkipVerify: true}}
|
2022-12-13 19:54:17 +00:00
|
|
|
err = source2.StartRecording("rtsps://localhost:8322/rtsps_path",
|
2023-08-26 16:54:28 +00:00
|
|
|
&description.Session{Medias: []*description.Media{medi}})
|
2022-11-11 10:59:52 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
defer source2.Close()
|
|
|
|
|
2022-11-02 17:25:49 +00:00
|
|
|
u, err := url.Parse("rtmp://localhost:1935/rtmp_path")
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
nconn, err := net.Dial("tcp", u.Host)
|
|
|
|
require.NoError(t, err)
|
|
|
|
defer nconn.Close()
|
|
|
|
|
2023-07-31 17:41:59 +00:00
|
|
|
conn, err := rtmp.NewClientConn(nconn, u, true)
|
2022-11-02 17:25:49 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2023-08-26 16:54:28 +00:00
|
|
|
videoTrack := &format.H264{
|
2022-12-13 19:54:17 +00:00
|
|
|
PayloadTyp: 96,
|
2022-11-02 17:25:49 +00:00
|
|
|
SPS: []byte{ // 1920x1080 baseline
|
|
|
|
0x67, 0x42, 0xc0, 0x28, 0xd9, 0x00, 0x78, 0x02,
|
|
|
|
0x27, 0xe5, 0x84, 0x00, 0x00, 0x03, 0x00, 0x04,
|
|
|
|
0x00, 0x00, 0x03, 0x00, 0xf0, 0x3c, 0x60, 0xc9, 0x20,
|
|
|
|
},
|
2022-11-15 22:46:40 +00:00
|
|
|
PPS: []byte{0x08, 0x06, 0x07, 0x08},
|
|
|
|
PacketizationMode: 1,
|
2022-11-02 17:25:49 +00:00
|
|
|
}
|
|
|
|
|
2023-07-30 21:15:22 +00:00
|
|
|
_, err = rtmp.NewWriter(conn, videoTrack, nil)
|
2021-08-12 09:48:47 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2023-05-18 18:05:35 +00:00
|
|
|
time.Sleep(500 * time.Millisecond)
|
|
|
|
|
2023-05-18 17:16:07 +00:00
|
|
|
bo = httpPullFile(t, hc, "http://localhost:9998/metrics")
|
2021-08-12 09:48:47 +00:00
|
|
|
|
2022-11-11 10:59:52 +00:00
|
|
|
require.Regexp(t,
|
|
|
|
`^paths\{name=".*?",state="ready"\} 1`+"\n"+
|
|
|
|
`paths_bytes_received\{name=".*?",state="ready"\} 0`+"\n"+
|
|
|
|
`paths\{name=".*?",state="ready"\} 1`+"\n"+
|
|
|
|
`paths_bytes_received\{name=".*?",state="ready"\} 0`+"\n"+
|
|
|
|
`paths\{name=".*?",state="ready"\} 1`+"\n"+
|
|
|
|
`paths_bytes_received\{name=".*?",state="ready"\} 0`+"\n"+
|
2023-04-13 16:15:13 +00:00
|
|
|
`hls_muxers\{name=".*?"\} 1`+"\n"+
|
|
|
|
`hls_muxers_bytes_sent\{name=".*?"\} [0-9]+`+"\n"+
|
|
|
|
`hls_muxers\{name=".*?"\} 1`+"\n"+
|
|
|
|
`hls_muxers_bytes_sent\{name=".*?"\} [0-9]+`+"\n"+
|
|
|
|
`hls_muxers\{name=".*?"\} 1`+"\n"+
|
|
|
|
`hls_muxers_bytes_sent\{name=".*?"\} [0-9]+`+"\n"+
|
2022-11-11 10:59:52 +00:00
|
|
|
`rtsp_conns\{id=".*?"\} 1`+"\n"+
|
|
|
|
`rtsp_conns_bytes_received\{id=".*?"\} [0-9]+`+"\n"+
|
|
|
|
`rtsp_conns_bytes_sent\{id=".*?"\} [0-9]+`+"\n"+
|
|
|
|
`rtsp_sessions\{id=".*?",state="publish"\} 1`+"\n"+
|
|
|
|
`rtsp_sessions_bytes_received\{id=".*?",state="publish"\} 0`+"\n"+
|
|
|
|
`rtsp_sessions_bytes_sent\{id=".*?",state="publish"\} [0-9]+`+"\n"+
|
|
|
|
`rtsps_conns\{id=".*?"\} 1`+"\n"+
|
|
|
|
`rtsps_conns_bytes_received\{id=".*?"\} [0-9]+`+"\n"+
|
|
|
|
`rtsps_conns_bytes_sent\{id=".*?"\} [0-9]+`+"\n"+
|
|
|
|
`rtsps_sessions\{id=".*?",state="publish"\} 1`+"\n"+
|
|
|
|
`rtsps_sessions_bytes_received\{id=".*?",state="publish"\} 0`+"\n"+
|
|
|
|
`rtsps_sessions_bytes_sent\{id=".*?",state="publish"\} [0-9]+`+"\n"+
|
|
|
|
`rtmp_conns\{id=".*?",state="publish"\} 1`+"\n"+
|
|
|
|
`rtmp_conns_bytes_received\{id=".*?",state="publish"\} [0-9]+`+"\n"+
|
|
|
|
`rtmp_conns_bytes_sent\{id=".*?",state="publish"\} [0-9]+`+"\n"+
|
2023-05-16 13:59:37 +00:00
|
|
|
`webrtc_sessions 0`+"\n"+
|
|
|
|
`webrtc_sessions_bytes_received 0`+"\n"+
|
|
|
|
`webrtc_sessions_bytes_sent 0`+"\n"+
|
2022-12-15 23:50:47 +00:00
|
|
|
"$",
|
2022-11-11 10:59:52 +00:00
|
|
|
string(bo))
|
2021-08-12 09:48:47 +00:00
|
|
|
}
|