From 6921472e3bd8a7f5ca43193e78e07b053ceac239 Mon Sep 17 00:00:00 2001 From: Richard Fuchs Date: Fri, 8 Mar 2019 16:24:32 -0500 Subject: [PATCH] TT#54800 add ptime tests Change-Id: Ia8423bf560d6a563b5a3f6ba77edf11a726b2766 --- t/auto-daemon-tests.pl | 404 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 404 insertions(+) diff --git a/t/auto-daemon-tests.pl b/t/auto-daemon-tests.pl index 634b1c65d..bccce7c5e 100755 --- a/t/auto-daemon-tests.pl +++ b/t/auto-daemon-tests.pl @@ -1636,6 +1636,410 @@ srtp_rcv($sock_a, -1, rtpm(8, $seq + 4, $ts + 160 * 4, $ssrc, $pcma_5), $srtp_ct + + +# ptime tests + +($sock_a, $sock_b) = new_call([qw(198.51.100.1 3000)], [qw(198.51.100.3 3002)]); + +($port_a) = offer('default ptime in/out', { ICE => 'remove', replace => ['origin'] }, < 'remove', replace => ['origin'] }, < 'remove', replace => ['origin'] }, < 'remove', replace => ['origin'] }, < 'remove', replace => ['origin'], ptime => 30 }, < 'remove', replace => ['origin'] }, <B: 5x 20 ms packets -> 3x 30 ms +snd($sock_a, $port_b, rtp(0, 1000, 3000, 0x1234, "\00" x 160)); +Time::HiRes::usleep(20000); # 20 ms, needed to ensure that packet 1000 is received first +snd($sock_a, $port_b, rtp(0, 1001, 3160, 0x1234, "\00" x 160)); +($ssrc) = rcv($sock_b, $port_a, rtpm(0, 1000, 3000, -1, "\00" x 240)); +snd($sock_a, $port_b, rtp(0, 1002, 3320, 0x1234, "\00" x 160)); +rcv($sock_b, $port_a, rtpm(0, 1001, 3240, $ssrc, "\00" x 240)); +snd($sock_a, $port_b, rtp(0, 1003, 3480, 0x1234, "\00" x 160)); +snd($sock_a, $port_b, rtp(0, 1004, 3640, 0x1234, "\00" x 160)); +rcv($sock_b, $port_a, rtpm(0, 1002, 3480, $ssrc, "\00" x 240)); + +# A->B: 60 ms packet -> 2x 30 ms +# also perform TS and seq reset +snd($sock_a, $port_b, rtp(0, 8000, 500000, 0x1234, "\00" x 480)); +rcv($sock_b, $port_a, rtpm(0, 1003, 3720, $ssrc, "\00" x 240)); +rcv($sock_b, $port_a, rtpm(0, 1004, 3960, $ssrc, "\00" x 240)); + +# B->A: 2x 60 ms packet -> 6x 20 ms +snd($sock_b, $port_a, rtp(0, 4000, 5000, 0x4567, "\x88" x 480)); +($ssrc) = rcv($sock_a, $port_b, rtpm(0, 4000, 5000, -1, "\x88" x 160)); +rcv($sock_a, $port_b, rtpm(0, 4001, 5160, $ssrc, "\x88" x 160)); +rcv($sock_a, $port_b, rtpm(0, 4002, 5320, $ssrc, "\x88" x 160)); +snd($sock_b, $port_a, rtp(0, 4001, 5480, 0x4567, "\x88" x 480)); +rcv($sock_a, $port_b, rtpm(0, 4003, 5480, $ssrc, "\x88" x 160)); +rcv($sock_a, $port_b, rtpm(0, 4004, 5640, $ssrc, "\x88" x 160)); +rcv($sock_a, $port_b, rtpm(0, 4005, 5800, $ssrc, "\x88" x 160)); + +# B->A: 4x 10 ms packet -> 2x 20 ms +# out of order packet input +snd($sock_b, $port_a, rtp(0, 4003, 6040, 0x4567, "\x88" x 80)); +Time::HiRes::usleep(10000); +snd($sock_b, $port_a, rtp(0, 4002, 5960, 0x4567, "\x88" x 80)); +rcv($sock_a, $port_b, rtpm(0, 4006, 5960, $ssrc, "\x88" x 160)); +snd($sock_b, $port_a, rtp(0, 4004, 6120, 0x4567, "\x88" x 80)); +snd($sock_b, $port_a, rtp(0, 4005, 6200, 0x4567, "\x88" x 80)); +rcv($sock_a, $port_b, rtpm(0, 4007, 6120, $ssrc, "\x88" x 160)); + + + + +($sock_a, $sock_b) = new_call([qw(198.51.100.1 3008)], [qw(198.51.100.3 3010)]); + +($port_a) = offer('default ptime in, no change, ptime=30 response', { + ICE => 'remove', replace => ['origin'] }, < 'remove', replace => ['origin'] }, <B: 20 ms unchanged +snd($sock_a, $port_b, rtp(0, 1000, 3000, 0x1234, "\00" x 160)); +($ssrc) = rcv($sock_b, $port_a, rtpm(0, 1000, 3000, -1, "\00" x 160)); +# A->B: 30 ms unchanged +snd($sock_a, $port_b, rtp(0, 1001, 3160, 0x1234, "\00" x 240)); +rcv($sock_b, $port_a, rtpm(0, 1001, 3160, $ssrc, "\00" x 240)); + +# B->A: 20 ms unchanged +snd($sock_b, $port_a, rtp(0, 4000, 5000, 0x4567, "\x88" x 160)); +($ssrc) = rcv($sock_a, $port_b, rtpm(0, 4000, 5000, -1, "\x88" x 160)); +# B->A: 30 ms unchanged +snd($sock_b, $port_a, rtp(0, 4001, 5160, 0x4567, "\x88" x 240)); +rcv($sock_a, $port_b, rtpm(0, 4001, 5160, $ssrc, "\x88" x 240)); + + + +($sock_a, $sock_b) = new_call([qw(198.51.100.1 3012)], [qw(198.51.100.3 3014)]); + +($port_a) = offer('ptime=50 in, change to 30, default response', { + ICE => 'remove', replace => ['origin'], ptime => 30 }, < 'remove', replace => ['origin'] }, <B: 2x 50 ms -> 3x 30 ms (plus 10 ms left) +snd($sock_a, $port_b, rtp(0, 1000, 3000, 0x1234, "\00" x 400)); +($ssrc) = rcv($sock_b, $port_a, rtpm(0, 1000, 3000, -1, "\00" x 240)); +snd($sock_a, $port_b, rtp(0, 1001, 3400, 0x1234, "\00" x 400)); +rcv($sock_b, $port_a, rtpm(0, 1001, 3240, $ssrc, "\00" x 240)); +rcv($sock_b, $port_a, rtpm(0, 1002, 3480, $ssrc, "\00" x 240)); +# A->B: add another 20 ms for another full 30 ms +snd($sock_a, $port_b, rtp(0, 1002, 3800, 0x1234, "\00" x 160)); +rcv($sock_b, $port_a, rtpm(0, 1003, 3720, $ssrc, "\00" x 240)); + +# B->A: 4x 30 ms -> 2x 50 ms (plus 20 ms left) +snd($sock_b, $port_a, rtp(0, 4000, 5000, 0x4567, "\x88" x 240)); +Time::HiRes::usleep(20000); # 20 ms, needed to ensure that packet 1000 is received first +snd($sock_b, $port_a, rtp(0, 4001, 5240, 0x4567, "\x88" x 240)); +($ssrc) = rcv($sock_a, $port_b, rtpm(0, 4000, 5000, -1, "\x88" x 400)); +snd($sock_b, $port_a, rtp(0, 4002, 5480, 0x4567, "\x88" x 240)); +snd($sock_b, $port_a, rtp(0, 4003, 5720, 0x4567, "\x88" x 240)); +rcv($sock_a, $port_b, rtpm(0, 4001, 5400, $ssrc, "\x88" x 400)); +# B->A: add another 30 ms for another full 50 ms +snd($sock_b, $port_a, rtp(0, 4004, 5960, 0x4567, "\x88" x 240)); +rcv($sock_a, $port_b, rtpm(0, 4002, 5800, $ssrc, "\x88" x 400)); + + + + +($sock_a, $sock_b) = new_call([qw(198.51.100.1 3016)], [qw(198.51.100.3 3018)]); + +($port_a) = offer('ptime=50 in, change to 30, response 30, change to 50', { + ICE => 'remove', replace => ['origin'], ptime => 30 }, < 'remove', replace => ['origin'], ptime => 50 }, <B: 2x 50 ms -> 3x 30 ms (plus 10 ms left) +snd($sock_a, $port_b, rtp(0, 1000, 3000, 0x1234, "\00" x 400)); +($ssrc) = rcv($sock_b, $port_a, rtpm(0, 1000, 3000, -1, "\00" x 240)); +snd($sock_a, $port_b, rtp(0, 1001, 3400, 0x1234, "\00" x 400)); +rcv($sock_b, $port_a, rtpm(0, 1001, 3240, $ssrc, "\00" x 240)); +rcv($sock_b, $port_a, rtpm(0, 1002, 3480, $ssrc, "\00" x 240)); +# A->B: add another 20 ms for another full 30 ms +snd($sock_a, $port_b, rtp(0, 1002, 3800, 0x1234, "\00" x 160)); +rcv($sock_b, $port_a, rtpm(0, 1003, 3720, $ssrc, "\00" x 240)); + +# B->A: 4x 30 ms -> 2x 50 ms (plus 20 ms left) +snd($sock_b, $port_a, rtp(0, 4000, 5000, 0x4567, "\x88" x 240)); +Time::HiRes::usleep(20000); # 20 ms, needed to ensure that packet 1000 is received first +snd($sock_b, $port_a, rtp(0, 4001, 5240, 0x4567, "\x88" x 240)); +($ssrc) = rcv($sock_a, $port_b, rtpm(0, 4000, 5000, -1, "\x88" x 400)); +snd($sock_b, $port_a, rtp(0, 4002, 5480, 0x4567, "\x88" x 240)); +snd($sock_b, $port_a, rtp(0, 4003, 5720, 0x4567, "\x88" x 240)); +rcv($sock_a, $port_b, rtpm(0, 4001, 5400, $ssrc, "\x88" x 400)); +# B->A: add another 30 ms for another full 50 ms +snd($sock_b, $port_a, rtp(0, 4004, 5960, 0x4567, "\x88" x 240)); +rcv($sock_a, $port_b, rtpm(0, 4002, 5800, $ssrc, "\x88" x 400)); + + + + END { if ($rtpe_pid) { kill('INT', $rtpe_pid) or die;