Skip to content

Commit

Permalink
Improve fuzzer code coverage (#239)
Browse files Browse the repository at this point in the history
* fuzz: test grapheme break functions

* fuzz: cover character lumping
  • Loading branch information
randy408 authored May 26, 2022
1 parent 39dbf50 commit 63f31c9
Showing 1 changed file with 10 additions and 1 deletion.
11 changes: 10 additions & 1 deletion test/fuzzer.c
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
if(data[size-1] != '\0') return 0;

const uint8_t* ptr = data;
utf8proc_int32_t c = 0;
utf8proc_int32_t c = 0, c_prev = 0, state = 0;
utf8proc_option_t options;
utf8proc_ssize_t ret, bytes = 0;
size_t len = strlen((const char*)data);
Expand All @@ -34,6 +34,11 @@ int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
utf8proc_category(c);
utf8proc_category_string(c);
utf8proc_codepoint_valid(c);

utf8proc_grapheme_break(c_prev, c);
utf8proc_grapheme_break_stateful(c_prev, c, &state);

c_prev = c;
}

utf8proc_int32_t *copy = size >= 4 ? NULL : malloc(size);
Expand All @@ -58,6 +63,10 @@ int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
memcpy(copy, data, size);
utf8proc_normalize_utf32(copy, size, options);

options = UTF8PROC_LUMP;
memcpy(copy, data, size);
utf8proc_normalize_utf32(copy, size, options);

options = 0;
memcpy(copy, data, size);
utf8proc_normalize_utf32(copy, size, options);
Expand Down

0 comments on commit 63f31c9

Please sign in to comment.