fuzzing: Add fuzz tests for GUri parsing and escaping

Signed-off-by: Philip Withnall <withnall@endlessm.com>

Helps: #110
This commit is contained in:
Philip Withnall
2020-06-19 11:54:41 +01:00
committed by Marc-André Lureau
parent d83d68d64c
commit dd11160f7f
4 changed files with 78 additions and 0 deletions

29
fuzzing/fuzz_uri_escape.c Normal file
View File

@@ -0,0 +1,29 @@
#include "fuzz.h"
int
LLVMFuzzerTestOneInput (const unsigned char *data, size_t size)
{
GBytes *unescaped_bytes = NULL;
gchar *escaped_string = NULL;
fuzz_set_logging_func ();
if (size > G_MAXSSIZE)
return 0;
unescaped_bytes = g_uri_unescape_bytes ((const gchar *) data, (gssize) size);
if (unescaped_bytes == NULL)
return 0;
escaped_string = g_uri_escape_bytes (g_bytes_get_data (unescaped_bytes, NULL),
g_bytes_get_size (unescaped_bytes),
NULL);
g_bytes_unref (unescaped_bytes);
if (escaped_string == NULL)
return 0;
g_free (escaped_string);
return 0;
}