blob: 480094887b3cf97d42a3c7501eafee24ebb1e8d8 [file] [log] [blame]
// Copyright 2019 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// Fuzz test for `Complex::Ok()` from `complex_structure.emb` on arbitrary data.
//
// This fuzz target verifies that `Ok()` does not crash on any input. It does
// not verify that `Ok()` does the right thing.
#include "testdata/complex_structure.emb.h"
// Entry point for fuzz tester: this must have this exact signature, including
// the name `LLVMFuzzerTestOneInput`, or it will not work.
extern "C" int LLVMFuzzerTestOneInput(const ::std::uint8_t *data,
::std::size_t size) {
auto storage = ::std::basic_string</**/ ::std::uint8_t>(data, size);
const auto view = ::emboss_test::MakeComplexView(&storage);
(void)view.Ok();
return 0;
}