/src/snappy/snappy_compress_fuzzer.cc
Line | Count | Source |
1 | | // Copyright 2019 Google Inc. All Rights Reserved. |
2 | | // |
3 | | // Redistribution and use in source and binary forms, with or without |
4 | | // modification, are permitted provided that the following conditions are |
5 | | // met: |
6 | | // |
7 | | // * Redistributions of source code must retain the above copyright |
8 | | // notice, this list of conditions and the following disclaimer. |
9 | | // * Redistributions in binary form must reproduce the above |
10 | | // copyright notice, this list of conditions and the following disclaimer |
11 | | // in the documentation and/or other materials provided with the |
12 | | // distribution. |
13 | | // * Neither the name of Google Inc. nor the names of its |
14 | | // contributors may be used to endorse or promote products derived from |
15 | | // this software without specific prior written permission. |
16 | | // |
17 | | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
18 | | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
19 | | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
20 | | // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
21 | | // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
22 | | // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
23 | | // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
24 | | // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
25 | | // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
26 | | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
27 | | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
28 | | // |
29 | | // libFuzzer harness for fuzzing snappy compression code. |
30 | | |
31 | | #include <stddef.h> |
32 | | #include <stdint.h> |
33 | | |
34 | | #include <cassert> |
35 | | #include <string> |
36 | | |
37 | | #include "snappy.h" |
38 | | |
39 | | // Entry point for LibFuzzer. |
40 | 2.41k | extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { |
41 | 2.41k | std::string input(reinterpret_cast<const char*>(data), size); |
42 | 2.41k | for (int level = snappy::CompressionOptions::MinCompressionLevel(); |
43 | 7.24k | level <= snappy::CompressionOptions::MaxCompressionLevel(); ++level) { |
44 | 4.83k | std::string compressed; |
45 | 4.83k | size_t compressed_size = |
46 | 4.83k | snappy::Compress(input.data(), input.size(), &compressed, |
47 | 4.83k | snappy::CompressionOptions{/*level=*/level}); |
48 | | |
49 | 4.83k | (void)compressed_size; // Variable only used in debug builds. |
50 | 4.83k | assert(compressed_size == compressed.size()); |
51 | 4.83k | assert(compressed.size() <= snappy::MaxCompressedLength(input.size())); |
52 | 4.83k | assert( |
53 | 4.83k | snappy::IsValidCompressedBuffer(compressed.data(), compressed.size())); |
54 | | |
55 | 4.83k | std::string uncompressed_after_compress; |
56 | 4.83k | bool uncompress_succeeded = snappy::Uncompress( |
57 | 4.83k | compressed.data(), compressed.size(), &uncompressed_after_compress); |
58 | | |
59 | 4.83k | (void)uncompress_succeeded; // Variable only used in debug builds. |
60 | 4.83k | assert(uncompress_succeeded); |
61 | 4.83k | assert(input == uncompressed_after_compress); |
62 | 4.83k | } |
63 | 2.41k | return 0; |
64 | 2.41k | } |