bind9/lib/dns/tests/tkey_test.c
Michał Kępień 154f2ca6f6 Tweak lib/dns/tests/tkey_test requirements
Currently, the lib/dns/tests/tkey_test unit test is only run when the
linker supports the --wrap option.  However, linker support for that
option is only needed for static builds.  As a result, the unit test
mentioned before is not being run everywhere it can be run as even for
builds done using --with-libtool, the test is not run unless the linker
supports the --wrap option.

Tweak preprocessor directives in lib/dns/tests/tkey_test.c so that this
test is run:

  - for all builds using --with-libtool,
  - for static builds done using a linker supporting the --wrap option.
2019-09-12 14:25:57 +02:00

205 lines
4.4 KiB
C

/*
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* See the COPYRIGHT file distributed with this work for additional
* information regarding copyright ownership.
*/
#if HAVE_CMOCKA
#include <stdarg.h>
#include <stddef.h>
#include <setjmp.h>
#include <sched.h> /* IWYU pragma: keep */
#include <stdbool.h>
#include <stdlib.h>
#include <cmocka.h>
#include <isc/mem.h>
#include <isc/result.h>
#include <isc/util.h>
#include <dns/tkey.h>
#if defined(USE_LIBTOOL) || LD_WRAP
static isc_mem_t mock_mctx = {
.impmagic = 0,
.magic = ISCAPI_MCTX_MAGIC,
.methods = NULL
};
void *
__wrap_isc__mem_get(isc_mem_t *mctx, size_t size);
void
__wrap_isc__mem_put(isc_mem_t *ctx0, void *ptr, size_t size);
void
__wrap_isc_mem_attach(isc_mem_t *source0, isc_mem_t **targetp);
void
__wrap_isc_mem_detach(isc_mem_t **ctxp);
void
__wrap_isc__mem_putanddetach(isc_mem_t **ctxp, void *ptr, size_t size);
void *
__wrap_isc__mem_get(isc_mem_t *mctx, size_t size)
{
bool has_enough_memory = mock_type(bool);
UNUSED(mctx);
mock_assert(has_enough_memory, "mock isc_mem_get failed",
__FILE__, __LINE__);
/* cppcheck-suppress leakNoVarFunctionCall */
return (malloc(size));
}
void
__wrap_isc__mem_put(isc_mem_t *ctx0, void *ptr, size_t size) {
UNUSED(ctx0);
UNUSED(size);
free(ptr);
}
void
__wrap_isc_mem_attach(isc_mem_t *source0, isc_mem_t **targetp) {
*targetp = source0;
}
void
__wrap_isc_mem_detach(isc_mem_t **ctxp) {
*ctxp = NULL;
}
void
__wrap_isc__mem_putanddetach(isc_mem_t **ctxp, void *ptr, size_t size) {
isc_mem_t *ctx = *ctxp;
__wrap_isc__mem_put(ctx, ptr, size);
__wrap_isc_mem_detach(ctxp);
}
#ifdef USE_LIBTOOL
#if ISC_MEM_TRACKLINES
#define FLARG , const char *file, unsigned int line
#else
#define FLARG
#endif
void *
isc__mem_get(isc_mem_t *mctx, size_t size FLARG)
{
UNUSED(file);
UNUSED(line);
return (__wrap_isc__mem_get(mctx, size));
}
void
isc__mem_put(isc_mem_t *ctx0, void *ptr, size_t size FLARG)
{
UNUSED(file);
UNUSED(line);
__wrap_isc__mem_put(ctx0, ptr, size);
}
void
isc_mem_attach(isc_mem_t *source0, isc_mem_t **targetp) {
__wrap_isc_mem_attach(source0, targetp);
}
void
isc_mem_detach(isc_mem_t **ctxp) {
__wrap_isc_mem_detach(ctxp);
}
void
isc__mem_putanddetach(isc_mem_t **ctxp, void *ptr, size_t size FLARG){
UNUSED(file);
UNUSED(line);
__wrap_isc__mem_putanddetach(ctxp, ptr, size);
}
#endif /* USE_LIBTOOL */
static int
_setup(void **state) {
dns_tkeyctx_t *tctx = NULL;
will_return(__wrap_isc__mem_get, true);
if (dns_tkeyctx_create(&mock_mctx, &tctx) != ISC_R_SUCCESS) {
return (-1);
}
*state = tctx;
return (0);
}
static int
_teardown(void **state) {
dns_tkeyctx_t *tctx = *state;
if (tctx != NULL) {
dns_tkeyctx_destroy(&tctx);
}
return (0);
}
static void
dns_tkeyctx_create_test(void **state) {
dns_tkeyctx_t *tctx;
tctx = NULL;
will_return(__wrap_isc__mem_get, false);
expect_assert_failure(dns_tkeyctx_create(&mock_mctx, &tctx));
tctx = NULL;
will_return(__wrap_isc__mem_get, true);
assert_int_equal(dns_tkeyctx_create(&mock_mctx, &tctx),
ISC_R_SUCCESS);
*state = tctx;
}
static void
dns_tkeyctx_destroy_test(void **state) {
dns_tkeyctx_t *tctx = *state;
assert_non_null(tctx);
dns_tkeyctx_destroy(&tctx);
}
#endif /* defined(USE_LIBTOOL) || LD_WRAP */
int
main(void) {
#if defined(USE_LIBTOOL) || LD_WRAP
const struct CMUnitTest tkey_tests[] = {
cmocka_unit_test_teardown(dns_tkeyctx_create_test, _teardown),
cmocka_unit_test_setup(dns_tkeyctx_destroy_test, _setup),
#if 0 /* not yet */
cmocka_unit_test(dns_tkey_processquery_test),
cmocka_unit_test(dns_tkey_builddhquery_test),
cmocka_unit_test(dns_tkey_buildgssquery_test),
cmocka_unit_test(dns_tkey_builddeletequery_test),
cmocka_unit_test(dns_tkey_processdhresponse_test),
cmocka_unit_test(dns_tkey_processgssresponse_test),
cmocka_unit_test(dns_tkey_processdeleteresponse_test),
cmocka_unit_test(dns_tkey_gssnegotiate_test),
#endif
};
return (cmocka_run_group_tests(tkey_tests, NULL, NULL));
#else /* defined(USE_LIBTOOL) || LD_WRAP */
print_message("1..0 # Skip tkey_test requires libtool or LD_WRAP\n");
#endif /* defined(USE_LIBTOOL) || LD_WRAP */
}
#else /* CMOCKA */
#include <stdio.h>
int
main(void) {
printf("1..0 # Skipped: cmocka not available\n");
return (0);
}
#endif /* CMOCKA */