/src/liblouis/tests/fuzzing/fuzz_backtranslate.c
Line | Count | Source (jump to first uncovered line) |
1 | | // |
2 | | // liblouis Braille Translation and Back-Translation Library |
3 | | // |
4 | | // Copyright (C) 2023 Anna Stan, Nicolas Morel, Kalilou Mamadou Dramé |
5 | | // |
6 | | // This file is part of liblouis. |
7 | | // |
8 | | // liblouis is free software: you can redistribute it and/or modify it |
9 | | // under the terms of the GNU Lesser General Public License as published |
10 | | // by the Free Software Foundation, either version 2.1 of the License, or |
11 | | // (at your option) any later version. |
12 | | // |
13 | | // liblouis is distributed in the hope that it will be useful, but |
14 | | // WITHOUT ANY WARRANTY; without even the implied warranty of |
15 | | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
16 | | // Lesser General Public License for more details. |
17 | | // |
18 | | // You should have received a copy of the GNU Lesser General Public |
19 | | // License along with liblouis. If not, see <http://www.gnu.org/licenses/>. |
20 | | // |
21 | | |
22 | | #include <config.h> |
23 | | |
24 | | #include <assert.h> |
25 | | #include <fcntl.h> |
26 | | #include <internal.h> |
27 | | #include <liblouis.h> |
28 | | #include <stdint.h> |
29 | | #include <stdio.h> |
30 | | #include <stdlib.h> |
31 | | #include <string.h> |
32 | | #include <unistd.h> |
33 | | |
34 | | #define LANGUAGE "en" |
35 | | |
36 | | static int initialized = 0; |
37 | | |
38 | | #define BOLDRED(x) "\x1b[31m\x1b[1m" x "\x1b[0m" |
39 | | |
40 | | static const char *table_default; |
41 | | |
42 | 0 | static void __attribute__((destructor)) free_ressources(void) { lou_free(); } |
43 | | |
44 | 264k | void avoid_log(logLevels level, const char *msg) { |
45 | 264k | (void)level; |
46 | 264k | (void)msg; |
47 | 264k | } |
48 | | |
49 | | extern int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size); |
50 | | |
51 | 505 | int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) { |
52 | 505 | int inputLen = 0; |
53 | 505 | int outputLen = 0; |
54 | 505 | static int counter = 0; |
55 | 505 | if (!initialized) { |
56 | 2 | lou_registerLogCallback(avoid_log); |
57 | 2 | initialized = 1; |
58 | 2 | } |
59 | | |
60 | 505 | if (size < 512) { |
61 | 0 | return 0; |
62 | 0 | } |
63 | | |
64 | | // Write first half of fuzz data to a table file. |
65 | 505 | char new_file[256]; |
66 | 505 | sprintf(new_file, "/tmp/libfuzzer-%d.ctb", counter); |
67 | 505 | counter++; |
68 | | |
69 | 505 | FILE *fp = fopen(new_file, "wb"); |
70 | 505 | if (!fp) { |
71 | 0 | return 0; |
72 | 0 | } |
73 | 505 | fwrite(data, 512, 1, fp); |
74 | 505 | fclose(fp); |
75 | | |
76 | | // Adjust data pointer to after the table file data. |
77 | 505 | data += 512; |
78 | 505 | size -= 512; |
79 | | |
80 | | /* check if this works, otherwise bail */ |
81 | 505 | if (lou_checkTable(new_file) == 0) { |
82 | 55 | lou_free(); |
83 | 55 | unlink(new_file); |
84 | 55 | return 0; |
85 | 55 | } |
86 | 450 | char *mutable_data = NULL; |
87 | 450 | table_default = new_file; |
88 | | |
89 | 450 | mutable_data = strndup((char *)data, size); |
90 | 450 | if (!mutable_data) { |
91 | 0 | perror("malloc"); |
92 | 0 | exit(1); |
93 | 0 | } |
94 | | |
95 | 450 | widechar *inputText = malloc((size * 16 + 1) * sizeof(widechar)); |
96 | 450 | int len = (int)_lou_extParseChars(mutable_data, inputText); |
97 | 450 | free(mutable_data); |
98 | 450 | if (len <= 0) { |
99 | 15 | free(inputText); |
100 | 15 | unlink(new_file); |
101 | 15 | lou_free(); |
102 | 15 | return -1; |
103 | 15 | } |
104 | | |
105 | 435 | assert(len <= (size * 16)); |
106 | 435 | inputLen = len; |
107 | 435 | outputLen = len * 16; |
108 | 435 | widechar *outputText = malloc((outputLen + 1) * sizeof(widechar)); |
109 | | |
110 | 435 | lou_backTranslateString(table_default, inputText, &inputLen, outputText, |
111 | 435 | &outputLen, NULL, NULL, ucBrl); |
112 | | |
113 | 435 | free(inputText); |
114 | 435 | free(outputText); |
115 | | |
116 | 435 | lou_free(); |
117 | 435 | unlink(new_file); |
118 | | |
119 | 435 | return 0; |
120 | 435 | } |