blob: 3815486ad691bef26ef72d22fbe1663ed0f60ae0 [file] [log] [blame]
Avi Drissmane4622aa2022-09-08 20:36:061// Copyright 2017 The Chromium Authors
Charles Harrison45a98332017-10-20 03:39:272// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include <string>
Helmut Januschka0fc785b2024-04-17 21:13:366#include <string_view>
Charles Harrison45a98332017-10-20 03:39:277
8#include "base/base64.h"
Hans Wennborgc3cffa62020-04-27 10:09:129#include "base/check_op.h"
Daniel Cheng17390fd2025-06-07 06:38:2610#include "base/strings/string_view_util.h"
Charles Harrison45a98332017-10-20 03:39:2711
12// Encode some random data, and then decode it.
danakjd6537d032024-05-21 21:32:5713extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data_ptr, size_t size) {
14 // SAFETY: libfuzzer provides a valid pointer and size pair.
15 auto data = UNSAFE_BUFFERS(base::span(data_ptr, size));
16 std::string_view data_string = base::as_string_view(data);
Collin Bakere21f723d2019-09-05 20:05:4117
danakjd6537d032024-05-21 21:32:5718 const std::string encode_output = base::Base64Encode(data);
Collin Bakere21f723d2019-09-05 20:05:4119 std::string decode_output;
Charles Harrison45a98332017-10-20 03:39:2720 CHECK(base::Base64Decode(encode_output, &decode_output));
danakjd6537d032024-05-21 21:32:5721 CHECK_EQ(data_string, decode_output);
Collin Bakere21f723d2019-09-05 20:05:4122
Helmut Januschka0fc785b2024-04-17 21:13:3623 // Also run the std::string_view variant and check that it gives the same
24 // results.
danakjd6537d032024-05-21 21:32:5725 CHECK_EQ(encode_output, base::Base64Encode(data_string));
Collin Bakere21f723d2019-09-05 20:05:4126
Charles Harrison45a98332017-10-20 03:39:2727 return 0;
28}