1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
/***************************************************************************
*
* Copyright (C) 2018-2025 - ZmartZone Holding BV
*
* 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.
*
* @Author: Hans Zandbelt - hans.zandbelt@openidc.com
*
**************************************************************************/
#include "check_liboauth2.h"
#include "oauth2/log.h"
#include <check.h>
#include <stdlib.h>
static oauth2_log_t *_log = 0;
static void setup(void)
{
// for coverage
oauth2_log_free(NULL);
_log = oauth2_log_init(OAUTH2_LOG_TRACE1, 0);
}
static void teardown(void)
{
oauth2_log_free(_log);
}
START_TEST(test_log)
{
// mostly to complete coverage
// TODO: could return bytes written from oauth2_log statements
oauth2_debug(NULL, NULL);
// TOOD: could return bool from oauth2_log_sink_add
oauth2_log_sink_add(_log, &oauth2_log_sink_stderr);
oauth2_info(_log, NULL);
oauth2_info(_log, "");
oauth2_log_sink_level_set(&oauth2_log_sink_stderr, OAUTH2_LOG_ERROR);
}
END_TEST
static int check_log_test_sink_callback_dummy = 0;
static void
check_log_test_sink_callback(oauth2_log_sink_t *sink, const char *filename,
unsigned long line, const char *function,
oauth2_log_level_t level, const char *msg)
{
check_log_test_sink_callback_dummy = 1;
}
START_TEST(test_sink)
{
char *dummy = "dummy";
oauth2_log_sink_t *sink = oauth2_log_sink_create(
OAUTH2_LOG_TRACE1, check_log_test_sink_callback, dummy);
oauth2_log_sink_add(_log, sink);
ck_assert_ptr_eq(oauth2_log_sink_callback_get(sink),
check_log_test_sink_callback);
ck_assert_ptr_eq(oauth2_log_sink_ctx_get(sink), dummy);
check_log_test_sink_callback_dummy = 0;
oauth2_info(_log, "");
ck_assert_int_eq(check_log_test_sink_callback_dummy, 1);
}
END_TEST
Suite *oauth2_check_log_suite()
{
Suite *s = suite_create("log");
TCase *c = tcase_create("core");
tcase_add_checked_fixture(c, setup, teardown);
tcase_add_test(c, test_log);
tcase_add_test(c, test_sink);
suite_add_tcase(s, c);
return s;
}
|