blob: 7e3511b3f1db237f49a837e288188504dcdb6e52 [file] [log] [blame]
// Copyright 2019 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 <stddef.h>
#include <stdint.h>
#include <fuzzer/FuzzedDataProvider.h>
#include "content/browser/speech/audio_encoder.h"
using content::AudioChunk;
// Copied from speech_recognition_engine.cc.
const int kDefaultConfigSampleRate = 8000;
const int kDefaultConfigBitsPerSample = 16;
const int kAudioSampleRate = 16000;
const int kAudioPacketIntervalMs = 100;
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
FuzzedDataProvider provider(data, size);
content::AudioEncoder encoder(kDefaultConfigSampleRate,
kDefaultConfigBitsPerSample);
while (provider.remaining_bytes()) {
std::string chunk_str =
provider.ConsumeRandomLengthString(provider.remaining_bytes());
scoped_refptr<AudioChunk> chunk =
new AudioChunk(reinterpret_cast<const uint8_t*>(chunk_str.data()),
chunk_str.size(), kDefaultConfigBitsPerSample / 8);
encoder.Encode(*chunk);
}
size_t sample_count = kAudioSampleRate * kAudioPacketIntervalMs / 1000;
scoped_refptr<AudioChunk> dummy_chunk = new AudioChunk(
sample_count * sizeof(int16_t), kDefaultConfigBitsPerSample / 8);
encoder.Encode(*dummy_chunk.get());
encoder.Flush();
scoped_refptr<AudioChunk> encoded_data(encoder.GetEncodedDataAndClear());
encoded_data->AsString();
encoder.GetMimeType();
encoder.GetBitsPerSample();
return 0;
}