2 Fuzz cli_credentials_parse_string
3 Copyright (C) Catalyst IT 2020
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
19 #include "auth/credentials/credentials.h"
20 #include "fuzzing/fuzzing.h"
22 #define MAX_LENGTH (1024 * 10)
23 char buf
[MAX_LENGTH
+ 1];
25 const enum credentials_obtained obtained
= CRED_UNINITIALISED
;
28 int LLVMFuzzerTestOneInput(uint8_t *input
, size_t len
)
30 TALLOC_CTX
*mem_ctx
= NULL
;
31 struct cli_credentials
*credentials
= NULL
;
36 if (len
> MAX_LENGTH
) {
40 memcpy(buf
, input
, len
);
43 mem_ctx
= talloc_new(NULL
);
44 credentials
= cli_credentials_init(mem_ctx
);
46 cli_credentials_parse_string(credentials
, buf
, obtained
);
48 anon
= cli_credentials_is_anonymous(credentials
);
50 cli_credentials_get_ntlm_username_domain(credentials
,
60 int LLVMFuzzerInitialize(int *argc
, char ***argv
)