Rewrote the rcp_rtcp test.
Finished rewriting the rtp_rtcp test. Rewrote first RTP RTCP test BUG= TEST= Review URL: http://webrtc-codereview.appspot.com/342007 git-svn-id: http://webrtc.googlecode.com/svn/trunk@1386 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
parent
6b6ff558a8
commit
01530a2ac2
195
src/voice_engine/main/test/auto_test/standard/rtp_rtcp_test.cc
Normal file
195
src/voice_engine/main/test/auto_test/standard/rtp_rtcp_test.cc
Normal file
@ -0,0 +1,195 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Use of this source code is governed by a BSD-style license
|
||||||
|
* that can be found in the LICENSE file in the root of the source
|
||||||
|
* tree. An additional intellectual property rights grant can be found
|
||||||
|
* in the file PATENTS. All contributing project authors may
|
||||||
|
* be found in the AUTHORS file in the root of the source tree.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "after_streaming_fixture.h"
|
||||||
|
#include "voe_standard_test.h"
|
||||||
|
#include "testsupport/fileutils.h"
|
||||||
|
|
||||||
|
static const char* const RTCP_CNAME = "Whatever";
|
||||||
|
|
||||||
|
class RtpRtcpTest : public AfterStreamingFixture {
|
||||||
|
protected:
|
||||||
|
void SetUp() {
|
||||||
|
// We need a second channel for this test, so set it up.
|
||||||
|
second_channel_ = voe_base_->CreateChannel();
|
||||||
|
EXPECT_GE(second_channel_, 0);
|
||||||
|
|
||||||
|
EXPECT_EQ(0, voe_base_->SetSendDestination(
|
||||||
|
second_channel_, 8002, "127.0.0.1"));
|
||||||
|
EXPECT_EQ(0, voe_base_->SetLocalReceiver(
|
||||||
|
second_channel_, 8002));
|
||||||
|
EXPECT_EQ(0, voe_base_->StartReceive(second_channel_));
|
||||||
|
EXPECT_EQ(0, voe_base_->StartPlayout(second_channel_));
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->SetLocalSSRC(second_channel_, 5678));
|
||||||
|
EXPECT_EQ(0, voe_base_->StartSend(second_channel_));
|
||||||
|
|
||||||
|
// We'll set up the RTCP CNAME and SSRC to something arbitrary here.
|
||||||
|
voe_rtp_rtcp_->SetRTCP_CNAME(channel_, RTCP_CNAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TearDown() {
|
||||||
|
voe_base_->DeleteChannel(second_channel_);
|
||||||
|
}
|
||||||
|
|
||||||
|
int second_channel_;
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_F(RtpRtcpTest, RemoteRtcpCnameHasPropagatedToRemoteSide) {
|
||||||
|
// We need to sleep a bit here for the name to propagate. For instance,
|
||||||
|
// 200 milliseconds is not enough, so we'll go with one second here.
|
||||||
|
Sleep(1000);
|
||||||
|
|
||||||
|
char char_buffer[256];
|
||||||
|
voe_rtp_rtcp_->GetRemoteRTCP_CNAME(channel_, char_buffer);
|
||||||
|
EXPECT_STREQ(RTCP_CNAME, char_buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(RtpRtcpTest, SSRCPropagatesCorrectly) {
|
||||||
|
unsigned int local_ssrc = 1234;
|
||||||
|
EXPECT_EQ(0, voe_base_->StopSend(channel_));
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->SetLocalSSRC(channel_, local_ssrc));
|
||||||
|
EXPECT_EQ(0, voe_base_->StartSend(channel_));
|
||||||
|
|
||||||
|
Sleep(1000);
|
||||||
|
|
||||||
|
unsigned int ssrc;
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->GetLocalSSRC(channel_, ssrc));
|
||||||
|
EXPECT_EQ(local_ssrc, ssrc);
|
||||||
|
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->GetRemoteSSRC(channel_, ssrc));
|
||||||
|
EXPECT_EQ(local_ssrc, ssrc);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(RtpRtcpTest, RtcpApplicationDefinedPacketsCanBeSentAndReceived) {
|
||||||
|
voetest::RtcpAppHandler rtcp_app_handler;
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->RegisterRTCPObserver(
|
||||||
|
channel_, rtcp_app_handler));
|
||||||
|
|
||||||
|
// Send data aligned to 32 bytes.
|
||||||
|
const char* data = "application-dependent data------";
|
||||||
|
unsigned short data_length = strlen(data);
|
||||||
|
unsigned int data_name = 0x41424344; // 'ABCD' in ascii
|
||||||
|
unsigned char data_subtype = 1;
|
||||||
|
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->SendApplicationDefinedRTCPPacket(
|
||||||
|
channel_, data_subtype, data_name, data, data_length));
|
||||||
|
|
||||||
|
// Ensure the RTP-RTCP process gets scheduled.
|
||||||
|
Sleep(1000);
|
||||||
|
|
||||||
|
// Ensure we received the data in the callback.
|
||||||
|
EXPECT_EQ(data_length, rtcp_app_handler.length_in_bytes_);
|
||||||
|
EXPECT_EQ(0, memcmp(data, rtcp_app_handler.data_, data_length));
|
||||||
|
EXPECT_EQ(data_name, rtcp_app_handler.name_);
|
||||||
|
EXPECT_EQ(data_subtype, rtcp_app_handler.sub_type_);
|
||||||
|
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->DeRegisterRTCPObserver(channel_));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(RtpRtcpTest, DisabledRtcpObserverDoesNotReceiveData) {
|
||||||
|
voetest::RtcpAppHandler rtcp_app_handler;
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->RegisterRTCPObserver(
|
||||||
|
channel_, rtcp_app_handler));
|
||||||
|
|
||||||
|
// Put observer in a known state before de-registering.
|
||||||
|
rtcp_app_handler.Reset();
|
||||||
|
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->DeRegisterRTCPObserver(channel_));
|
||||||
|
|
||||||
|
const char* data = "whatever";
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->SendApplicationDefinedRTCPPacket(
|
||||||
|
channel_, 1, 0x41424344, data, strlen(data)));
|
||||||
|
|
||||||
|
// Ensure the RTP-RTCP process gets scheduled.
|
||||||
|
Sleep(1000);
|
||||||
|
|
||||||
|
// Ensure we received no data.
|
||||||
|
EXPECT_EQ(0u, rtcp_app_handler.name_);
|
||||||
|
EXPECT_EQ(0u, rtcp_app_handler.sub_type_);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(RtpRtcpTest, InsertExtraRTPPacketDealsWithInvalidArguments) {
|
||||||
|
const char payload_data[8] = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H' };
|
||||||
|
|
||||||
|
EXPECT_EQ(-1, voe_rtp_rtcp_->InsertExtraRTPPacket(
|
||||||
|
-1, 0, false, payload_data, 8)) <<
|
||||||
|
"Should reject: invalid channel.";
|
||||||
|
EXPECT_EQ(-1, voe_rtp_rtcp_->InsertExtraRTPPacket(
|
||||||
|
channel_, -1, false, payload_data, 8)) <<
|
||||||
|
"Should reject: invalid payload type.";
|
||||||
|
EXPECT_EQ(-1, voe_rtp_rtcp_->InsertExtraRTPPacket(
|
||||||
|
channel_, 128, false, payload_data, 8)) <<
|
||||||
|
"Should reject: invalid payload type.";
|
||||||
|
EXPECT_EQ(-1, voe_rtp_rtcp_->InsertExtraRTPPacket(
|
||||||
|
channel_, 99, false, NULL, 8)) <<
|
||||||
|
"Should reject: bad pointer.";
|
||||||
|
EXPECT_EQ(-1, voe_rtp_rtcp_->InsertExtraRTPPacket(
|
||||||
|
channel_, 99, false, payload_data, 1500 - 28 + 1)) <<
|
||||||
|
"Should reject: invalid size.";
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(RtpRtcpTest, CanTransmitExtraRtpPacketsWithoutError) {
|
||||||
|
const char payload_data[8] = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H' };
|
||||||
|
|
||||||
|
for (int i = 0; i < 128; ++i) {
|
||||||
|
// Try both with and without the marker bit set
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->InsertExtraRTPPacket(
|
||||||
|
channel_, i, false, payload_data, 8));
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->InsertExtraRTPPacket(
|
||||||
|
channel_, i, true, payload_data, 8));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(RtpRtcpTest, CanCreateRtpDumpFilesWithoutError) {
|
||||||
|
// Create two RTP dump files (3 seconds long). You can verify these after
|
||||||
|
// the test using rtpplay or NetEqRTPplay if you like.
|
||||||
|
std::string output_path = webrtc::test::OutputPath();
|
||||||
|
std::string incoming_filename = output_path + "dump_in_3sec.rtp";
|
||||||
|
std::string outgoing_filename = output_path + "dump_out_3sec.rtp";
|
||||||
|
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->StartRTPDump(
|
||||||
|
channel_, incoming_filename.c_str(), webrtc::kRtpIncoming));
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->StartRTPDump(
|
||||||
|
channel_, outgoing_filename.c_str(), webrtc::kRtpOutgoing));
|
||||||
|
|
||||||
|
Sleep(3000);
|
||||||
|
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->StopRTPDump(channel_, webrtc::kRtpIncoming));
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->StopRTPDump(channel_, webrtc::kRtpOutgoing));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(RtpRtcpTest, ObserverGetsNotifiedOnSsrcChange) {
|
||||||
|
voetest::TestRtpObserver rtcp_observer;
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->RegisterRTPObserver(
|
||||||
|
channel_, rtcp_observer));
|
||||||
|
rtcp_observer.Reset();
|
||||||
|
|
||||||
|
unsigned int new_ssrc = 7777;
|
||||||
|
EXPECT_EQ(0, voe_base_->StopSend(channel_));
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->SetLocalSSRC(channel_, new_ssrc));
|
||||||
|
EXPECT_EQ(0, voe_base_->StartSend(channel_));
|
||||||
|
|
||||||
|
Sleep(500);
|
||||||
|
|
||||||
|
// Verify we got the new SSRC.
|
||||||
|
EXPECT_EQ(new_ssrc, rtcp_observer.ssrc_[0]);
|
||||||
|
|
||||||
|
// Now try another SSRC.
|
||||||
|
unsigned int newer_ssrc = 1717;
|
||||||
|
EXPECT_EQ(0, voe_base_->StopSend(channel_));
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->SetLocalSSRC(channel_, newer_ssrc));
|
||||||
|
EXPECT_EQ(0, voe_base_->StartSend(channel_));
|
||||||
|
|
||||||
|
Sleep(500);
|
||||||
|
|
||||||
|
EXPECT_EQ(newer_ssrc, rtcp_observer.ssrc_[0]);
|
||||||
|
|
||||||
|
EXPECT_EQ(0, voe_rtp_rtcp_->DeRegisterRTPObserver(channel_));
|
||||||
|
}
|
@ -131,25 +131,25 @@ const char* summaryFilename = "/tmp/VoiceEngineSummary.txt";
|
|||||||
|
|
||||||
int dummy = 0; // Dummy used in different functions to avoid warnings
|
int dummy = 0; // Dummy used in different functions to avoid warnings
|
||||||
|
|
||||||
MyRTPObserver::MyRTPObserver() {
|
TestRtpObserver::TestRtpObserver() {
|
||||||
Reset();
|
Reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
MyRTPObserver::~MyRTPObserver() {
|
TestRtpObserver::~TestRtpObserver() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyRTPObserver::Reset() {
|
void TestRtpObserver::Reset() {
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
_SSRC[i] = 0;
|
ssrc_[i] = 0;
|
||||||
_CSRC[i][0] = 0;
|
csrc_[i][0] = 0;
|
||||||
_CSRC[i][1] = 0;
|
csrc_[i][1] = 0;
|
||||||
_added[i][0] = false;
|
added_[i][0] = false;
|
||||||
_added[i][1] = false;
|
added_[i][1] = false;
|
||||||
_size[i] = 0;
|
size_[i] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyRTPObserver::OnIncomingCSRCChanged(const int channel,
|
void TestRtpObserver::OnIncomingCSRCChanged(const int channel,
|
||||||
const unsigned int CSRC,
|
const unsigned int CSRC,
|
||||||
const bool added) {
|
const bool added) {
|
||||||
char msg[128];
|
char msg[128];
|
||||||
@ -160,22 +160,22 @@ void MyRTPObserver::OnIncomingCSRCChanged(const int channel,
|
|||||||
if (channel > 1)
|
if (channel > 1)
|
||||||
return; // Not enough memory.
|
return; // Not enough memory.
|
||||||
|
|
||||||
_CSRC[channel][_size[channel]] = CSRC;
|
csrc_[channel][size_[channel]] = CSRC;
|
||||||
_added[channel][_size[channel]] = added;
|
added_[channel][size_[channel]] = added;
|
||||||
|
|
||||||
_size[channel]++;
|
size_[channel]++;
|
||||||
if (_size[channel] == 2)
|
if (size_[channel] == 2)
|
||||||
_size[channel] = 0;
|
size_[channel] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyRTPObserver::OnIncomingSSRCChanged(const int channel,
|
void TestRtpObserver::OnIncomingSSRCChanged(const int channel,
|
||||||
const unsigned int SSRC) {
|
const unsigned int SSRC) {
|
||||||
char msg[128];
|
char msg[128];
|
||||||
sprintf(msg, "\n=> OnIncomingSSRCChanged(channel=%d, SSRC=%u)\n", channel,
|
sprintf(msg, "\n=> OnIncomingSSRCChanged(channel=%d, SSRC=%u)\n", channel,
|
||||||
SSRC);
|
SSRC);
|
||||||
TEST_LOG("%s", msg);
|
TEST_LOG("%s", msg);
|
||||||
|
|
||||||
_SSRC[channel] = SSRC;
|
ssrc_[channel] = SSRC;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyDeadOrAlive::OnPeriodicDeadOrAlive(const int /*channel*/,
|
void MyDeadOrAlive::OnPeriodicDeadOrAlive(const int /*channel*/,
|
||||||
@ -316,25 +316,22 @@ void MyTraceCallback::Print(const TraceLevel level,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void RtcpAppHandler::OnApplicationDataReceived(
|
void RtcpAppHandler::OnApplicationDataReceived(
|
||||||
const int /*channel*/, const unsigned char subType, const unsigned int name,
|
const int /*channel*/, const unsigned char sub_type,
|
||||||
const unsigned char* data, const unsigned short dataLengthInBytes) {
|
const unsigned int name, const unsigned char* data,
|
||||||
_lengthBytes = dataLengthInBytes;
|
const unsigned short length_in_bytes) {
|
||||||
memcpy(_data, &data[0], dataLengthInBytes);
|
length_in_bytes_ = length_in_bytes;
|
||||||
_subType = subType;
|
memcpy(data_, &data[0], length_in_bytes);
|
||||||
_name = name;
|
sub_type_ = sub_type;
|
||||||
|
name_ = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
void RtcpAppHandler::Reset() {
|
void RtcpAppHandler::Reset() {
|
||||||
_lengthBytes = 0;
|
length_in_bytes_ = 0;
|
||||||
memset(_data, 0, sizeof(_data));
|
memset(data_, 0, sizeof(data_));
|
||||||
_subType = 0;
|
sub_type_ = 0;
|
||||||
_name = 0;
|
name_ = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
ErrorObserver obs;
|
|
||||||
RtcpAppHandler myRtcpAppHandler;
|
|
||||||
MyRTPObserver rtpObserver;
|
|
||||||
|
|
||||||
void my_encryption::encrypt(int, unsigned char * in_data,
|
void my_encryption::encrypt(int, unsigned char * in_data,
|
||||||
unsigned char * out_data,
|
unsigned char * out_data,
|
||||||
int bytes_in,
|
int bytes_in,
|
||||||
@ -882,7 +879,7 @@ int VoETestManager::ReleaseInterfaces() {
|
|||||||
return (releaseOK == true) ? 0 : -1;
|
return (releaseOK == true) ? 0 : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int VoETestManager::SetUp() {
|
int VoETestManager::SetUp(ErrorObserver* error_observer) {
|
||||||
char char_buffer[1024];
|
char char_buffer[1024];
|
||||||
|
|
||||||
TEST_MUSTPASS(voe_base_->Init());
|
TEST_MUSTPASS(voe_base_->Init());
|
||||||
@ -891,7 +888,7 @@ int VoETestManager::SetUp() {
|
|||||||
TEST_MUSTPASS(voe_hardware_->SetLoudspeakerStatus(false));
|
TEST_MUSTPASS(voe_hardware_->SetLoudspeakerStatus(false));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
TEST_MUSTPASS(voe_base_->RegisterVoiceEngineObserver(obs));
|
TEST_MUSTPASS(voe_base_->RegisterVoiceEngineObserver(*error_observer));
|
||||||
|
|
||||||
TEST_LOG("Get version \n");
|
TEST_LOG("Get version \n");
|
||||||
TEST_MUSTPASS(voe_base_->GetVersion(char_buffer));
|
TEST_MUSTPASS(voe_base_->GetVersion(char_buffer));
|
||||||
@ -977,208 +974,18 @@ int VoETestManager::DoStandardTest() {
|
|||||||
|
|
||||||
TEST_LOG("\n\n+++ Base tests +++\n\n");
|
TEST_LOG("\n\n+++ Base tests +++\n\n");
|
||||||
|
|
||||||
if (SetUp() != 0) return -1;
|
ErrorObserver error_observer;
|
||||||
|
if (SetUp(&error_observer) != 0) return -1;
|
||||||
|
|
||||||
// TODO(qhogpat): this gets verified way later - quite ugly. Make sure to
|
|
||||||
// put this into setup when rewriting the test that requires this.
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->SetRTCP_CNAME(0, "Niklas"));
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->SetLocalSSRC(0, 1234));
|
|
||||||
voe_network_->SetSourceFilter(0, 0);
|
voe_network_->SetSourceFilter(0, 0);
|
||||||
|
|
||||||
FakeExternalTransport channel0_transport(voe_network_);
|
FakeExternalTransport channel0_transport(voe_network_);
|
||||||
if (TestStartStreaming(channel0_transport) != 0) return -1;
|
if (TestStartStreaming(channel0_transport) != 0) return -1;
|
||||||
if (TestStartPlaying() != 0) return -1;
|
if (TestStartPlaying() != 0) return -1;
|
||||||
|
|
||||||
/////////////////////////
|
|
||||||
// Start another channel
|
|
||||||
|
|
||||||
#if defined(_TEST_RTP_RTCP_)
|
|
||||||
TEST_LOG("\n\n+++ Preparing another channel for"
|
|
||||||
" RTP/RTCP tests +++ \n\n");
|
|
||||||
|
|
||||||
TEST_LOG("Create one more channel and start it up\n");
|
|
||||||
TEST_MUSTPASS(!(1==voe_base_->CreateChannel()));
|
|
||||||
#ifdef WEBRTC_EXTERNAL_TRANSPORT
|
|
||||||
FakeExternalTransport ch1transport(voe_network_);
|
|
||||||
TEST_MUSTPASS(voe_network_->RegisterExternalTransport(1, ch1transport));
|
|
||||||
#else
|
|
||||||
TEST_MUSTPASS(voe_base_->SetSendDestination(1, 8002, "127.0.0.1"));
|
|
||||||
TEST_MUSTPASS(voe_base_->SetLocalReceiver(1, 8002));
|
|
||||||
#endif
|
|
||||||
TEST_MUSTPASS(voe_base_->StartReceive(1));
|
|
||||||
TEST_MUSTPASS(voe_base_->StartPlayout(1));
|
|
||||||
// Ensures SSSR_ch1 = 5678.
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->SetLocalSSRC(1, 5678));
|
|
||||||
TEST_MUSTPASS(voe_base_->StartSend(1));
|
|
||||||
SLEEP(2000);
|
|
||||||
#else
|
|
||||||
TEST_LOG("\n\n+++ Preparing another channel NOT NEEDED +++ \n");
|
|
||||||
#endif // defined(_TEST_RTP_RTCP_)
|
|
||||||
/////////////////
|
|
||||||
// Conferencing
|
|
||||||
|
|
||||||
#ifndef _TEST_BASE_
|
#ifndef _TEST_BASE_
|
||||||
|
|
||||||
TEST_LOG("\n\n+++ (Base) tests NOT ENABLED +++\n");
|
TEST_LOG("\n\n+++ (Base) tests NOT ENABLED +++\n");
|
||||||
#endif // #ifdef _TEST_BASE_
|
#endif // #ifdef _TEST_BASE_
|
||||||
////////////////////////////////////////////////
|
|
||||||
// RTP/RTCP (test after streaming is activated)
|
|
||||||
|
|
||||||
#if (defined(_TEST_RTP_RTCP_) && defined(_TEST_BASE_))
|
|
||||||
|
|
||||||
TEST_LOG("\n\n+++ More RTP/RTCP tests +++\n\n");
|
|
||||||
|
|
||||||
SLEEP(8000);
|
|
||||||
|
|
||||||
char char_buffer[256];
|
|
||||||
TEST_LOG("Check that we have gotten RTCP packet, and collected CName\n");
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->GetRemoteRTCP_CNAME(0, char_buffer));
|
|
||||||
TEST_LOG("default cname is %s", char_buffer);
|
|
||||||
TEST_MUSTPASS(_stricmp("Niklas", char_buffer));
|
|
||||||
|
|
||||||
TEST_LOG("Check that we have received the right SSRC\n");
|
|
||||||
unsigned int ssrc1;
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->GetLocalSSRC(0, ssrc1));
|
|
||||||
TEST_LOG("SSRC chan 0 = %lu \n", (long unsigned int) ssrc1);
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->GetRemoteSSRC(0, ssrc1));
|
|
||||||
// the originally set 1234 should be maintained
|
|
||||||
TEST_MUSTPASS(1234 != ssrc1);
|
|
||||||
|
|
||||||
// RTCP APP tests
|
|
||||||
TEST_LOG("Check RTCP APP send/receive \n");
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->RegisterRTCPObserver(0, myRtcpAppHandler));
|
|
||||||
SLEEP(100);
|
|
||||||
// send RTCP APP packet (fill up data message to multiple of 32 bits)
|
|
||||||
const char* data = "application-dependent data------"; // multiple of 32byte
|
|
||||||
unsigned short lenBytes(static_cast<unsigned short> (strlen(data)));
|
|
||||||
unsigned int name = static_cast<unsigned int> (0x41424344); // 'ABCD';
|
|
||||||
unsigned char subType = 1;
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->SendApplicationDefinedRTCPPacket(0,
|
|
||||||
subType,
|
|
||||||
name,
|
|
||||||
data,
|
|
||||||
lenBytes));
|
|
||||||
TEST_LOG("Waiting for RTCP APP callback...\n");
|
|
||||||
SLEEP(8000); // ensures that RTCP is scheduled
|
|
||||||
TEST_MUSTPASS(strlen(data) != myRtcpAppHandler._lengthBytes);
|
|
||||||
TEST_MUSTPASS(memcmp(data, myRtcpAppHandler._data, lenBytes));
|
|
||||||
TEST_MUSTPASS(myRtcpAppHandler._name != name);
|
|
||||||
TEST_MUSTPASS(myRtcpAppHandler._subType != subType);
|
|
||||||
TEST_LOG("=> application-dependent data of size %d bytes was received\n",
|
|
||||||
lenBytes);
|
|
||||||
// disable the callback and verify that no callback is received this time
|
|
||||||
myRtcpAppHandler.Reset();
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->DeRegisterRTCPObserver(0));
|
|
||||||
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->SendApplicationDefinedRTCPPacket(0,
|
|
||||||
subType,
|
|
||||||
name,
|
|
||||||
data,
|
|
||||||
lenBytes));
|
|
||||||
TEST_LOG("RTCP APP callback should not be received since the observer "
|
|
||||||
"is disabled...\n");
|
|
||||||
SLEEP(5000); // ensures that RTCP is scheduled
|
|
||||||
TEST_MUSTPASS(myRtcpAppHandler._name != 0);
|
|
||||||
TEST_MUSTPASS(myRtcpAppHandler._subType != 0);
|
|
||||||
|
|
||||||
#if !defined(WEBRTC_EXTERNAL_TRANSPORT)
|
|
||||||
printf("Tesing InsertExtraRTPPacket\n");
|
|
||||||
|
|
||||||
const char payloadData[8] = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H' };
|
|
||||||
|
|
||||||
// fail tests
|
|
||||||
// invalid channel
|
|
||||||
TEST_MUSTPASS(-1 != voe_rtp_rtcp_->InsertExtraRTPPacket(-1,
|
|
||||||
0,
|
|
||||||
false,
|
|
||||||
payloadData,
|
|
||||||
8));
|
|
||||||
// invalid payload type
|
|
||||||
TEST_MUSTPASS(-1 != voe_rtp_rtcp_->InsertExtraRTPPacket(0,
|
|
||||||
-1,
|
|
||||||
false,
|
|
||||||
payloadData,
|
|
||||||
8));
|
|
||||||
// invalid payload type
|
|
||||||
TEST_MUSTPASS(-1 != voe_rtp_rtcp_->InsertExtraRTPPacket(0,
|
|
||||||
128,
|
|
||||||
false,
|
|
||||||
payloadData,
|
|
||||||
8));
|
|
||||||
// invalid pointer
|
|
||||||
TEST_MUSTPASS(-1 != voe_rtp_rtcp_->InsertExtraRTPPacket(0,
|
|
||||||
99,
|
|
||||||
false,
|
|
||||||
NULL,
|
|
||||||
8));
|
|
||||||
// invalid size
|
|
||||||
TEST_MUSTPASS(-1 != voe_rtp_rtcp_->InsertExtraRTPPacket(0,
|
|
||||||
99,
|
|
||||||
false,
|
|
||||||
payloadData,
|
|
||||||
1500 - 28 + 1));
|
|
||||||
|
|
||||||
// transmit some extra RTP packets
|
|
||||||
for (int pt = 0; pt < 128; pt++) {
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->InsertExtraRTPPacket(0,
|
|
||||||
pt,
|
|
||||||
false,
|
|
||||||
payloadData,
|
|
||||||
8));
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->InsertExtraRTPPacket(0,
|
|
||||||
pt,
|
|
||||||
true,
|
|
||||||
payloadData,
|
|
||||||
8));
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
printf("Skipping InsertExtraRTPPacket tests -"
|
|
||||||
" WEBRTC_EXTERNAL_TRANSPORT is defined \n");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
TEST_LOG("Enable the RTP observer\n");
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->RegisterRTPObserver(0, rtpObserver));
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->RegisterRTPObserver(1, rtpObserver));
|
|
||||||
rtpObserver.Reset();
|
|
||||||
|
|
||||||
// Create two RTP-dump files (3 seconds long).
|
|
||||||
// Verify using rtpplay or NetEqRTPplay when test is done.
|
|
||||||
TEST_LOG("Creating two RTP-dump files...\n");
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->StartRTPDump(0,
|
|
||||||
GetFilename("dump_in_3sec.rtp"),
|
|
||||||
kRtpIncoming));
|
|
||||||
MARK();
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->StartRTPDump(0,
|
|
||||||
GetFilename("dump_out_3sec.rtp"),
|
|
||||||
kRtpOutgoing));
|
|
||||||
MARK();
|
|
||||||
SLEEP(3000);
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->StopRTPDump(0, kRtpIncoming));
|
|
||||||
MARK();
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->StopRTPDump(0, kRtpOutgoing));
|
|
||||||
MARK();
|
|
||||||
|
|
||||||
rtpObserver.Reset();
|
|
||||||
|
|
||||||
TEST_LOG("Verify the OnIncomingSSRCChanged callback\n");
|
|
||||||
TEST_MUSTPASS(voe_base_->StopSend(0));
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->SetLocalSSRC(0, 7777));
|
|
||||||
TEST_MUSTPASS(voe_base_->StartSend(0));
|
|
||||||
SLEEP(500);
|
|
||||||
TEST_MUSTPASS(rtpObserver._SSRC[0] != 7777);
|
|
||||||
TEST_MUSTPASS(voe_base_->StopSend(0));
|
|
||||||
TEST_MUSTPASS(voe_rtp_rtcp_->SetLocalSSRC(0, 1234));
|
|
||||||
TEST_MUSTPASS(voe_base_->StartSend(0));
|
|
||||||
SLEEP(500);
|
|
||||||
TEST_MUSTPASS(rtpObserver._SSRC[0] != 1234);
|
|
||||||
rtpObserver.Reset();
|
|
||||||
if (voe_file_) {
|
|
||||||
TEST_LOG("Start playing a file as microphone again...\n");
|
|
||||||
TEST_MUSTPASS(voe_file_->StartPlayingFileAsMicrophone(0,
|
|
||||||
AudioFilename(),
|
|
||||||
true,
|
|
||||||
true));
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef WEBRTC_CODEC_RED
|
#ifdef WEBRTC_CODEC_RED
|
||||||
TEST_LOG("Enabling FEC \n");
|
TEST_LOG("Enabling FEC \n");
|
||||||
@ -1191,20 +998,7 @@ int VoETestManager::DoStandardTest() {
|
|||||||
#else
|
#else
|
||||||
TEST_LOG("Skipping FEC tests - WEBRTC_CODEC_RED not defined \n");
|
TEST_LOG("Skipping FEC tests - WEBRTC_CODEC_RED not defined \n");
|
||||||
#endif // #ifdef WEBRTC_CODEC_RED
|
#endif // #ifdef WEBRTC_CODEC_RED
|
||||||
#else
|
|
||||||
TEST_LOG("\n\n+++ More RTP/RTCP tests NOT ENABLED +++\n");
|
|
||||||
#endif // #ifdef _TEST_RTP_RTCP_
|
|
||||||
/////////////////////////
|
|
||||||
// Delete extra channel
|
|
||||||
|
|
||||||
#if defined(_TEST_RTP_RTCP_)
|
|
||||||
TEST_LOG("\n\n+++ Delete extra channel +++ \n\n");
|
|
||||||
|
|
||||||
TEST_LOG("Delete channel 1, stopping everything\n");
|
|
||||||
TEST_MUSTPASS(voe_base_->DeleteChannel(1));
|
|
||||||
#else
|
|
||||||
TEST_LOG("\n\n+++ Delete extra channel NOT NEEDED +++ \n");
|
|
||||||
#endif // #if defined(WEBRTC_VOICE_ENGINE_CONFERENCING) && (define......
|
|
||||||
/////////////////////////////////////////////////
|
/////////////////////////////////////////////////
|
||||||
// Hardware (test after streaming is activated)
|
// Hardware (test after streaming is activated)
|
||||||
|
|
||||||
@ -2345,10 +2139,10 @@ TEST_MUSTPASS(voe_codec_->SetSendCodec(0, ci));
|
|||||||
SLEEP(3000);
|
SLEEP(3000);
|
||||||
|
|
||||||
#if !defined(_INSTRUMENTATION_TESTING_)
|
#if !defined(_INSTRUMENTATION_TESTING_)
|
||||||
TEST_LOG("obs.code is %d\n", obs.code);
|
TEST_LOG("error_observer.code is %d\n", error_observer.code);
|
||||||
TEST_MUSTPASS(obs.code != VE_RECEIVE_PACKET_TIMEOUT);
|
TEST_MUSTPASS(error_observer.code != VE_RECEIVE_PACKET_TIMEOUT);
|
||||||
#endif
|
#endif
|
||||||
obs.code = -1;
|
error_observer.code = -1;
|
||||||
TEST_MUSTPASS(voe_base_->StartSend(0));
|
TEST_MUSTPASS(voe_base_->StartSend(0));
|
||||||
if (voe_file_) {
|
if (voe_file_) {
|
||||||
TEST_LOG("Start playing a file as microphone again \n");
|
TEST_LOG("Start playing a file as microphone again \n");
|
||||||
@ -2360,17 +2154,17 @@ TEST_MUSTPASS(voe_codec_->SetSendCodec(0, ci));
|
|||||||
TEST_LOG("You should see runtime error %d\n", VE_PACKET_RECEIPT_RESTARTED);
|
TEST_LOG("You should see runtime error %d\n", VE_PACKET_RECEIPT_RESTARTED);
|
||||||
SLEEP(1000);
|
SLEEP(1000);
|
||||||
#if !defined(_INSTRUMENTATION_TESTING_)
|
#if !defined(_INSTRUMENTATION_TESTING_)
|
||||||
TEST_MUSTPASS(obs.code != VE_PACKET_RECEIPT_RESTARTED);
|
TEST_MUSTPASS(error_observer.code != VE_PACKET_RECEIPT_RESTARTED);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(_INSTRUMENTATION_TESTING_)
|
#if !defined(_INSTRUMENTATION_TESTING_)
|
||||||
TEST_LOG("Disabling observer, no runtime error should be seen...\n");
|
TEST_LOG("Disabling observer, no runtime error should be seen...\n");
|
||||||
TEST_MUSTPASS(voe_base_->DeRegisterVoiceEngineObserver());
|
TEST_MUSTPASS(voe_base_->DeRegisterVoiceEngineObserver());
|
||||||
obs.code = -1;
|
error_observer.code = -1;
|
||||||
TEST_MUSTPASS(voe_base_->StopSend(0));
|
TEST_MUSTPASS(voe_base_->StopSend(0));
|
||||||
TEST_MUSTPASS(voe_network_->SetPacketTimeoutNotification(0, true, 2));
|
TEST_MUSTPASS(voe_network_->SetPacketTimeoutNotification(0, true, 2));
|
||||||
SLEEP(2500);
|
SLEEP(2500);
|
||||||
TEST_MUSTPASS(obs.code != -1);
|
TEST_MUSTPASS(error_observer.code != -1);
|
||||||
// disable notifications to avoid additional 8082 callbacks
|
// disable notifications to avoid additional 8082 callbacks
|
||||||
TEST_MUSTPASS(voe_network_->SetPacketTimeoutNotification(0, false, 2));
|
TEST_MUSTPASS(voe_network_->SetPacketTimeoutNotification(0, false, 2));
|
||||||
TEST_MUSTPASS(voe_base_->StartSend(0));
|
TEST_MUSTPASS(voe_base_->StartSend(0));
|
||||||
@ -2384,14 +2178,15 @@ TEST_MUSTPASS(voe_codec_->SetSendCodec(0, ci));
|
|||||||
SLEEP(1000);
|
SLEEP(1000);
|
||||||
/// TEST_MUSTPASS(obs.code != -1);
|
/// TEST_MUSTPASS(obs.code != -1);
|
||||||
TEST_LOG("Enabling observer again\n");
|
TEST_LOG("Enabling observer again\n");
|
||||||
TEST_MUSTPASS(voe_base_->RegisterVoiceEngineObserver(obs));
|
TEST_MUSTPASS(voe_base_->RegisterVoiceEngineObserver(error_observer));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
TEST_LOG("Enable dead-or-alive callbacks for 4 seconds (dT=1sec)...\n");
|
TEST_LOG("Enable dead-or-alive callbacks for 4 seconds (dT=1sec)...\n");
|
||||||
TEST_LOG("You should see ALIVE messages\n");
|
TEST_LOG("You should see ALIVE messages\n");
|
||||||
|
|
||||||
MyDeadOrAlive obs;
|
MyDeadOrAlive dead_or_alive_observer;
|
||||||
TEST_MUSTPASS(voe_network_->RegisterDeadOrAliveObserver(0, obs));
|
TEST_MUSTPASS(voe_network_->RegisterDeadOrAliveObserver(
|
||||||
|
0, dead_or_alive_observer));
|
||||||
TEST_MUSTPASS(voe_network_->SetPeriodicDeadOrAliveStatus(0, true, 1));
|
TEST_MUSTPASS(voe_network_->SetPeriodicDeadOrAliveStatus(0, true, 1));
|
||||||
SLEEP(4000);
|
SLEEP(4000);
|
||||||
|
|
||||||
|
@ -65,10 +65,10 @@ namespace voetest {
|
|||||||
void createSummary(VoiceEngine* ve);
|
void createSummary(VoiceEngine* ve);
|
||||||
void prepareDelivery();
|
void prepareDelivery();
|
||||||
|
|
||||||
class MyRTPObserver : public VoERTPObserver {
|
class TestRtpObserver : public VoERTPObserver {
|
||||||
public:
|
public:
|
||||||
MyRTPObserver();
|
TestRtpObserver();
|
||||||
~MyRTPObserver();
|
virtual ~TestRtpObserver();
|
||||||
virtual void OnIncomingCSRCChanged(const int channel,
|
virtual void OnIncomingCSRCChanged(const int channel,
|
||||||
const unsigned int CSRC,
|
const unsigned int CSRC,
|
||||||
const bool added);
|
const bool added);
|
||||||
@ -76,10 +76,10 @@ class MyRTPObserver : public VoERTPObserver {
|
|||||||
const unsigned int SSRC);
|
const unsigned int SSRC);
|
||||||
void Reset();
|
void Reset();
|
||||||
public:
|
public:
|
||||||
unsigned int _SSRC[2];
|
unsigned int ssrc_[2];
|
||||||
unsigned int _CSRC[2][2]; // stores 2 SSRCs for each channel
|
unsigned int csrc_[2][2]; // Stores 2 CSRCs for each channel.
|
||||||
bool _added[2][2];
|
bool added_[2][2];
|
||||||
int _size[2];
|
int size_[2];
|
||||||
};
|
};
|
||||||
|
|
||||||
class MyTraceCallback : public TraceCallback {
|
class MyTraceCallback : public TraceCallback {
|
||||||
@ -103,16 +103,16 @@ class ErrorObserver : public VoiceEngineObserver {
|
|||||||
class RtcpAppHandler : public VoERTCPObserver {
|
class RtcpAppHandler : public VoERTCPObserver {
|
||||||
public:
|
public:
|
||||||
void OnApplicationDataReceived(const int channel,
|
void OnApplicationDataReceived(const int channel,
|
||||||
const unsigned char subType,
|
const unsigned char sub_type,
|
||||||
const unsigned int name,
|
const unsigned int name,
|
||||||
const unsigned char* data,
|
const unsigned char* data,
|
||||||
const unsigned short dataLengthInBytes);
|
const unsigned short length_in_bytes);
|
||||||
void Reset();
|
void Reset();
|
||||||
~RtcpAppHandler() {}
|
~RtcpAppHandler() {}
|
||||||
unsigned short _lengthBytes;
|
unsigned short length_in_bytes_;
|
||||||
unsigned char _data[256];
|
unsigned char data_[256];
|
||||||
unsigned char _subType;
|
unsigned char sub_type_;
|
||||||
unsigned int _name;
|
unsigned int name_;
|
||||||
};
|
};
|
||||||
|
|
||||||
class DtmfCallback : public VoETelephoneEventObserver {
|
class DtmfCallback : public VoETelephoneEventObserver {
|
||||||
@ -338,14 +338,9 @@ class VoETestManager {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int SetUp();
|
int SetUp(ErrorObserver* error_observer);
|
||||||
int TestHardwareBeforeStreaming();
|
|
||||||
int TestCodecsBeforeStreaming();
|
|
||||||
int TestNetworkBeforeStreaming();
|
|
||||||
int TestStartStreaming(FakeExternalTransport& channel0_transport);
|
int TestStartStreaming(FakeExternalTransport& channel0_transport);
|
||||||
int TestStartPlaying();
|
int TestStartPlaying();
|
||||||
int TestNetEq();
|
|
||||||
int TestCodecs();
|
|
||||||
|
|
||||||
bool initialized_;
|
bool initialized_;
|
||||||
|
|
||||||
|
@ -44,6 +44,7 @@
|
|||||||
'auto_test/standard/neteq_test.cc',
|
'auto_test/standard/neteq_test.cc',
|
||||||
'auto_test/standard/network_before_streaming_test.cc',
|
'auto_test/standard/network_before_streaming_test.cc',
|
||||||
'auto_test/standard/rtp_rtcp_before_streaming_test.cc',
|
'auto_test/standard/rtp_rtcp_before_streaming_test.cc',
|
||||||
|
'auto_test/standard/rtp_rtcp_test.cc',
|
||||||
'auto_test/standard/voe_base_misc_test.cc',
|
'auto_test/standard/voe_base_misc_test.cc',
|
||||||
'auto_test/resource_manager.cc',
|
'auto_test/resource_manager.cc',
|
||||||
'auto_test/voe_cpu_test.cc',
|
'auto_test/voe_cpu_test.cc',
|
||||||
|
Loading…
Reference in New Issue
Block a user