Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(183)

Unified Diff: webrtc/modules/module_common_types_unittest.cc

Issue 2750783004: Add mute state field to AudioFrame. (Closed)
Patch Set: Fix num_channels check in UpMix() Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webrtc/modules/module_common_types_unittest.cc
diff --git a/webrtc/modules/module_common_types_unittest.cc b/webrtc/modules/module_common_types_unittest.cc
index 159e26babe92a59ee5245829c9ea1e24e29f9600..0de3fe857f5f0796b4e89e4fb4dd1bd002fd409e 100644
--- a/webrtc/modules/module_common_types_unittest.cc
+++ b/webrtc/modules/module_common_types_unittest.cc
@@ -10,10 +10,116 @@
#include "webrtc/modules/include/module_common_types.h"
+#include <cstring> // memcmp
+
#include "webrtc/test/gtest.h"
namespace webrtc {
+class AudioFrameTest : public ::testing::Test {
+ protected:
+ static bool AllSamplesAre(int16_t sample, const AudioFrame& frame) {
+ const int16_t* frame_data = frame.data();
+ for (size_t i = 0; i < AudioFrame::kMaxDataSizeSamples; i++) {
+ if (frame_data[i] != sample) {
+ return false;
+ }
+ }
+ return true;
+ }
+
+ static constexpr int kId = 16;
+ static constexpr uint32_t kTimestamp = 27;
+ static constexpr int kSampleRateHz = 16000;
+ static constexpr size_t kNumChannels = 1;
+ static constexpr size_t kSamplesPerChannel = kSampleRateHz / 100;
+};
+
+constexpr int AudioFrameTest::kId;
+constexpr uint32_t AudioFrameTest::kTimestamp;
+constexpr int AudioFrameTest::kSampleRateHz;
+constexpr size_t AudioFrameTest::kNumChannels;
+constexpr size_t AudioFrameTest::kSamplesPerChannel;
+
+TEST_F(AudioFrameTest, FrameStartsMuted) {
+ AudioFrame frame;
+ EXPECT_TRUE(frame.muted());
+ EXPECT_TRUE(AllSamplesAre(0, frame));
hlundin-webrtc 2017/03/22 12:07:26 I think you can replace this with EXPECT_THAT(fram
yujo 2017/03/22 19:45:45 Deleted the unnecessary test fixture. data() retu
hlundin-webrtc 2017/03/23 07:04:03 Don't change any more. This is good enough. I did
+}
+
+TEST_F(AudioFrameTest, UnmutedFrameIsInitiallyZeroed) {
+ AudioFrame frame;
+ frame.mutable_data();
+ EXPECT_FALSE(frame.muted());
+ EXPECT_TRUE(AllSamplesAre(0, frame));
+}
+
+TEST_F(AudioFrameTest, MutedFrameBufferIsZeroed) {
+ AudioFrame frame;
+ int16_t* frame_data = frame.mutable_data();
+ for (size_t i = 0; i < AudioFrame::kMaxDataSizeSamples; i++) {
+ frame_data[i] = 17;
+ }
+ ASSERT_TRUE(AllSamplesAre(17, frame));
+ frame.Mute();
+ EXPECT_TRUE(frame.muted());
+ EXPECT_TRUE(AllSamplesAre(0, frame));
+}
+
+TEST_F(AudioFrameTest, UpdateFrame) {
+ AudioFrame frame;
+ int16_t samples[kNumChannels * kSamplesPerChannel] = {17};
+ frame.UpdateFrame(kId, kTimestamp, samples, kSamplesPerChannel, kSampleRateHz,
+ AudioFrame::kPLC, AudioFrame::kVadActive, kNumChannels);
+
+ EXPECT_EQ(kId, frame.id_);
+ EXPECT_EQ(kTimestamp, frame.timestamp_);
+ EXPECT_EQ(kSamplesPerChannel, frame.samples_per_channel_);
+ EXPECT_EQ(kSampleRateHz, frame.sample_rate_hz_);
+ EXPECT_EQ(AudioFrame::kPLC, frame.speech_type_);
+ EXPECT_EQ(AudioFrame::kVadActive, frame.vad_activity_);
+ EXPECT_EQ(kNumChannels, frame.num_channels_);
+
+ EXPECT_FALSE(frame.muted());
+ EXPECT_EQ(0, std::memcmp(samples, frame.data(), sizeof(samples)));
hlundin-webrtc 2017/03/22 12:07:26 Can you use EXPECT_THAT(frame.data(), ::testing::E
yujo 2017/03/22 19:45:45 Yes here, but not in the other two cases below. Le
hlundin-webrtc 2017/03/23 07:04:03 Acknowledged.
+
+ frame.UpdateFrame(kId, kTimestamp, nullptr /* data*/, kSamplesPerChannel,
+ kSampleRateHz, AudioFrame::kPLC, AudioFrame::kVadActive,
+ kNumChannels);
+ EXPECT_TRUE(frame.muted());
+ EXPECT_TRUE(AllSamplesAre(0, frame));
+}
+
+TEST_F(AudioFrameTest, CopyFrom) {
+ AudioFrame frame1;
+ AudioFrame frame2;
+
+ int16_t samples[kNumChannels * kSamplesPerChannel] = {17};
+ frame2.UpdateFrame(kId, kTimestamp, samples, kSamplesPerChannel,
+ kSampleRateHz, AudioFrame::kPLC, AudioFrame::kVadActive,
+ kNumChannels);
+ frame1.CopyFrom(frame2);
+
+ EXPECT_EQ(frame2.id_, frame1.id_);
+ EXPECT_EQ(frame2.timestamp_, frame1.timestamp_);
+ EXPECT_EQ(frame2.samples_per_channel_, frame1.samples_per_channel_);
+ EXPECT_EQ(frame2.sample_rate_hz_, frame1.sample_rate_hz_);
+ EXPECT_EQ(frame2.speech_type_, frame1.speech_type_);
+ EXPECT_EQ(frame2.vad_activity_, frame1.vad_activity_);
+ EXPECT_EQ(frame2.num_channels_, frame1.num_channels_);
+
+ EXPECT_EQ(frame2.muted(), frame1.muted());
+ EXPECT_EQ(0, std::memcmp(frame2.data(), frame1.data(), sizeof(samples)));
hlundin-webrtc 2017/03/22 12:07:26 EXPECT_THAT(...)
+
+ frame2.UpdateFrame(kId, kTimestamp, nullptr /* data */, kSamplesPerChannel,
+ kSampleRateHz, AudioFrame::kPLC, AudioFrame::kVadActive,
+ kNumChannels);
+ frame1.CopyFrom(frame2);
+
+ EXPECT_EQ(frame2.muted(), frame1.muted());
+ EXPECT_EQ(0, std::memcmp(frame2.data(), frame1.data(), sizeof(samples)));
hlundin-webrtc 2017/03/22 12:07:26 EXPECT_THAT(...)
+}
+
TEST(IsNewerSequenceNumber, Equal) {
EXPECT_FALSE(IsNewerSequenceNumber(0x0001, 0x0001));
}

Powered by Google App Engine
This is Rietveld 408576698