// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <limits>
#include "base/logging.h"
#include "base/basictypes.h"
#include "base/memory/scoped_ptr.h"
#include "media/audio/audio_parameters.h"
#include "media/audio/simple_sources.h"
#include "media/base/audio_bus.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace media {
// Validate that the SineWaveAudioSource writes the expected values.
TEST(SimpleSources, SineWaveAudioSource) {
static const uint32 samples = 1024;
static const uint32 bytes_per_sample = 2;
static const int freq = 200;
AudioParameters params(
AudioParameters::AUDIO_PCM_LINEAR, CHANNEL_LAYOUT_MONO,
AudioParameters::kTelephoneSampleRate, bytes_per_sample * 8, samples);
SineWaveAudioSource source(1, freq, params.sample_rate());
scoped_ptr<AudioBus> audio_bus = AudioBus::Create(params);
source.OnMoreData(audio_bus.get(), AudioBuffersState());
EXPECT_EQ(1, source.callbacks());
EXPECT_EQ(0, source.errors());
uint32 half_period = AudioParameters::kTelephoneSampleRate / (freq * 2);
// Spot test positive incursion of sine wave.
EXPECT_NEAR(0, audio_bus->channel(0)[0],
std::numeric_limits<float>::epsilon());
EXPECT_FLOAT_EQ(0.15643446f, audio_bus->channel(0)[1]);
EXPECT_LT(audio_bus->channel(0)[1], audio_bus->channel(0)[2]);
EXPECT_LT(audio_bus->channel(0)[2], audio_bus->channel(0)[3]);
// Spot test negative incursion of sine wave.
EXPECT_NEAR(0, audio_bus->channel(0)[half_period],
std::numeric_limits<float>::epsilon());
EXPECT_FLOAT_EQ(-0.15643446f, audio_bus->channel(0)[half_period + 1]);
EXPECT_GT(audio_bus->channel(0)[half_period + 1],
audio_bus->channel(0)[half_period + 2]);
EXPECT_GT(audio_bus->channel(0)[half_period + 2],
audio_bus->channel(0)[half_period + 3]);
}
TEST(SimpleSources, SineWaveAudioCapped) {
SineWaveAudioSource source(1, 200, AudioParameters::kTelephoneSampleRate);
static const int kSampleCap = 100;
source.CapSamples(kSampleCap);
scoped_ptr<AudioBus> audio_bus = AudioBus::Create(1, 2 * kSampleCap);
EXPECT_EQ(source.OnMoreData(
audio_bus.get(), AudioBuffersState()), kSampleCap);
EXPECT_EQ(1, source.callbacks());
EXPECT_EQ(source.OnMoreData(audio_bus.get(), AudioBuffersState()), 0);
EXPECT_EQ(2, source.callbacks());
source.Reset();
EXPECT_EQ(source.OnMoreData(
audio_bus.get(), AudioBuffersState()), kSampleCap);
EXPECT_EQ(3, source.callbacks());
EXPECT_EQ(0, source.errors());
}
TEST(SimpleSources, OnError) {
SineWaveAudioSource source(1, 200, AudioParameters::kTelephoneSampleRate);
source.OnError(NULL);
EXPECT_EQ(1, source.errors());
source.OnError(NULL);
EXPECT_EQ(2, source.errors());
}
} // namespace media