#!/usr/bin/perl use strict; use warnings; use NGCP::Rtpengine::Test; use NGCP::Rtpclient::SRTP; use NGCP::Rtpengine::AutoTest; use Test::More; use NGCP::Rtpclient::ICE; use POSIX; use Data::Dumper; autotest_start(qw(--config-file=none -t -1 -i 203.0.113.1 -i 2001:db8:4321::1 --measure-rtp --mos=LQ -n 2223 -c 12345 -f -L 7 -E -u 2222 --silence-detect=1 --log-level-internals=7)) or die; my $extended_tests = $ENV{RTPENGINE_MOS_TESTS}; my ($sock_a, $sock_b, $sock_c, $sock_d, $port_a, $port_b, $ssrc, $ssrc_b, $resp, $sock_ax, $sock_bx, $port_ax, $port_bx, $srtp_ctx_a, $srtp_ctx_b, $srtp_ctx_a_rev, $srtp_ctx_b_rev, $ufrag_a, $ufrag_b, @ret1, @ret2, @ret3, @ret4, $srtp_key_a, $srtp_key_b, $ts, $seq, $has_recv); ($sock_a, $sock_ax, $sock_b, $sock_bx) = new_call( [qw(198.51.100.1 7160)], [qw(198.51.100.1 7161)], [qw(198.51.100.3 7162)], [qw(198.51.100.3 7163)], ); ($port_a, $port_ax) = offer('stats delete w/o from-tag and w/o delete-delay', { }, < 0 } ); #print Dumper($resp); #print Dumper($resp->{SSRC}); is($resp->{SSRC}{0x1234}{bytes}, 172, "0x1234 byte count"); is($resp->{SSRC}{0x1234}{'highest MOS'}{MOS}, '43', "0x1234 MOS"); is($resp->{SSRC}{0x6543}{bytes}, 172, "0x6543 byte count"); is($resp->{SSRC}{0x6543}{'highest MOS'}{MOS}, '43', "0x6543 MOS"); #print Dumper($resp->{tags}{ft()}{medias}[0]{'egress SSRCs'}); is($resp->{tags}{ft()}{medias}[0]{'egress SSRCs'}[0]{SSRC}, 0x6543, 'egress SSRC'); #print Dumper($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}); is($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}[0]{SSRC}, 0x1234, 'ingress SSRC'); is($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}[0]{'highest MOS'}{MOS}, '43', 'ingress SSRC MOS'); #print Dumper($resp->{tags}{ft()}{medias}[0]{streams}[0]{SSRC}); #print Dumper($resp->{tags}{tt()}{medias}[0]{'egress SSRCs'}); is($resp->{tags}{tt()}{medias}[0]{'egress SSRCs'}[0]{SSRC}, 0x1234, 'egress SSRC'); #print Dumper($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}); #print Dumper($resp->{tags}{tt()}{medias}[0]{streams}[0]{SSRC}); is($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}[0]{SSRC}, 0x6543, 'ingress SSRC'); is($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}[0]{'highest MOS'}{MOS}, '43', 'ingress SSRC MOS'); is($resp->{totals}{RTP}{packets}, 2, 'RTP packet count'); is($resp->{totals}{RTP}{bytes}, 344, 'RTP octet count'); is($resp->{totals}{RTCP}{packets}, 2, 'RTCP packet count'); is($resp->{totals}{RTCP}{bytes}, 104, 'RTCP octet count'); ($sock_a, $sock_ax, $sock_b, $sock_bx) = new_call( [qw(198.51.100.1 7164)], [qw(198.51.100.1 7165)], [qw(198.51.100.3 7166)], [qw(198.51.100.3 7167)], ); ($port_a, $port_ax) = offer('stats delete w/ from-tag and w/o delete-delay', { }, < 0, 'from-tag' => ft() } ); #print Dumper($resp); #print Dumper($resp->{SSRC}); is($resp->{SSRC}{0x1234}{bytes}, 172, "0x1234 byte count"); is($resp->{SSRC}{0x1234}{'highest MOS'}{MOS}, '43', "0x1234 MOS"); is($resp->{SSRC}{0x6543}{bytes}, 172, "0x6543 byte count"); is($resp->{SSRC}{0x6543}{'highest MOS'}{MOS}, '43', "0x6543 MOS"); #print Dumper($resp->{tags}{ft()}{medias}[0]{'egress SSRCs'}); is($resp->{tags}{ft()}{medias}[0]{'egress SSRCs'}[0]{SSRC}, 0x6543, 'egress SSRC'); #print Dumper($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}); is($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}[0]{SSRC}, 0x1234, 'ingress SSRC'); is($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}[0]{'highest MOS'}{MOS}, '43', 'ingress SSRC MOS'); #print Dumper($resp->{tags}{ft()}{medias}[0]{streams}[0]{SSRC}); #print Dumper($resp->{tags}{tt()}{medias}[0]{'egress SSRCs'}); is($resp->{tags}{tt()}{medias}[0]{'egress SSRCs'}[0]{SSRC}, 0x1234, 'egress SSRC'); #print Dumper($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}); #print Dumper($resp->{tags}{tt()}{medias}[0]{streams}[0]{SSRC}); is($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}[0]{SSRC}, 0x6543, 'ingress SSRC'); is($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}[0]{'highest MOS'}{MOS}, '43', 'ingress SSRC MOS'); is($resp->{totals}{RTP}{packets}, 2, 'RTP packet count'); is($resp->{totals}{RTP}{bytes}, 344, 'RTP octet count'); is($resp->{totals}{RTCP}{packets}, 2, 'RTCP packet count'); is($resp->{totals}{RTCP}{bytes}, 104, 'RTCP octet count'); ($sock_a, $sock_ax, $sock_b, $sock_bx) = new_call( [qw(198.51.100.1 7168)], [qw(198.51.100.1 7169)], [qw(198.51.100.3 7170)], [qw(198.51.100.3 7171)], ); ($port_a, $port_ax) = offer('stats delete w/o from-tag and w/ delete-delay', { }, < 1 } ); #print Dumper($resp); #print Dumper($resp->{SSRC}); is($resp->{SSRC}{0x1234}{bytes}, 172, "0x1234 byte count"); is($resp->{SSRC}{0x1234}{'highest MOS'}{MOS}, '43', "0x1234 MOS"); is($resp->{SSRC}{0x6543}{bytes}, 172, "0x6543 byte count"); is($resp->{SSRC}{0x6543}{'highest MOS'}{MOS}, '43', "0x6543 MOS"); #print Dumper($resp->{tags}{ft()}{medias}[0]{'egress SSRCs'}); is($resp->{tags}{ft()}{medias}[0]{'egress SSRCs'}[0]{SSRC}, 0x6543, 'egress SSRC'); #print Dumper($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}); is($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}[0]{SSRC}, 0x1234, 'ingress SSRC'); is($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}[0]{'highest MOS'}{MOS}, '43', 'ingress SSRC MOS'); #print Dumper($resp->{tags}{ft()}{medias}[0]{streams}[0]{SSRC}); #print Dumper($resp->{tags}{tt()}{medias}[0]{'egress SSRCs'}); is($resp->{tags}{tt()}{medias}[0]{'egress SSRCs'}[0]{SSRC}, 0x1234, 'egress SSRC'); #print Dumper($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}); #print Dumper($resp->{tags}{tt()}{medias}[0]{streams}[0]{SSRC}); is($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}[0]{SSRC}, 0x6543, 'ingress SSRC'); is($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}[0]{'highest MOS'}{MOS}, '43', 'ingress SSRC MOS'); is($resp->{totals}{RTP}{packets}, 2, 'RTP packet count'); is($resp->{totals}{RTP}{bytes}, 344, 'RTP octet count'); is($resp->{totals}{RTCP}{packets}, 2, 'RTCP packet count'); is($resp->{totals}{RTCP}{bytes}, 104, 'RTCP octet count'); ($sock_a, $sock_ax, $sock_b, $sock_bx) = new_call( [qw(198.51.100.1 7172)], [qw(198.51.100.1 7173)], [qw(198.51.100.3 7174)], [qw(198.51.100.3 7175)], ); ($port_a, $port_ax) = offer('stats delete w/ from-tag and w/ delete-delay', { }, < 1, 'from-tag' => ft() } ); #print Dumper($resp); #print Dumper($resp->{SSRC}); is($resp->{SSRC}{0x1234}{bytes}, 172, "0x1234 byte count"); is($resp->{SSRC}{0x1234}{'highest MOS'}{MOS}, '43', "0x1234 MOS"); is($resp->{SSRC}{0x6543}{bytes}, 172, "0x6543 byte count"); is($resp->{SSRC}{0x6543}{'highest MOS'}{MOS}, '43', "0x6543 MOS"); #print Dumper($resp->{tags}{ft()}{medias}[0]{'egress SSRCs'}); is($resp->{tags}{ft()}{medias}[0]{'egress SSRCs'}[0]{SSRC}, 0x6543, 'egress SSRC'); #print Dumper($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}); is($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}[0]{SSRC}, 0x1234, 'ingress SSRC'); is($resp->{tags}{ft()}{medias}[0]{'ingress SSRCs'}[0]{'highest MOS'}{MOS}, '43', 'ingress SSRC MOS'); #print Dumper($resp->{tags}{ft()}{medias}[0]{streams}[0]{SSRC}); #print Dumper($resp->{tags}{tt()}{medias}[0]{'egress SSRCs'}); is($resp->{tags}{tt()}{medias}[0]{'egress SSRCs'}[0]{SSRC}, 0x1234, 'egress SSRC'); #print Dumper($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}); #print Dumper($resp->{tags}{tt()}{medias}[0]{streams}[0]{SSRC}); is($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}[0]{SSRC}, 0x6543, 'ingress SSRC'); is($resp->{tags}{tt()}{medias}[0]{'ingress SSRCs'}[0]{'highest MOS'}{MOS}, '43', 'ingress SSRC MOS'); is($resp->{totals}{RTP}{packets}, 2, 'RTP packet count'); is($resp->{totals}{RTP}{bytes}, 344, 'RTP octet count'); is($resp->{totals}{RTCP}{packets}, 2, 'RTCP packet count'); is($resp->{totals}{RTCP}{bytes}, 104, 'RTCP octet count'); if ($extended_tests) { ($sock_a, $sock_ax, $sock_b, $sock_bx) = new_call([qw(198.51.100.23 3000)], [qw(198.51.100.23 3001)], [qw(198.51.100.23 3002)], [qw(198.51.100.23 3003)]); ($port_a, $port_ax) = offer('MOS basic', { flags => ['generate RTCP'] }, < ['generate RTCP'] }, <{SSRC}{0x1234567}{'average MOS'}{samples}, '>=', 1, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{samples}, '<=', 3, 'metric matches'; is $resp->{SSRC}{0x1234567}{'average MOS'}{MOS}, 43, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{jitter}, '>=', 0, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{jitter}, '<=', 1, 'metric matches'; is $resp->{SSRC}{0x1234567}{'average MOS'}{'packet loss'}, 0, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{samples}, '>=', 1, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{samples}, '<=', 3, 'metric matches'; is $resp->{SSRC}{0x7654321}{'average MOS'}{MOS}, 43, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{jitter}, '>=', 0, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{jitter}, '<=', 1, 'metric matches'; is $resp->{SSRC}{0x7654321}{'average MOS'}{'packet loss'}, 0, 'metric matches'; ($sock_a, $sock_ax, $sock_b, $sock_bx) = new_call([qw(198.51.100.23 3004)], [qw(198.51.100.23 3005)], [qw(198.51.100.23 3006)], [qw(198.51.100.23 3007)]); ($port_a, $port_ax) = offer('MOS PL', { flags => ['generate RTCP'] }, < ['generate RTCP'] }, <{SSRC}{0x1234567}{'average MOS'}{samples}, '>=', 1, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{samples}, '<=', 3, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{MOS}, '>=', 35, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{MOS}, '<=', 36, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{jitter}, '>=', 0, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{jitter}, '<=', 1, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{'packet loss'}, '>=', 3, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{'packet loss'}, '<=', 4, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{samples}, '>=', 1, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{samples}, '<=', 3, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{MOS}, '>=', 35, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{MOS}, '<=', 36, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{jitter}, '>=', 0, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{jitter}, '<=', 1, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{'packet loss'}, '>=', 3, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{'packet loss'}, '<=', 4, 'metric matches'; ($sock_a, $sock_ax, $sock_b, $sock_bx) = new_call([qw(198.51.100.23 3008)], [qw(198.51.100.23 3009)], [qw(198.51.100.23 3010)], [qw(198.51.100.23 3011)]); ($port_a, $port_ax) = offer('MOS very degraded', { flags => ['generate RTCP'] }, < ['generate RTCP'] }, <{SSRC}{0x1234567}{'average MOS'}{samples}, '>=', 1, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{samples}, '<=', 4, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{MOS}, '>=', 27, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{MOS}, '<=', 28, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{jitter}, '>=', 4, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{jitter}, '<=', 12, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{'packet loss'}, '>=', 8, 'metric matches'; cmp_ok $resp->{SSRC}{0x1234567}{'average MOS'}{'packet loss'}, '<=', 9, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{samples}, '>=', 1, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{samples}, '<=', 4, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{MOS}, '>=', 27, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{MOS}, '<=', 28, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{jitter}, '>=', 4, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{jitter}, '<=', 12, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{'packet loss'}, '>=', 8, 'metric matches'; cmp_ok $resp->{SSRC}{0x7654321}{'average MOS'}{'packet loss'}, '<=', 9, 'metric matches'; } #done_testing;NGCP::Rtpengine::AutoTest::terminate('f00');exit; done_testing();