redict/deps/jemalloc/test/unit/prof_thread_name.c

121 lines
3.1 KiB
C
Raw Normal View History

2015-10-06 10:18:30 -04:00
#include "test/jemalloc_test.h"
static void
mallctl_thread_name_get_impl(const char *thread_name_expected, const char *func,
2018-05-24 11:17:37 -04:00
int line) {
2015-10-06 10:18:30 -04:00
const char *thread_name_old;
size_t sz;
sz = sizeof(thread_name_old);
2018-05-24 11:17:37 -04:00
assert_d_eq(mallctl("thread.prof.name", (void *)&thread_name_old, &sz,
NULL, 0), 0,
"%s():%d: Unexpected mallctl failure reading thread.prof.name",
2015-10-06 10:18:30 -04:00
func, line);
assert_str_eq(thread_name_old, thread_name_expected,
"%s():%d: Unexpected thread.prof.name value", func, line);
}
2018-05-24 11:17:37 -04:00
#define mallctl_thread_name_get(a) \
2015-10-06 10:18:30 -04:00
mallctl_thread_name_get_impl(a, __func__, __LINE__)
static void
mallctl_thread_name_set_impl(const char *thread_name, const char *func,
2018-05-24 11:17:37 -04:00
int line) {
assert_d_eq(mallctl("thread.prof.name", NULL, NULL,
(void *)&thread_name, sizeof(thread_name)), 0,
2015-10-06 10:18:30 -04:00
"%s():%d: Unexpected mallctl failure reading thread.prof.name",
func, line);
mallctl_thread_name_get_impl(thread_name, func, line);
}
2018-05-24 11:17:37 -04:00
#define mallctl_thread_name_set(a) \
2015-10-06 10:18:30 -04:00
mallctl_thread_name_set_impl(a, __func__, __LINE__)
2018-05-24 11:17:37 -04:00
TEST_BEGIN(test_prof_thread_name_validation) {
2015-10-06 10:18:30 -04:00
const char *thread_name;
test_skip_if(!config_prof);
mallctl_thread_name_get("");
mallctl_thread_name_set("hi there");
/* NULL input shouldn't be allowed. */
thread_name = NULL;
2018-05-24 11:17:37 -04:00
assert_d_eq(mallctl("thread.prof.name", NULL, NULL,
(void *)&thread_name, sizeof(thread_name)), EFAULT,
2015-10-06 10:18:30 -04:00
"Unexpected mallctl result writing \"%s\" to thread.prof.name",
thread_name);
/* '\n' shouldn't be allowed. */
thread_name = "hi\nthere";
2018-05-24 11:17:37 -04:00
assert_d_eq(mallctl("thread.prof.name", NULL, NULL,
(void *)&thread_name, sizeof(thread_name)), EFAULT,
2015-10-06 10:18:30 -04:00
"Unexpected mallctl result writing \"%s\" to thread.prof.name",
thread_name);
/* Simultaneous read/write shouldn't be allowed. */
{
const char *thread_name_old;
size_t sz;
sz = sizeof(thread_name_old);
2018-05-24 11:17:37 -04:00
assert_d_eq(mallctl("thread.prof.name",
(void *)&thread_name_old, &sz, (void *)&thread_name,
sizeof(thread_name)), EPERM,
2015-10-06 10:18:30 -04:00
"Unexpected mallctl result writing \"%s\" to "
"thread.prof.name", thread_name);
}
mallctl_thread_name_set("");
}
TEST_END
2018-05-24 11:17:37 -04:00
#define NTHREADS 4
#define NRESET 25
2015-10-06 10:18:30 -04:00
static void *
2018-05-24 11:17:37 -04:00
thd_start(void *varg) {
2015-10-06 10:18:30 -04:00
unsigned thd_ind = *(unsigned *)varg;
char thread_name[16] = "";
unsigned i;
malloc_snprintf(thread_name, sizeof(thread_name), "thread %u", thd_ind);
mallctl_thread_name_get("");
mallctl_thread_name_set(thread_name);
for (i = 0; i < NRESET; i++) {
assert_d_eq(mallctl("prof.reset", NULL, NULL, NULL, 0), 0,
"Unexpected error while resetting heap profile data");
mallctl_thread_name_get(thread_name);
}
mallctl_thread_name_set(thread_name);
mallctl_thread_name_set("");
2018-05-24 11:17:37 -04:00
return NULL;
2015-10-06 10:18:30 -04:00
}
2018-05-24 11:17:37 -04:00
TEST_BEGIN(test_prof_thread_name_threaded) {
2015-10-06 10:18:30 -04:00
thd_t thds[NTHREADS];
unsigned thd_args[NTHREADS];
unsigned i;
test_skip_if(!config_prof);
for (i = 0; i < NTHREADS; i++) {
thd_args[i] = i;
thd_create(&thds[i], thd_start, (void *)&thd_args[i]);
}
2018-05-24 11:17:37 -04:00
for (i = 0; i < NTHREADS; i++) {
2015-10-06 10:18:30 -04:00
thd_join(thds[i], NULL);
2018-05-24 11:17:37 -04:00
}
2015-10-06 10:18:30 -04:00
}
TEST_END
#undef NTHREADS
#undef NRESET
int
2018-05-24 11:17:37 -04:00
main(void) {
return test(
2015-10-06 10:18:30 -04:00
test_prof_thread_name_validation,
2018-05-24 11:17:37 -04:00
test_prof_thread_name_threaded);
2015-10-06 10:18:30 -04:00
}