blob: cc0fc206e7f488771884a2478b9df76443fd77ef [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
leozwang@webrtc.org91b359e2012-02-28 17:26:14 +00002 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
niklase@google.com470e71d2011-07-07 08:21:25 +00003 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
kjellander@webrtc.org543c3ea2011-11-23 12:20:35 +000011#include "TwoWayCommunication.h"
12
pbos@webrtc.org12dc1a32013-08-05 16:22:53 +000013#include <ctype.h>
niklase@google.com470e71d2011-07-07 08:21:25 +000014#include <stdio.h>
15#include <string.h>
16
17#ifdef WIN32
18#include <Windows.h>
19#endif
20
kjellander@webrtc.org3c0aae12014-09-04 09:55:40 +000021#include "testing/gtest/include/gtest/gtest.h"
turaj@webrtc.org6ea3d1c2013-10-02 21:44:33 +000022#include "webrtc/engine_configurations.h"
turaj@webrtc.org6ea3d1c2013-10-02 21:44:33 +000023#include "webrtc/common_types.h"
24#include "webrtc/modules/audio_coding/main/test/PCMFile.h"
25#include "webrtc/modules/audio_coding/main/test/utility.h"
26#include "webrtc/system_wrappers/interface/trace.h"
pbos@webrtc.org2ab209e2013-08-09 08:49:48 +000027#include "webrtc/test/testsupport/fileutils.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000028
tina.legrand@webrtc.org554ae1a2011-12-16 10:09:04 +000029namespace webrtc {
niklase@google.com470e71d2011-07-07 08:21:25 +000030
31#define MAX_FILE_NAME_LENGTH_BYTE 500
32
henrik.lundin@webrtc.orgadaf8092014-04-17 08:29:10 +000033TwoWayCommunication::TwoWayCommunication(int testMode)
34 : _acmA(AudioCodingModule::Create(1)),
35 _acmB(AudioCodingModule::Create(2)),
36 _acmRefA(AudioCodingModule::Create(3)),
37 _acmRefB(AudioCodingModule::Create(4)),
38 _testMode(testMode) {}
niklase@google.com470e71d2011-07-07 08:21:25 +000039
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000040TwoWayCommunication::~TwoWayCommunication() {
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000041 delete _channel_A2B;
42 delete _channel_B2A;
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000043 delete _channelRef_A2B;
44 delete _channelRef_B2A;
niklase@google.com470e71d2011-07-07 08:21:25 +000045#ifdef WEBRTC_DTMF_DETECTION
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +000046 if (_dtmfDetectorA != NULL) {
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000047 delete _dtmfDetectorA;
48 }
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +000049 if (_dtmfDetectorB != NULL) {
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000050 delete _dtmfDetectorB;
51 }
niklase@google.com470e71d2011-07-07 08:21:25 +000052#endif
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000053 _inFileA.Close();
54 _inFileB.Close();
55 _outFileA.Close();
56 _outFileB.Close();
57 _outFileRefA.Close();
58 _outFileRefB.Close();
niklase@google.com470e71d2011-07-07 08:21:25 +000059}
60
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +000061void TwoWayCommunication::ChooseCodec(uint8_t* codecID_A,
62 uint8_t* codecID_B) {
kwiberg@webrtc.org00b8f6b2015-02-26 14:34:55 +000063 rtc::scoped_ptr<AudioCodingModule> tmpACM(AudioCodingModule::Create(0));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000064 uint8_t noCodec = tmpACM->NumberOfCodecs();
65 CodecInst codecInst;
66 printf("List of Supported Codecs\n");
67 printf("========================\n");
68 for (uint8_t codecCntr = 0; codecCntr < noCodec; codecCntr++) {
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +000069 EXPECT_EQ(tmpACM->Codec(codecCntr, &codecInst), 0);
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000070 printf("%d- %s\n", codecCntr, codecInst.plname);
71 }
72 printf("\nChoose a send codec for side A [0]: ");
73 char myStr[15] = "";
74 EXPECT_TRUE(fgets(myStr, 10, stdin) != NULL);
75 *codecID_A = (uint8_t) atoi(myStr);
niklase@google.com470e71d2011-07-07 08:21:25 +000076
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000077 printf("\nChoose a send codec for side B [0]: ");
78 EXPECT_TRUE(fgets(myStr, 10, stdin) != NULL);
79 *codecID_B = (uint8_t) atoi(myStr);
niklase@google.com470e71d2011-07-07 08:21:25 +000080
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000081 printf("\n");
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000082}
niklase@google.com470e71d2011-07-07 08:21:25 +000083
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +000084void TwoWayCommunication::SetUp() {
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000085 uint8_t codecID_A;
86 uint8_t codecID_B;
87
88 ChooseCodec(&codecID_A, &codecID_B);
89 CodecInst codecInst_A;
90 CodecInst codecInst_B;
91 CodecInst dummyCodec;
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +000092 EXPECT_EQ(0, _acmA->Codec(codecID_A, &codecInst_A));
93 EXPECT_EQ(0, _acmB->Codec(codecID_B, &codecInst_B));
94 EXPECT_EQ(0, _acmA->Codec(6, &dummyCodec));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000095
96 //--- Set A codecs
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +000097 EXPECT_EQ(0, _acmA->RegisterSendCodec(codecInst_A));
98 EXPECT_EQ(0, _acmA->RegisterReceiveCodec(codecInst_B));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000099#ifdef WEBRTC_DTMF_DETECTION
100 _dtmfDetectorA = new(DTMFDetector);
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000101 EXPECT_GT(_acmA->RegisterIncomingMessagesCallback(_dtmfDetectorA, ACMUSA),
102 -1);
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000103#endif
104 //--- Set ref-A codecs
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000105 EXPECT_EQ(0, _acmRefA->RegisterSendCodec(codecInst_A));
106 EXPECT_EQ(0, _acmRefA->RegisterReceiveCodec(codecInst_B));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000107
108 //--- Set B codecs
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000109 EXPECT_EQ(0, _acmB->RegisterSendCodec(codecInst_B));
110 EXPECT_EQ(0, _acmB->RegisterReceiveCodec(codecInst_A));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000111#ifdef WEBRTC_DTMF_DETECTION
112 _dtmfDetectorB = new(DTMFDetector);
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000113 EXPECT_GT(_acmB->RegisterIncomingMessagesCallback(_dtmfDetectorB, ACMUSA),
114 -1);
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000115#endif
116
117 //--- Set ref-B codecs
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000118 EXPECT_EQ(0, _acmRefB->RegisterSendCodec(codecInst_B));
119 EXPECT_EQ(0, _acmRefB->RegisterReceiveCodec(codecInst_A));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000120
121 uint16_t frequencyHz;
122
123 //--- Input A
124 std::string in_file_name = webrtc::test::ResourcePath(
125 "audio_coding/testfile32kHz", "pcm");
126 frequencyHz = 32000;
127 printf("Enter input file at side A [%s]: ", in_file_name.c_str());
128 PCMFile::ChooseFile(&in_file_name, 499, &frequencyHz);
129 _inFileA.Open(in_file_name, frequencyHz, "rb");
130
131 //--- Output A
132 std::string out_file_a = webrtc::test::OutputPath() + "outA.pcm";
133 printf("Output file at side A: %s\n", out_file_a.c_str());
134 printf("Sampling frequency (in Hz) of the above file: %u\n", frequencyHz);
135 _outFileA.Open(out_file_a, frequencyHz, "wb");
136 std::string ref_file_name = webrtc::test::OutputPath() + "ref_outA.pcm";
137 _outFileRefA.Open(ref_file_name, frequencyHz, "wb");
138
139 //--- Input B
140 in_file_name = webrtc::test::ResourcePath("audio_coding/testfile32kHz",
141 "pcm");
142 frequencyHz = 32000;
143 printf("\n\nEnter input file at side B [%s]: ", in_file_name.c_str());
144 PCMFile::ChooseFile(&in_file_name, 499, &frequencyHz);
145 _inFileB.Open(in_file_name, frequencyHz, "rb");
146
147 //--- Output B
148 std::string out_file_b = webrtc::test::OutputPath() + "outB.pcm";
149 printf("Output file at side B: %s\n", out_file_b.c_str());
150 printf("Sampling frequency (in Hz) of the above file: %u\n", frequencyHz);
151 _outFileB.Open(out_file_b, frequencyHz, "wb");
152 ref_file_name = webrtc::test::OutputPath() + "ref_outB.pcm";
153 _outFileRefB.Open(ref_file_name, frequencyHz, "wb");
154
155 //--- Set A-to-B channel
156 _channel_A2B = new Channel;
157 _acmA->RegisterTransportCallback(_channel_A2B);
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000158 _channel_A2B->RegisterReceiverACM(_acmB.get());
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000159 //--- Do the same for the reference
160 _channelRef_A2B = new Channel;
161 _acmRefA->RegisterTransportCallback(_channelRef_A2B);
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000162 _channelRef_A2B->RegisterReceiverACM(_acmRefB.get());
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000163
164 //--- Set B-to-A channel
165 _channel_B2A = new Channel;
166 _acmB->RegisterTransportCallback(_channel_B2A);
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000167 _channel_B2A->RegisterReceiverACM(_acmA.get());
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000168 //--- Do the same for reference
169 _channelRef_B2A = new Channel;
170 _acmRefB->RegisterTransportCallback(_channelRef_B2A);
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000171 _channelRef_B2A->RegisterReceiverACM(_acmRefA.get());
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000172
173 // The clicks will be more obvious when we
174 // are in FAX mode.
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000175 EXPECT_EQ(_acmB->SetPlayoutMode(fax), 0);
176 EXPECT_EQ(_acmRefB->SetPlayoutMode(fax), 0);
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000177}
178
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000179void TwoWayCommunication::SetUpAutotest() {
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000180 CodecInst codecInst_A;
181 CodecInst codecInst_B;
182 CodecInst dummyCodec;
183
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000184 EXPECT_EQ(0, _acmA->Codec("ISAC", &codecInst_A, 16000, 1));
185 EXPECT_EQ(0, _acmB->Codec("L16", &codecInst_B, 8000, 1));
186 EXPECT_EQ(0, _acmA->Codec(6, &dummyCodec));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000187
188 //--- Set A codecs
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000189 EXPECT_EQ(0, _acmA->RegisterSendCodec(codecInst_A));
190 EXPECT_EQ(0, _acmA->RegisterReceiveCodec(codecInst_B));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000191#ifdef WEBRTC_DTMF_DETECTION
192 _dtmfDetectorA = new(DTMFDetector);
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000193 EXPECT_EQ(0, _acmA->RegisterIncomingMessagesCallback(_dtmfDetectorA, ACMUSA));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000194#endif
195
196 //--- Set ref-A codecs
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000197 EXPECT_GT(_acmRefA->RegisterSendCodec(codecInst_A), -1);
198 EXPECT_GT(_acmRefA->RegisterReceiveCodec(codecInst_B), -1);
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000199
200 //--- Set B codecs
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000201 EXPECT_GT(_acmB->RegisterSendCodec(codecInst_B), -1);
202 EXPECT_GT(_acmB->RegisterReceiveCodec(codecInst_A), -1);
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000203#ifdef WEBRTC_DTMF_DETECTION
204 _dtmfDetectorB = new(DTMFDetector);
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000205 EXPECT_EQ(0, _acmB->RegisterIncomingMessagesCallback(_dtmfDetectorB, ACMUSA));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000206#endif
207
208 //--- Set ref-B codecs
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000209 EXPECT_EQ(0, _acmRefB->RegisterSendCodec(codecInst_B));
210 EXPECT_EQ(0, _acmRefB->RegisterReceiveCodec(codecInst_A));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000211
212 uint16_t frequencyHz;
213
214 //--- Input A and B
215 std::string in_file_name = webrtc::test::ResourcePath(
216 "audio_coding/testfile32kHz", "pcm");
217 frequencyHz = 16000;
218 _inFileA.Open(in_file_name, frequencyHz, "rb");
219 _inFileB.Open(in_file_name, frequencyHz, "rb");
220
221 //--- Output A
222 std::string output_file_a = webrtc::test::OutputPath() + "outAutotestA.pcm";
223 frequencyHz = 16000;
224 _outFileA.Open(output_file_a, frequencyHz, "wb");
225 std::string output_ref_file_a = webrtc::test::OutputPath()
226 + "ref_outAutotestA.pcm";
227 _outFileRefA.Open(output_ref_file_a, frequencyHz, "wb");
228
229 //--- Output B
230 std::string output_file_b = webrtc::test::OutputPath() + "outAutotestB.pcm";
231 frequencyHz = 16000;
232 _outFileB.Open(output_file_b, frequencyHz, "wb");
233 std::string output_ref_file_b = webrtc::test::OutputPath()
234 + "ref_outAutotestB.pcm";
235 _outFileRefB.Open(output_ref_file_b, frequencyHz, "wb");
236
237 //--- Set A-to-B channel
238 _channel_A2B = new Channel;
239 _acmA->RegisterTransportCallback(_channel_A2B);
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000240 _channel_A2B->RegisterReceiverACM(_acmB.get());
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000241 //--- Do the same for the reference
242 _channelRef_A2B = new Channel;
243 _acmRefA->RegisterTransportCallback(_channelRef_A2B);
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000244 _channelRef_A2B->RegisterReceiverACM(_acmRefB.get());
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000245
246 //--- Set B-to-A channel
247 _channel_B2A = new Channel;
248 _acmB->RegisterTransportCallback(_channel_B2A);
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000249 _channel_B2A->RegisterReceiverACM(_acmA.get());
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000250 //--- Do the same for reference
251 _channelRef_B2A = new Channel;
252 _acmRefB->RegisterTransportCallback(_channelRef_B2A);
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000253 _channelRef_B2A->RegisterReceiverACM(_acmRefA.get());
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000254
255 // The clicks will be more obvious when we
256 // are in FAX mode.
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000257 EXPECT_EQ(0, _acmB->SetPlayoutMode(fax));
258 EXPECT_EQ(0, _acmRefB->SetPlayoutMode(fax));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000259}
260
261void TwoWayCommunication::Perform() {
262 if (_testMode == 0) {
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000263 SetUpAutotest();
264 } else {
265 SetUp();
266 }
267 unsigned int msecPassed = 0;
268 unsigned int secPassed = 0;
269
270 int32_t outFreqHzA = _outFileA.SamplingFrequency();
271 int32_t outFreqHzB = _outFileB.SamplingFrequency();
272
273 AudioFrame audioFrame;
274
275 CodecInst codecInst_B;
276 CodecInst dummy;
277
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000278 EXPECT_EQ(0, _acmB->SendCodec(&codecInst_B));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000279
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000280 // In the following loop we tests that the code can handle misuse of the APIs.
281 // In the middle of a session with data flowing between two sides, called A
282 // and B, APIs will be called, like ResetEncoder(), and the code should
283 // continue to run, and be able to recover.
284 bool expect_error_add = false;
285 bool expect_error_process = false;
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000286 while (!_inFileA.EndOfFile() && !_inFileB.EndOfFile()) {
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000287 msecPassed += 10;
288 EXPECT_GT(_inFileA.Read10MsData(audioFrame), 0);
289 EXPECT_EQ(0, _acmA->Add10MsData(audioFrame));
290 EXPECT_EQ(0, _acmRefA->Add10MsData(audioFrame));
niklase@google.com470e71d2011-07-07 08:21:25 +0000291
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000292 EXPECT_GT(_inFileB.Read10MsData(audioFrame), 0);
niklase@google.com470e71d2011-07-07 08:21:25 +0000293
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000294 // Expect call to pass except for the time when no send codec is registered.
295 if (!expect_error_add) {
296 EXPECT_EQ(0, _acmB->Add10MsData(audioFrame));
297 } else {
298 EXPECT_EQ(-1, _acmB->Add10MsData(audioFrame));
299 }
300 // Expect to pass except for the time when there either is no send codec
301 // registered, or no receive codec.
302 if (!expect_error_process) {
303 EXPECT_GT(_acmB->Process(), -1);
304 } else {
305 EXPECT_EQ(_acmB->Process(), -1);
306 }
307 EXPECT_EQ(0, _acmRefB->Add10MsData(audioFrame));
308 EXPECT_GT(_acmA->Process(), -1);
309 EXPECT_GT(_acmRefA->Process(), -1);
310 EXPECT_GT(_acmRefB->Process(), -1);
311 EXPECT_EQ(0, _acmA->PlayoutData10Ms(outFreqHzA, &audioFrame));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000312 _outFileA.Write10MsData(audioFrame);
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000313 EXPECT_EQ(0, _acmRefA->PlayoutData10Ms(outFreqHzA, &audioFrame));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000314 _outFileRefA.Write10MsData(audioFrame);
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000315 EXPECT_EQ(0, _acmB->PlayoutData10Ms(outFreqHzB, &audioFrame));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000316 _outFileB.Write10MsData(audioFrame);
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000317 EXPECT_EQ(0, _acmRefB->PlayoutData10Ms(outFreqHzB, &audioFrame));
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000318 _outFileRefB.Write10MsData(audioFrame);
niklase@google.com470e71d2011-07-07 08:21:25 +0000319
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000320 // Update time counters each time a second of data has passed.
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000321 if (msecPassed >= 1000) {
322 msecPassed = 0;
323 secPassed++;
324 }
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000325 // Call RestEncoder for ACM on side A, and InitializeSender for ACM on
326 // side B.
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000327 if (((secPassed % 5) == 4) && (msecPassed == 0)) {
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000328 EXPECT_EQ(0, _acmA->ResetEncoder());
329 EXPECT_EQ(0, _acmB->InitializeSender());
330 expect_error_add = true;
331 expect_error_process = true;
niklase@google.com470e71d2011-07-07 08:21:25 +0000332 }
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000333 // Re-register send codec on side B.
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000334 if (((secPassed % 5) == 4) && (msecPassed >= 990)) {
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000335 EXPECT_EQ(0, _acmB->RegisterSendCodec(codecInst_B));
336 EXPECT_EQ(0, _acmB->SendCodec(&dummy));
337 expect_error_add = false;
338 expect_error_process = false;
niklase@google.com470e71d2011-07-07 08:21:25 +0000339 }
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000340 // Reset decoder on side B, and initialize receiver on side A.
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000341 if (((secPassed % 7) == 6) && (msecPassed == 0)) {
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000342 EXPECT_EQ(0, _acmB->ResetDecoder());
343 EXPECT_EQ(0, _acmA->InitializeReceiver());
niklase@google.com470e71d2011-07-07 08:21:25 +0000344 }
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000345 // Re-register codec on side A.
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000346 if (((secPassed % 7) == 6) && (msecPassed >= 990)) {
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000347 EXPECT_EQ(0, _acmA->RegisterReceiveCodec(codecInst_B));
niklase@google.com470e71d2011-07-07 08:21:25 +0000348 }
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000349 }
niklase@google.com470e71d2011-07-07 08:21:25 +0000350}
351
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000352} // namespace webrtc