Skip to content

Commit

Permalink
[tests] Add knet_log_get_loglevel tests
Browse files Browse the repository at this point in the history
Signed-off-by: Fabio M. Di Nitto <fdinitto@redhat.com>
  • Loading branch information
fabbione committed Jun 26, 2016
1 parent 98b057d commit 24ba2c3
Show file tree
Hide file tree
Showing 2 changed files with 106 additions and 0 deletions.
4 changes: 4 additions & 0 deletions libknet/tests/Makefile.am
Expand Up @@ -40,6 +40,7 @@ check_PROGRAMS = \
api_knet_log_get_loglevel_name \
api_knet_log_get_loglevel_id \
api_knet_log_set_loglevel \
api_knet_log_get_loglevel \
timediff_test

noinst_PROGRAMS = \
Expand Down Expand Up @@ -104,6 +105,9 @@ api_knet_log_get_loglevel_id_SOURCES = api_knet_log_get_loglevel_id.c \
api_knet_log_set_loglevel_SOURCES = api_knet_log_set_loglevel.c \
test-common.c

api_knet_log_get_loglevel_SOURCES = api_knet_log_get_loglevel.c \
test-common.c

ping_test_SOURCES = ping_test.c

pckt_test_SOURCES = pckt_test.c
Expand Down
102 changes: 102 additions & 0 deletions libknet/tests/api_knet_log_get_loglevel.c
@@ -0,0 +1,102 @@
/*
* Copyright (C) 2016 Red Hat, Inc. All rights reserved.
*
* Authors: Fabio M. Di Nitto <fabbione@kronosnet.org>
*
* This software licensed under GPL-2.0+, LGPL-2.0+
*/

#include "config.h"

#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/time.h>
#include <sys/resource.h>

#include "libknet.h"
#include "internals.h"

#include "test-common.h"

static void test(void)
{
knet_handle_t knet_h;
uint8_t level;
int logfds[2];

printf("Test knet_log_get_loglevel incorrect knet_h\n");

if ((!knet_log_get_loglevel(NULL, KNET_SUB_LAST, &level)) || (errno != EINVAL)) {
printf("knet_log_get_loglevel accepted invalid knet_h or returned incorrect error: %s\n", strerror(errno));
exit(FAIL);
}

setup_logpipes(logfds);

printf("Test knet_log_get_loglevel incorrect subsystem\n");

knet_h = knet_handle_new(1, logfds[1], KNET_LOG_INFO);

if (!knet_h) {
printf("knet_handle_new failed: %s\n", strerror(errno));
flush_logs(logfds[0], stdout);
close_logpipes(logfds);
exit(FAIL);
}

if ((!knet_log_get_loglevel(knet_h, KNET_SUB_LAST + 1, &level)) || (errno != EINVAL)) {
printf("knet_log_get_loglevel accepted invalid subsystem or returned incorrect error: %s\n", strerror(errno));
knet_handle_free(knet_h);
flush_logs(logfds[0], stdout);
close_logpipes(logfds);
exit(FAIL);
}

flush_logs(logfds[0], stdout);

printf("Test knet_log_get_loglevel incorrect log level\n");

if ((!knet_log_get_loglevel(knet_h, KNET_SUB_LAST, NULL)) || (errno != EINVAL)) {
printf("knet_log_get_loglevel accepted invalid log level or returned incorrect error: %s\n", strerror(errno));
knet_handle_free(knet_h);
flush_logs(logfds[0], stdout);
close_logpipes(logfds);
exit(FAIL);
}

flush_logs(logfds[0], stdout);

printf("Test knet_log_get_loglevel with valid parameters\n");

if (knet_log_get_loglevel(knet_h, KNET_SUB_LAST, &level ) < 0) {
printf("knet_log_get_loglevel failed: %s\n", strerror(errno));
knet_handle_free(knet_h);
flush_logs(logfds[0], stdout);
close_logpipes(logfds);
exit(FAIL);
}

if (knet_h->log_levels[KNET_SUB_LAST] != level) {
printf("knet_log_get_loglevel failed to get the right value\n");
knet_handle_free(knet_h);
flush_logs(logfds[0], stdout);
close_logpipes(logfds);
exit(FAIL);
}

knet_handle_free(knet_h);
flush_logs(logfds[0], stdout);
close_logpipes(logfds);
}

int main(int argc, char *argv[])
{
need_root();

test();

return PASS;
}

0 comments on commit 24ba2c3

Please sign in to comment.