2015-01-22 09:44:24 -08:00
|
|
|
/*
|
2018-02-23 09:53:12 +01:00
|
|
|
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
2015-01-22 09:44:24 -08:00
|
|
|
*
|
2016-06-27 14:56:38 +10:00
|
|
|
* 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/.
|
2018-02-23 09:53:12 +01:00
|
|
|
*
|
|
|
|
* See the COPYRIGHT file distributed with this work for additional
|
|
|
|
* information regarding copyright ownership.
|
2015-01-22 09:44:24 -08:00
|
|
|
*/
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
#if HAVE_CMOCKA
|
|
|
|
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <setjmp.h>
|
|
|
|
|
2015-01-22 09:44:24 -08:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
#define UNIT_TESTING
|
|
|
|
#include <cmocka.h>
|
2015-01-22 09:44:24 -08:00
|
|
|
|
2017-08-24 10:58:20 +05:30
|
|
|
#include <isc/file.h>
|
2015-01-22 09:44:24 -08:00
|
|
|
#include <isc/mem.h>
|
2015-05-23 14:21:51 +02:00
|
|
|
#include <isc/print.h>
|
2015-01-22 09:44:24 -08:00
|
|
|
#include <isc/result.h>
|
2017-08-24 10:58:20 +05:30
|
|
|
#include <isc/stdio.h>
|
2018-10-25 15:40:27 +08:00
|
|
|
#include <isc/util.h>
|
2015-01-22 09:44:24 -08:00
|
|
|
|
2018-10-03 19:04:46 -07:00
|
|
|
#include "../mem_p.h"
|
|
|
|
|
|
|
|
#include "isctest.h"
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
static int
|
|
|
|
_setup(void **state) {
|
|
|
|
isc_result_t result;
|
|
|
|
|
|
|
|
UNUSED(state);
|
|
|
|
|
|
|
|
result = isc_test_begin(NULL, true, 0);
|
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
|
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
|
2015-01-22 09:44:24 -08:00
|
|
|
static void *
|
|
|
|
default_memalloc(void *arg, size_t size) {
|
|
|
|
UNUSED(arg);
|
2018-10-25 15:40:27 +08:00
|
|
|
if (size == 0U) {
|
2015-01-22 09:44:24 -08:00
|
|
|
size = 1;
|
2018-10-25 15:40:27 +08:00
|
|
|
}
|
2015-01-22 09:44:24 -08:00
|
|
|
return (malloc(size));
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
default_memfree(void *arg, void *ptr) {
|
|
|
|
UNUSED(arg);
|
|
|
|
free(ptr);
|
|
|
|
}
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
static int
|
|
|
|
_teardown(void **state) {
|
|
|
|
UNUSED(state);
|
|
|
|
|
|
|
|
isc_test_end();
|
|
|
|
|
|
|
|
return (0);
|
2018-02-27 10:20:28 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#define MP1_FREEMAX 10
|
|
|
|
#define MP1_FILLCNT 10
|
|
|
|
#define MP1_MAXALLOC 30
|
|
|
|
|
|
|
|
#define MP2_FREEMAX 25
|
|
|
|
#define MP2_FILLCNT 25
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
/* general memory system tests */
|
|
|
|
static void
|
|
|
|
isc_mem_test(void **state) {
|
2018-02-27 10:20:28 -08:00
|
|
|
isc_result_t result;
|
|
|
|
void *items1[50];
|
|
|
|
void *items2[50];
|
|
|
|
void *tmp;
|
|
|
|
isc_mem_t *localmctx = NULL;
|
|
|
|
isc_mempool_t *mp1 = NULL, *mp2 = NULL;
|
|
|
|
unsigned int i, j;
|
|
|
|
int rval;
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
UNUSED(state);
|
2018-02-27 10:20:28 -08:00
|
|
|
|
|
|
|
result = isc_mem_create(0, 0, &localmctx);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2018-02-27 10:20:28 -08:00
|
|
|
|
|
|
|
result = isc_mempool_create(localmctx, 24, &mp1);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2018-02-27 10:20:28 -08:00
|
|
|
|
|
|
|
result = isc_mempool_create(localmctx, 31, &mp2);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2018-02-27 10:20:28 -08:00
|
|
|
|
|
|
|
isc_mempool_setfreemax(mp1, MP1_FREEMAX);
|
|
|
|
isc_mempool_setfillcount(mp1, MP1_FILLCNT);
|
|
|
|
isc_mempool_setmaxalloc(mp1, MP1_MAXALLOC);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Allocate MP1_MAXALLOC items from the pool. This is our max.
|
|
|
|
*/
|
|
|
|
for (i = 0; i < MP1_MAXALLOC; i++) {
|
|
|
|
items1[i] = isc_mempool_get(mp1);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(items1[i]);
|
2018-02-27 10:20:28 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Try to allocate one more. This should fail.
|
|
|
|
*/
|
|
|
|
tmp = isc_mempool_get(mp1);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_null(tmp);
|
2018-02-27 10:20:28 -08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Free the first 11 items. Verify that there are 10 free items on
|
|
|
|
* the free list (which is our max).
|
|
|
|
*/
|
|
|
|
for (i = 0; i < 11; i++) {
|
|
|
|
isc_mempool_put(mp1, items1[i]);
|
|
|
|
items1[i] = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
rval = isc_mempool_getfreecount(mp1);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(rval, 10);
|
2018-02-27 10:20:28 -08:00
|
|
|
|
|
|
|
rval = isc_mempool_getallocated(mp1);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(rval, 19);
|
2018-02-27 10:20:28 -08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Now, beat up on mp2 for a while. Allocate 50 items, then free
|
|
|
|
* them, then allocate 50 more, etc.
|
|
|
|
*/
|
|
|
|
|
|
|
|
isc_mempool_setfreemax(mp2, 25);
|
|
|
|
isc_mempool_setfillcount(mp2, 25);
|
|
|
|
|
|
|
|
for (j = 0; j < 500000; j++) {
|
|
|
|
for (i = 0; i < 50; i++) {
|
|
|
|
items2[i] = isc_mempool_get(mp2);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(items2[i]);
|
2018-02-27 10:20:28 -08:00
|
|
|
}
|
|
|
|
for (i = 0; i < 50; i++) {
|
|
|
|
isc_mempool_put(mp2, items2[i]);
|
|
|
|
items2[i] = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Free all the other items and blow away this pool.
|
|
|
|
*/
|
|
|
|
for (i = 11; i < MP1_MAXALLOC; i++) {
|
|
|
|
isc_mempool_put(mp1, items1[i]);
|
|
|
|
items1[i] = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
isc_mempool_destroy(&mp1);
|
|
|
|
isc_mempool_destroy(&mp2);
|
|
|
|
|
|
|
|
isc_mem_destroy(&localmctx);
|
|
|
|
|
2018-10-03 19:04:46 -07:00
|
|
|
result = isc_mem_createx(0, 0, default_memalloc, default_memfree,
|
|
|
|
NULL, &localmctx,
|
|
|
|
ISC_MEMFLAG_FILL | ISC_MEMFLAG_INTERNAL);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2018-08-14 17:13:20 +10:00
|
|
|
|
|
|
|
result = isc_mempool_create(localmctx, 2, &mp1);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2018-08-14 17:13:20 +10:00
|
|
|
|
|
|
|
tmp = isc_mempool_get(mp1);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(tmp);
|
2018-08-14 17:13:20 +10:00
|
|
|
|
|
|
|
isc_mempool_put(mp1, tmp);
|
|
|
|
|
|
|
|
isc_mempool_destroy(&mp1);
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
isc_mem_destroy(&localmctx);
|
2018-02-27 10:20:28 -08:00
|
|
|
|
2015-01-22 09:44:24 -08:00
|
|
|
}
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
/* test TotalUse calculation */
|
|
|
|
static void
|
|
|
|
isc_mem_total_test(void **state) {
|
2015-01-22 09:44:24 -08:00
|
|
|
isc_result_t result;
|
|
|
|
isc_mem_t *mctx2 = NULL;
|
|
|
|
size_t before, after;
|
|
|
|
ssize_t diff;
|
|
|
|
int i;
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
UNUSED(state);
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
/* Local alloc, free */
|
|
|
|
mctx2 = NULL;
|
2018-10-03 19:04:46 -07:00
|
|
|
result = isc_mem_createx(0, 0, default_memalloc, default_memfree,
|
|
|
|
NULL, &mctx2, 0);
|
2018-10-25 15:40:27 +08:00
|
|
|
if (result != ISC_R_SUCCESS) {
|
2015-01-22 09:44:24 -08:00
|
|
|
goto out;
|
2018-10-25 15:40:27 +08:00
|
|
|
}
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
before = isc_mem_total(mctx2);
|
|
|
|
|
|
|
|
for (i = 0; i < 100000; i++) {
|
|
|
|
void *ptr;
|
|
|
|
|
|
|
|
ptr = isc_mem_allocate(mctx2, 2048);
|
|
|
|
isc_mem_free(mctx2, ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
after = isc_mem_total(mctx2);
|
|
|
|
diff = after - before;
|
|
|
|
|
|
|
|
/* 2048 +8 bytes extra for size_info */
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(diff, (2048 + 8) * 100000);
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
/* ISC_MEMFLAG_INTERNAL */
|
|
|
|
|
|
|
|
before = isc_mem_total(mctx);
|
|
|
|
|
|
|
|
for (i = 0; i < 100000; i++) {
|
|
|
|
void *ptr;
|
|
|
|
|
|
|
|
ptr = isc_mem_allocate(mctx, 2048);
|
|
|
|
isc_mem_free(mctx, ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
after = isc_mem_total(mctx);
|
|
|
|
diff = after - before;
|
|
|
|
|
|
|
|
/* 2048 +8 bytes extra for size_info */
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(diff, (2048 + 8) * 100000);
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
out:
|
2018-10-25 15:40:27 +08:00
|
|
|
if (mctx2 != NULL) {
|
2015-01-22 09:44:24 -08:00
|
|
|
isc_mem_destroy(&mctx2);
|
2018-10-25 15:40:27 +08:00
|
|
|
}
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
/* test InUse calculation */
|
|
|
|
static void
|
|
|
|
isc_mem_inuse_test(void **state) {
|
2015-01-22 09:44:24 -08:00
|
|
|
isc_result_t result;
|
|
|
|
isc_mem_t *mctx2 = NULL;
|
2018-10-25 15:40:27 +08:00
|
|
|
size_t before, after;
|
2015-01-22 09:44:24 -08:00
|
|
|
ssize_t diff;
|
|
|
|
void *ptr;
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
UNUSED(state);
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
mctx2 = NULL;
|
2018-10-03 19:04:46 -07:00
|
|
|
result = isc_mem_createx(0, 0, default_memalloc, default_memfree,
|
|
|
|
NULL, &mctx2, 0);
|
2018-10-25 15:40:27 +08:00
|
|
|
if (result != ISC_R_SUCCESS) {
|
2015-01-22 09:44:24 -08:00
|
|
|
goto out;
|
2018-10-25 15:40:27 +08:00
|
|
|
}
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
before = isc_mem_inuse(mctx2);
|
|
|
|
ptr = isc_mem_allocate(mctx2, 1024000);
|
|
|
|
isc_mem_free(mctx2, ptr);
|
|
|
|
after = isc_mem_inuse(mctx2);
|
|
|
|
|
|
|
|
diff = after - before;
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(diff, 0);
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
out:
|
2018-10-25 15:40:27 +08:00
|
|
|
if (mctx2 != NULL) {
|
2015-01-22 09:44:24 -08:00
|
|
|
isc_mem_destroy(&mctx2);
|
2018-10-25 15:40:27 +08:00
|
|
|
}
|
2015-01-22 09:44:24 -08:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-08-24 10:58:20 +05:30
|
|
|
#if ISC_MEM_TRACKLINES
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
/* test mem with no flags */
|
|
|
|
static void
|
|
|
|
isc_mem_noflags_test(void **state) {
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_result_t result;
|
|
|
|
isc_mem_t *mctx2 = NULL;
|
|
|
|
char buf[4096], *p, *q;
|
|
|
|
FILE *f;
|
|
|
|
void *ptr;
|
|
|
|
|
|
|
|
result = isc_stdio_open("mem.output", "w", &f);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2017-08-24 10:58:20 +05:30
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
UNUSED(state);
|
2017-08-24 10:58:20 +05:30
|
|
|
|
2018-10-03 19:04:46 -07:00
|
|
|
result = isc_mem_createx(0, 0, default_memalloc, default_memfree,
|
|
|
|
NULL, &mctx2, 0);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_mem_debugging = 0;
|
|
|
|
ptr = isc_mem_get(mctx2, 2048);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(ptr);
|
2018-10-03 19:04:46 -07:00
|
|
|
isc__mem_printactive(mctx2, f);
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_mem_put(mctx2, ptr, 2048);
|
|
|
|
isc_mem_destroy(&mctx2);
|
|
|
|
isc_stdio_close(f);
|
|
|
|
|
2017-10-19 13:08:31 +11:00
|
|
|
memset(buf, 0, sizeof(buf));
|
2017-08-24 10:58:20 +05:30
|
|
|
result = isc_stdio_open("mem.output", "r", &f);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2017-10-19 13:08:31 +11:00
|
|
|
result = isc_stdio_read(buf, sizeof(buf), 1, f, NULL);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_EOF);
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_stdio_close(f);
|
|
|
|
isc_file_remove("mem.output");
|
|
|
|
|
2017-10-19 13:08:31 +11:00
|
|
|
buf[sizeof(buf) - 1] = 0;
|
|
|
|
|
2017-08-24 10:58:20 +05:30
|
|
|
p = strchr(buf, '\n');
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(p);
|
|
|
|
assert_in_range(p, 0, buf + sizeof(buf) - 3);
|
2017-08-24 10:58:20 +05:30
|
|
|
p += 2;
|
|
|
|
q = strchr(p, '\n');
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(q);
|
2017-08-24 10:58:20 +05:30
|
|
|
*q = '\0';
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_string_equal(p, "None.");
|
2017-08-24 10:58:20 +05:30
|
|
|
|
|
|
|
isc_mem_debugging = ISC_MEM_DEBUGRECORD;
|
|
|
|
}
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
/* test mem with record flag */
|
|
|
|
static void
|
|
|
|
isc_mem_recordflag_test(void **state) {
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_result_t result;
|
|
|
|
isc_mem_t *mctx2 = NULL;
|
|
|
|
char buf[4096], *p;
|
|
|
|
FILE *f;
|
|
|
|
void *ptr;
|
|
|
|
|
|
|
|
result = isc_stdio_open("mem.output", "w", &f);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2017-08-24 10:58:20 +05:30
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
UNUSED(state);
|
2017-08-24 10:58:20 +05:30
|
|
|
|
2018-10-03 19:04:46 -07:00
|
|
|
result = isc_mem_createx(0, 0, default_memalloc, default_memfree,
|
|
|
|
NULL, &mctx2, 0);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2017-08-24 10:58:20 +05:30
|
|
|
ptr = isc_mem_get(mctx2, 2048);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(ptr);
|
2018-10-03 19:04:46 -07:00
|
|
|
isc__mem_printactive(mctx2, f);
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_mem_put(mctx2, ptr, 2048);
|
|
|
|
isc_mem_destroy(&mctx2);
|
|
|
|
isc_stdio_close(f);
|
|
|
|
|
2017-08-30 19:02:52 -07:00
|
|
|
memset(buf, 0, sizeof(buf));
|
2017-08-24 10:58:20 +05:30
|
|
|
result = isc_stdio_open("mem.output", "r", &f);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2017-10-19 13:08:31 +11:00
|
|
|
result = isc_stdio_read(buf, sizeof(buf), 1, f, NULL);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_EOF);
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_stdio_close(f);
|
|
|
|
isc_file_remove("mem.output");
|
|
|
|
|
2017-10-19 13:08:31 +11:00
|
|
|
buf[sizeof(buf) - 1] = 0;
|
|
|
|
|
2017-08-24 10:58:20 +05:30
|
|
|
p = strchr(buf, '\n');
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(p);
|
|
|
|
assert_in_range(p, 0, buf + sizeof(buf) - 3);
|
|
|
|
assert_memory_equal(p + 2, "ptr ", 4);
|
2017-08-24 10:58:20 +05:30
|
|
|
p = strchr(p + 1, '\n');
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(p);
|
|
|
|
assert_int_equal(strlen(p), 1);
|
2017-08-24 10:58:20 +05:30
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
/* test mem with trace flag */
|
|
|
|
static void
|
|
|
|
isc_mem_traceflag_test(void **state) {
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_result_t result;
|
|
|
|
isc_mem_t *mctx2 = NULL;
|
|
|
|
char buf[4096], *p;
|
|
|
|
FILE *f;
|
|
|
|
void *ptr;
|
|
|
|
|
|
|
|
/* redirect stderr so we can check trace output */
|
|
|
|
f = freopen("mem.output", "w", stderr);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(f);
|
2017-08-24 10:58:20 +05:30
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
UNUSED(state);
|
2017-08-24 10:58:20 +05:30
|
|
|
|
2018-10-03 19:04:46 -07:00
|
|
|
result = isc_mem_createx(0, 0, default_memalloc, default_memfree,
|
|
|
|
NULL, &mctx2, 0);
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_mem_debugging = ISC_MEM_DEBUGTRACE;
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2017-08-24 10:58:20 +05:30
|
|
|
ptr = isc_mem_get(mctx2, 2048);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(ptr);
|
2018-10-03 19:04:46 -07:00
|
|
|
isc__mem_printactive(mctx2, f);
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_mem_put(mctx2, ptr, 2048);
|
|
|
|
isc_mem_destroy(&mctx2);
|
|
|
|
isc_stdio_close(f);
|
|
|
|
|
2017-10-19 13:08:31 +11:00
|
|
|
memset(buf, 0, sizeof(buf));
|
2017-08-24 10:58:20 +05:30
|
|
|
result = isc_stdio_open("mem.output", "r", &f);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
2017-10-19 13:08:31 +11:00
|
|
|
result = isc_stdio_read(buf, sizeof(buf), 1, f, NULL);
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_int_equal(result, ISC_R_EOF);
|
2017-08-24 10:58:20 +05:30
|
|
|
isc_stdio_close(f);
|
|
|
|
isc_file_remove("mem.output");
|
|
|
|
|
|
|
|
/* return stderr to TTY so we can see errors */
|
|
|
|
f = freopen("/dev/tty", "w", stderr);
|
|
|
|
|
2017-10-19 13:08:31 +11:00
|
|
|
buf[sizeof(buf) - 1] = 0;
|
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_memory_equal(buf, "add ", 4);
|
2017-08-24 10:58:20 +05:30
|
|
|
p = strchr(buf, '\n');
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(p);
|
2017-08-24 10:58:20 +05:30
|
|
|
p = strchr(p + 1, '\n');
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(p);
|
|
|
|
assert_in_range(p, 0, buf + sizeof(buf) - 3);
|
|
|
|
assert_memory_equal(p + 2, "ptr ", 4);
|
2017-08-24 10:58:20 +05:30
|
|
|
p = strchr(p + 1, '\n');
|
2018-10-25 15:40:27 +08:00
|
|
|
assert_non_null(p);
|
|
|
|
assert_memory_equal(p + 1, "del ", 4);
|
2017-08-24 10:58:20 +05:30
|
|
|
|
|
|
|
isc_mem_debugging = ISC_MEM_DEBUGRECORD;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-01-22 09:44:24 -08:00
|
|
|
/*
|
|
|
|
* Main
|
|
|
|
*/
|
2018-10-25 15:40:27 +08:00
|
|
|
|
|
|
|
int
|
|
|
|
main(void) {
|
|
|
|
const struct CMUnitTest tests[] = {
|
|
|
|
cmocka_unit_test_setup_teardown(isc_mem_test,
|
|
|
|
_setup, _teardown),
|
|
|
|
cmocka_unit_test_setup_teardown(isc_mem_total_test,
|
|
|
|
_setup, _teardown),
|
|
|
|
cmocka_unit_test_setup_teardown(isc_mem_inuse_test,
|
|
|
|
_setup, _teardown),
|
|
|
|
|
2017-08-24 10:58:20 +05:30
|
|
|
#if ISC_MEM_TRACKLINES
|
2018-10-25 15:40:27 +08:00
|
|
|
cmocka_unit_test_setup_teardown(isc_mem_noflags_test,
|
|
|
|
_setup, _teardown),
|
|
|
|
cmocka_unit_test_setup_teardown(isc_mem_recordflag_test,
|
|
|
|
_setup, _teardown),
|
|
|
|
cmocka_unit_test_setup_teardown(isc_mem_traceflag_test,
|
|
|
|
_setup, _teardown),
|
2017-08-24 10:58:20 +05:30
|
|
|
#endif
|
2018-10-25 15:40:27 +08:00
|
|
|
};
|
2015-01-22 09:44:24 -08:00
|
|
|
|
2018-10-25 15:40:27 +08:00
|
|
|
return (cmocka_run_group_tests(tests, NULL, NULL));
|
2015-01-22 09:44:24 -08:00
|
|
|
}
|
2018-10-25 15:40:27 +08:00
|
|
|
|
|
|
|
#else /* HAVE_CMOCKA */
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void) {
|
|
|
|
printf("1..0 # Skipped: cmocka not available\n");
|
|
|
|
return (0);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|