aboutsummaryrefslogtreecommitdiffhomepage
path: root/projects/icu/converter_fuzzer.cc
diff options
context:
space:
mode:
Diffstat (limited to 'projects/icu/converter_fuzzer.cc')
-rw-r--r--projects/icu/converter_fuzzer.cc45
1 files changed, 45 insertions, 0 deletions
diff --git a/projects/icu/converter_fuzzer.cc b/projects/icu/converter_fuzzer.cc
new file mode 100644
index 00000000..cfbdebf6
--- /dev/null
+++ b/projects/icu/converter_fuzzer.cc
@@ -0,0 +1,45 @@
+// 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.
+
+#include <stddef.h>
+#include <stdint.h>
+
+#include <algorithm>
+#include <array>
+#include <memory>
+#include <vector>
+
+#include "fuzzer_utils.h"
+#include "unicode/unistr.h"
+#include "unicode/ucnv.h"
+
+IcuEnvironment* env = new IcuEnvironment();
+
+template <typename T>
+using deleted_unique_ptr = std::unique_ptr<T, std::function<void(T*)>>;
+
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
+ UErrorCode status = U_ZERO_ERROR;
+ auto rng = CreateRng(data, size);
+ icu::UnicodeString str(UnicodeStringFromUtf8(data, size));
+
+ const char* converter_name =
+ ucnv_getAvailableName(rng() % ucnv_countAvailable());
+
+ deleted_unique_ptr<UConverter> converter(ucnv_open(converter_name, &status),
+ &ucnv_close);
+
+ if (U_FAILURE(status))
+ return 0;
+
+ static const size_t dest_buffer_size = 1024 * 1204;
+ static const std::unique_ptr<char[]> dest_buffer(new char[dest_buffer_size]);
+
+ str.extract(dest_buffer.get(), dest_buffer_size, converter.get(), status);
+
+ if (U_FAILURE(status))
+ return 0;
+
+ return 0;
+}