File: fuzz-main.c

package info (click to toggle)
casync 2%2B20201210-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye
  • size: 2,948 kB
  • sloc: ansic: 31,284; sh: 423; python: 69; makefile: 6
file content (48 lines) | stat: -rw-r--r-- 1,505 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/* SPDX-License-Identifier: LGPL-2.1+ */

#include <stddef.h>

#include "fuzz.h"
#include "util.h"

#define EXIT_TEST_SKIP 77

/* This is a test driver for fuzzers that provides a main function
 * for regression testing outside of oss-fuzz (https://github.com/google/oss-fuzz)
 *
 * It reads files named on the command line and passes them one by one
 * into the fuzzer that it is compiled into. */

/* This one was borrowed from
 * https://github.com/google/oss-fuzz/blob/646fca1b506b056db3a60d32c4a1a7398f171c94/infra/base-images/base-runner/bad_build_check#L19
 */

int main(int argc, char **argv) {
        int i;

        for (i = 1; i < argc; i++) {
                const char *name = argv[i];
                char buf[4096];
                ssize_t size;

                _cleanup_(safe_fclosep) FILE *f = fopen(name, "r");
                if (!f) {
                        log_error_errno(errno, "Failed to open %s: %m", name);
                        return EXIT_FAILURE;
                }

                size = fread(buf, 1, sizeof(buf), f);
                if (size < 0) {
                        log_error_errno(errno, "Failed to read %s: %m", name);
                        return EXIT_FAILURE;
                }

                printf("%s... ", name);
                fflush(stdout);
                if (LLVMFuzzerTestOneInput((uint8_t*)buf, size) == EXIT_TEST_SKIP)
                        return EXIT_TEST_SKIP;
                printf("ok\n");
        }

        return EXIT_SUCCESS;
}