1
1
libssh/tests/fuzz/ssh_bind_config_fuzzer.c
Jakub Jelen 314c57d414 fuzz: Get rid of cpp mess in fuzzers
Signed-off-by: Jakub Jelen <jjelen@redhat.com>
Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
2022-02-08 19:13:45 +01:00

53 строки
1.2 KiB
C

/*
* Copyright 2021 Jakub Jelen <jjelen@redhat.com>
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define LIBSSH_STATIC 1
#include "libssh/libssh.h"
#include "libssh/server.h"
#include "libssh/bind_config.h"
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
{
ssh_bind bind = NULL;
char *input = NULL;
input = (char *)malloc(size + 1);
if (!input) {
return 1;
}
strncpy(input, (const char *)data, size);
input[size] = '\0';
ssh_init();
bind = ssh_bind_new();
assert(bind != NULL);
ssh_bind_config_parse_string(bind, input);
ssh_bind_free(bind);
ssh_finalize();
free(input);
return 0;
}