Remove the deprecated EncodeInternal interface from AudioEncoder
Also hid MaxEncodedBytes by making it private. It will get removed as soon as subclasses have had time to remove their overrides. BUG=webrtc:5591 Review URL: https://codereview.webrtc.org/1864993002 Cr-Commit-Position: refs/heads/master@{#12329}
This commit is contained in:
@ -1,64 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2016 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 "testing/gtest/include/gtest/gtest.h"
|
||||
#include "webrtc/modules/audio_coding/codecs/mock/mock_audio_encoder.h"
|
||||
|
||||
using ::testing::_;
|
||||
using ::testing::Invoke;
|
||||
using ::testing::Return;
|
||||
|
||||
namespace webrtc {
|
||||
|
||||
TEST(AudioEncoderTest, EncodeInternalRedirectsOk) {
|
||||
const size_t kPayloadSize = 16;
|
||||
const uint8_t payload[kPayloadSize] =
|
||||
{0xf, 0xe, 0xd, 0xc, 0xb, 0xa, 0x9, 0x8,
|
||||
0x7, 0x6, 0x5, 0x4, 0x3, 0x2, 0x1, 0x0};
|
||||
|
||||
MockAudioEncoderDeprecated old_impl;
|
||||
MockAudioEncoder new_impl;
|
||||
MockAudioEncoderBase* impls[] = { &old_impl, &new_impl };
|
||||
for (auto* impl : impls) {
|
||||
EXPECT_CALL(*impl, Die());
|
||||
EXPECT_CALL(*impl, MaxEncodedBytes())
|
||||
.WillRepeatedly(Return(kPayloadSize * 2));
|
||||
EXPECT_CALL(*impl, NumChannels()).WillRepeatedly(Return(1));
|
||||
EXPECT_CALL(*impl, SampleRateHz()).WillRepeatedly(Return(8000));
|
||||
}
|
||||
|
||||
EXPECT_CALL(old_impl, EncodeInternal(_, _, _, _)).WillOnce(
|
||||
Invoke(MockAudioEncoderDeprecated::CopyEncoding(payload)));
|
||||
|
||||
EXPECT_CALL(new_impl, EncodeImpl(_, _, _)).WillOnce(
|
||||
Invoke(MockAudioEncoder::CopyEncoding(payload)));
|
||||
|
||||
int16_t audio[80];
|
||||
uint8_t output_array[kPayloadSize * 2];
|
||||
rtc::Buffer output_buffer;
|
||||
|
||||
AudioEncoder* old_encoder = &old_impl;
|
||||
AudioEncoder* new_encoder = &new_impl;
|
||||
auto old_info = old_encoder->Encode(0, audio, &output_buffer);
|
||||
auto new_info = new_encoder->DEPRECATED_Encode(0, audio,
|
||||
kPayloadSize * 2,
|
||||
output_array);
|
||||
|
||||
EXPECT_EQ(old_info.encoded_bytes, kPayloadSize);
|
||||
EXPECT_EQ(new_info.encoded_bytes, kPayloadSize);
|
||||
EXPECT_EQ(output_buffer.size(), kPayloadSize);
|
||||
|
||||
for (size_t i = 0; i != kPayloadSize; ++i) {
|
||||
EXPECT_EQ(output_buffer.data()[i], payload[i]);
|
||||
EXPECT_EQ(output_array[i], payload[i]);
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace webrtc
|
||||
Reference in New Issue
Block a user