s3:tests: let test_smbXsrv_client_dead_rec.sh cleanup the correct files
[Samba.git] / lib / fuzzing / fuzz_cli_credentials_parse_string.c
blobb71ef357309bd6ed119c67c4b989781934abb4d7
1 /*
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/>.
18 #include "includes.h"
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;
32 bool anon;
33 const char *username;
34 const char *domain;
36 if (len > MAX_LENGTH) {
37 return 0;
40 memcpy(buf, input, len);
41 buf[len] = '\0';
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,
51 mem_ctx,
52 &username,
53 &domain);
55 talloc_free(mem_ctx);
56 return 0;
60 int LLVMFuzzerInitialize(int *argc, char ***argv)
62 return 0;