Chromium Code Reviews| Index: net/base/fuzzed_data_provider.h |
| diff --git a/net/base/fuzzed_data_provider.h b/net/base/fuzzed_data_provider.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..68ea6214fed38d2f5089a35b021b2f5257d9df8d |
| --- /dev/null |
| +++ b/net/base/fuzzed_data_provider.h |
| @@ -0,0 +1,52 @@ |
| +// Copyright 2016 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. |
| + |
| +#ifndef NET_BASE_FUZZED_DATA_PROVIDER_H |
| +#define NET_BASE_FUZZED_DATA_PROVIDER_H |
| + |
| +#include <stdint.h> |
| + |
| +#include "base/macros.h" |
| +#include "base/strings/string_piece.h" |
| + |
| +namespace net { |
| + |
| +// Utility class to break up fuzzer input for multiple consumers. Whenever run |
| +// on the same input, provides the same output, as long as its methods are |
| +// called in the same order, with the same arguments. |
| +class FuzzedDataProvider { |
| + public: |
| + // |data| is an array of length |size| that the FuzzedDataProvider wraps to |
| + // provide more granular access. |data| must outlive the FuzzedDataProvider. |
| + FuzzedDataProvider(const uint8_t* data, size_t size); |
| + ~FuzzedDataProvider(); |
| + |
| + // Tries to copy the first |bytes| remaining bytes from the input data to |
| + // |dest|. If fewer than that many bytes of data remain, writes all the |
| + // data that's left. Returns number of bytes written, which may be 0. |
| + size_t ConsumeBytes(char* dest, size_t bytes); |
|
eroman
2016/04/28 01:32:36
I think this interface would be easier/safer if it
mmenke
2016/04/28 16:01:38
SGTM. Could even provide both interfaces, but I'l
|
| + |
| + // Returns a value from |min| to |max| inclusive, extracting a value from the |
| + // input data in some unspecified manner. Value may not be uniformly |
| + // distributed in the given range. If there's no input data left, always |
| + // returns |min|. |min| must be less than or equal to |max|. |
| + uint32_t ConsumeValueInRange(uint32_t min, uint32_t max); |
| + |
| + // Returns a value with the specified number of bits of data. Returns 0 if |
| + // there's no input data left. |num_bits| must non-zero, and at most 32. |
| + // Basically the same as ConsumeValueInRange((1 << num_bits) - 1); |
| + uint32_t ConsumeBits(size_t num_bits); |
| + |
| + // Same as ConsumeBits(1), but returns a bool. |
|
eroman
2016/04/28 01:32:36
Might want to mention returns |true| when there is
mmenke
2016/04/28 16:01:38
Done (Though now it's false).
|
| + bool ConsumeBool(); |
| + |
| + private: |
| + base::StringPiece remaining_data_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(FuzzedDataProvider); |
| +}; |
| + |
| +} // namespace net |
| + |
| +#endif // NET_BASE_FUZZED_DATA_PROVIDER_H |