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:
phoglund@webrtc.org 2012-01-11 12:26:34 +00:00
parent 6b6ff558a8
commit 01530a2ac2
4 changed files with 255 additions and 269 deletions

View 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_));
}

View File

@ -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);

View File

@ -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_;

View File

@ -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',