blob: 3e62a57582c8d6bc9aa030c85a9fb2bb9419ed91 [file] [log] [blame]
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +02001/*
2 * Copyright 2018 The WebRTC Project Authors. All rights reserved.
3 *
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
Yves Gerey3e707812018-11-28 16:47:49 +010011#include <stdint.h>
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020012#include <string.h> // memcmp
13
14#include "api/audio/audio_frame.h"
15#include "test/gtest.h"
16
17namespace webrtc {
18
19namespace {
20
21bool AllSamplesAre(int16_t sample, const AudioFrame& frame) {
22 const int16_t* frame_data = frame.data();
henrika2250b052019-07-04 11:27:52 +020023 for (size_t i = 0; i < frame.max_16bit_samples(); i++) {
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020024 if (frame_data[i] != sample) {
25 return false;
26 }
27 }
28 return true;
29}
30
31constexpr uint32_t kTimestamp = 27;
32constexpr int kSampleRateHz = 16000;
henrika2250b052019-07-04 11:27:52 +020033constexpr size_t kNumChannelsMono = 1;
34constexpr size_t kNumChannelsStereo = 2;
35constexpr size_t kNumChannels5_1 = 6;
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020036constexpr size_t kSamplesPerChannel = kSampleRateHz / 100;
37
38} // namespace
39
40TEST(AudioFrameTest, FrameStartsMuted) {
41 AudioFrame frame;
42 EXPECT_TRUE(frame.muted());
43 EXPECT_TRUE(AllSamplesAre(0, frame));
44}
45
46TEST(AudioFrameTest, UnmutedFrameIsInitiallyZeroed) {
47 AudioFrame frame;
48 frame.mutable_data();
49 EXPECT_FALSE(frame.muted());
50 EXPECT_TRUE(AllSamplesAre(0, frame));
51}
52
53TEST(AudioFrameTest, MutedFrameBufferIsZeroed) {
54 AudioFrame frame;
55 int16_t* frame_data = frame.mutable_data();
henrika2250b052019-07-04 11:27:52 +020056 for (size_t i = 0; i < frame.max_16bit_samples(); i++) {
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020057 frame_data[i] = 17;
58 }
59 ASSERT_TRUE(AllSamplesAre(17, frame));
60 frame.Mute();
61 EXPECT_TRUE(frame.muted());
62 EXPECT_TRUE(AllSamplesAre(0, frame));
63}
64
henrika2250b052019-07-04 11:27:52 +020065TEST(AudioFrameTest, UpdateFrameMono) {
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020066 AudioFrame frame;
henrika2250b052019-07-04 11:27:52 +020067 int16_t samples[kNumChannelsMono * kSamplesPerChannel] = {17};
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020068 frame.UpdateFrame(kTimestamp, samples, kSamplesPerChannel, kSampleRateHz,
henrika2250b052019-07-04 11:27:52 +020069 AudioFrame::kPLC, AudioFrame::kVadActive, kNumChannelsMono);
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020070
71 EXPECT_EQ(kTimestamp, frame.timestamp_);
henrika2250b052019-07-04 11:27:52 +020072 EXPECT_EQ(kSamplesPerChannel, frame.samples_per_channel());
73 EXPECT_EQ(kSampleRateHz, frame.sample_rate_hz());
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020074 EXPECT_EQ(AudioFrame::kPLC, frame.speech_type_);
75 EXPECT_EQ(AudioFrame::kVadActive, frame.vad_activity_);
henrika2250b052019-07-04 11:27:52 +020076 EXPECT_EQ(kNumChannelsMono, frame.num_channels());
77 EXPECT_EQ(CHANNEL_LAYOUT_MONO, frame.channel_layout());
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020078
79 EXPECT_FALSE(frame.muted());
80 EXPECT_EQ(0, memcmp(samples, frame.data(), sizeof(samples)));
81
82 frame.UpdateFrame(kTimestamp, nullptr /* data*/, kSamplesPerChannel,
83 kSampleRateHz, AudioFrame::kPLC, AudioFrame::kVadActive,
henrika2250b052019-07-04 11:27:52 +020084 kNumChannelsMono);
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +020085 EXPECT_TRUE(frame.muted());
86 EXPECT_TRUE(AllSamplesAre(0, frame));
87}
88
henrika2250b052019-07-04 11:27:52 +020089TEST(AudioFrameTest, UpdateFrameMultiChannel) {
90 AudioFrame frame;
91 frame.UpdateFrame(kTimestamp, nullptr /* data */, kSamplesPerChannel,
92 kSampleRateHz, AudioFrame::kPLC, AudioFrame::kVadActive,
93 kNumChannelsStereo);
94 EXPECT_EQ(kSamplesPerChannel, frame.samples_per_channel());
95 EXPECT_EQ(kNumChannelsStereo, frame.num_channels());
96 EXPECT_EQ(CHANNEL_LAYOUT_STEREO, frame.channel_layout());
97
98 frame.UpdateFrame(kTimestamp, nullptr /* data */, kSamplesPerChannel,
99 kSampleRateHz, AudioFrame::kPLC, AudioFrame::kVadActive,
100 kNumChannels5_1);
101 EXPECT_EQ(kSamplesPerChannel, frame.samples_per_channel());
102 EXPECT_EQ(kNumChannels5_1, frame.num_channels());
103 EXPECT_EQ(CHANNEL_LAYOUT_5_1, frame.channel_layout());
104}
105
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +0200106TEST(AudioFrameTest, CopyFrom) {
107 AudioFrame frame1;
108 AudioFrame frame2;
109
henrika2250b052019-07-04 11:27:52 +0200110 int16_t samples[kNumChannelsMono * kSamplesPerChannel] = {17};
Yves Gerey665174f2018-06-19 15:03:05 +0200111 frame2.UpdateFrame(kTimestamp, samples, kSamplesPerChannel, kSampleRateHz,
henrika2250b052019-07-04 11:27:52 +0200112 AudioFrame::kPLC, AudioFrame::kVadActive,
113 kNumChannelsMono);
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +0200114 frame1.CopyFrom(frame2);
115
116 EXPECT_EQ(frame2.timestamp_, frame1.timestamp_);
117 EXPECT_EQ(frame2.samples_per_channel_, frame1.samples_per_channel_);
118 EXPECT_EQ(frame2.sample_rate_hz_, frame1.sample_rate_hz_);
119 EXPECT_EQ(frame2.speech_type_, frame1.speech_type_);
120 EXPECT_EQ(frame2.vad_activity_, frame1.vad_activity_);
121 EXPECT_EQ(frame2.num_channels_, frame1.num_channels_);
122
123 EXPECT_EQ(frame2.muted(), frame1.muted());
124 EXPECT_EQ(0, memcmp(frame2.data(), frame1.data(), sizeof(samples)));
125
126 frame2.UpdateFrame(kTimestamp, nullptr /* data */, kSamplesPerChannel,
127 kSampleRateHz, AudioFrame::kPLC, AudioFrame::kVadActive,
henrika2250b052019-07-04 11:27:52 +0200128 kNumChannelsMono);
Fredrik Solenbergbbf21a32018-04-12 22:44:09 +0200129 frame1.CopyFrom(frame2);
130
131 EXPECT_EQ(frame2.muted(), frame1.muted());
132 EXPECT_EQ(0, memcmp(frame2.data(), frame1.data(), sizeof(samples)));
133}
134
135} // namespace webrtc