blob: 3efd6a0301d1bb53ab70779ec1be17c6dac1d60a [file] [log] [blame]
// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <stdlib.h>
#include <string>
#include "base/containers/span.h"
#include "base/files/file_path.h"
#include "base/files/file_util.h"
#include "base/files/scoped_temp_dir.h"
#include "base/logging.h"
#include "base/nix/mime_util_xdg.h"
// Entry point for LibFuzzer.
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
base::ScopedTempDir temp_dir;
if (!temp_dir.CreateUniqueTempDir()) {
// Not a fuzzer error, so we return 0.
LOG(ERROR) << "Failed to create temp dir";
return 0;
}
// The parser reads file $XDG_DATA_DIRS/mime/mime.cache.
setenv("XDG_DATA_DIRS", temp_dir.GetPath().value().c_str(), 1);
base::FilePath mime_dir = temp_dir.GetPath().Append("mime");
base::FilePath mime_cache = mime_dir.Append("mime.cache");
if (!base::CreateDirectory(mime_dir) ||
!base::WriteFile(mime_cache, base::make_span(data, size))) {
LOG(ERROR) << "Failed to create " << mime_cache;
// Not a fuzzer error, so we return 0.
return 0;
}
base::FilePath dummy_path("foo.txt");
std::string type = base::nix::GetFileMimeType(dummy_path);
return 0;
}