diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 14:07:11 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 14:07:11 +0000 |
commit | 63847496f14c813a5d80efd5b7de0f1294ffe1e3 (patch) | |
tree | 01c7571c7c762ceee70638549a99834fdd7c411b /test/ossshell.c | |
parent | Initial commit. (diff) | |
download | sqlite3-63847496f14c813a5d80efd5b7de0f1294ffe1e3.tar.xz sqlite3-63847496f14c813a5d80efd5b7de0f1294ffe1e3.zip |
Adding upstream version 3.45.1.upstream/3.45.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'test/ossshell.c')
-rw-r--r-- | test/ossshell.c | 100 |
1 files changed, 100 insertions, 0 deletions
diff --git a/test/ossshell.c b/test/ossshell.c new file mode 100644 index 0000000..54849f9 --- /dev/null +++ b/test/ossshell.c @@ -0,0 +1,100 @@ +/* +** This is a test interface for the ossfuzz.c module. The ossfuzz.c module +** is an adaptor for OSS-FUZZ. (https://github.com/google/oss-fuzz) +** +** This program links against ossfuzz.c. It reads files named on the +** command line and passes them one by one into ossfuzz.c. +*/ +#include <stddef.h> +#if !defined(_MSC_VER) +# include <stdint.h> +#endif +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include "sqlite3.h" + +#if defined(_MSC_VER) +typedef unsigned char uint8_t; +#endif + +/* +** The entry point in ossfuzz.c that this routine will be calling +*/ +int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size); + +/* Must match equivalent #defines in ossfuzz.c */ +#define FUZZ_SQL_TRACE 0x0001 /* Set an sqlite3_trace() callback */ +#define FUZZ_SHOW_MAX_DELAY 0x0002 /* Show maximum progress callback delay */ +#define FUZZ_SHOW_ERRORS 0x0004 /* Show SQL errors */ +extern void ossfuzz_set_debug_flags(unsigned); + + + +/* +** Read files named on the command-line and invoke the fuzzer for +** each one. +*/ +int main(int argc, char **argv){ + FILE *in; + int i; + int nErr = 0; + uint8_t *zBuf = 0; + size_t sz; + unsigned mDebug = 0; + + for(i=1; i<argc; i++){ + const char *zFilename = argv[i]; + if( zFilename[0]=='-' ){ + if( zFilename[1]=='-' ) zFilename++; + if( strcmp(zFilename, "-show-errors")==0 ){ + mDebug |= FUZZ_SHOW_ERRORS; + ossfuzz_set_debug_flags(mDebug); + }else + if( strcmp(zFilename, "-show-max-delay")==0 ){ + mDebug |= FUZZ_SHOW_MAX_DELAY; + ossfuzz_set_debug_flags(mDebug); + }else + if( strcmp(zFilename, "-sql-trace")==0 ){ + mDebug |= FUZZ_SQL_TRACE; + ossfuzz_set_debug_flags(mDebug); + }else + { + printf("unknown option \"%s\"\n", argv[i]); + printf("should be one of: --show-errors --show-max-delay" + " --sql-trace\n"); + exit(1); + } + continue; + } + in = fopen(zFilename, "rb"); + if( in==0 ){ + fprintf(stderr, "cannot open \"%s\"\n", zFilename); + nErr++; + continue; + } + fseek(in, 0, SEEK_END); + sz = ftell(in); + rewind(in); + zBuf = realloc(zBuf, sz); + if( zBuf==0 ){ + fprintf(stderr, "cannot malloc() for %d bytes\n", (int)sz); + exit(1); + } + if( fread(zBuf, sz, 1, in)!=1 ){ + fprintf(stderr, "cannot read %d bytes from \"%s\"\n", + (int)sz, zFilename); + nErr++; + }else{ + printf("%s... ", zFilename); + if( mDebug ) printf("\n"); + fflush(stdout); + (void)LLVMFuzzerTestOneInput(zBuf, sz); + if( mDebug ) printf("%s: ", zFilename); + printf("ok\n"); + } + fclose(in); + } + free(zBuf); + return nErr; +} |