
The methodology used to generate this CL is documented in https://crbug.com/1098010#c95. No-Try: true Bug: 1098010 Change-Id: I26884c98578ee1ba4d7708ace5b25d1df5c0e576 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3895939 Owners-Override: Avi Drissman <avi@chromium.org> Commit-Queue: Mark Mentovai <mark@chromium.org> Reviewed-by: Mark Mentovai <mark@chromium.org> Auto-Submit: Avi Drissman <avi@chromium.org> Cr-Commit-Position: refs/heads/main@{#1047098}
30 lines
1.1 KiB
C++
30 lines
1.1 KiB
C++
// Copyright 2018 The Chromium Authors
|
|
// 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 <vector>
|
|
|
|
#include "net/third_party/quiche/src/quiche/quic/core/crypto/transport_parameters.h"
|
|
|
|
// Entry point for LibFuzzer.
|
|
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
|
FuzzedDataProvider data_provider(data, size);
|
|
auto perspective = data_provider.ConsumeBool() ? quic::Perspective::IS_CLIENT
|
|
: quic::Perspective::IS_SERVER;
|
|
quic::TransportParameters transport_parameters;
|
|
std::vector<uint8_t> remaining_bytes =
|
|
data_provider.ConsumeRemainingBytes<uint8_t>();
|
|
quic::ParsedQuicVersion version = quic::AllSupportedVersionsWithTls().front();
|
|
CHECK(version.UsesTls());
|
|
std::string error_details;
|
|
quic::ParseTransportParameters(version, perspective, remaining_bytes.data(),
|
|
remaining_bytes.size(), &transport_parameters,
|
|
&error_details);
|
|
return 0;
|
|
}
|