diff options
Diffstat (limited to 'src/tests/common.h')
-rw-r--r-- | src/tests/common.h | 144 |
1 files changed, 144 insertions, 0 deletions
diff --git a/src/tests/common.h b/src/tests/common.h new file mode 100644 index 0000000..8ef24f4 --- /dev/null +++ b/src/tests/common.h @@ -0,0 +1,144 @@ +/* + SSSD + + Common utilities for check-based tests using talloc. + + Authors: + Martin Nagy <mnagy@redhat.com> + + Copyright (C) Red Hat, Inc 2009 + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +#ifndef __TESTS_COMMON_H__ +#define __TESTS_COMMON_H__ + +/* used to enable all debug levels in debug-tests.c and find_uid-tests.c + * 0x0800 isn't used for historical reasons: 0x1FFF0 - 0x0800 = 0x1F7F0 + */ +#define SSSDBG_MASK_ALL 0x1F7F0 + +#include "config.h" + +#include <talloc.h> +#include "util/util.h" +#include "providers/data_provider.h" +#include "providers/ldap/sdap.h" + + +#ifdef HAVE_FUNCTION_ATTRIBUTE_WARN_UNUSED_RESULT +#define SSS_ATTRIBUTE_WARN_UNUSED_RESULT __attribute__((warn_unused_result)) +#else +#define SSS_ATTRIBUTE_WARN_UNUSED_RESULT +#endif + +extern TALLOC_CTX *global_talloc_context; + +void check_leaks_push(TALLOC_CTX *ctx); + +#define check_leaks_pop(ctx) _check_leaks_pop((ctx), __location__) +bool _check_leaks_pop(TALLOC_CTX *ctx, const char *location) + SSS_ATTRIBUTE_WARN_UNUSED_RESULT; + +bool leak_check_setup(void) SSS_ATTRIBUTE_WARN_UNUSED_RESULT; +bool leak_check_teardown(void) SSS_ATTRIBUTE_WARN_UNUSED_RESULT; +const char *check_leaks_err_msg(void); + +void tests_set_cwd(void); + +errno_t +compare_dp_options(struct dp_option *map1, size_t size1, + struct dp_option *map2); + +errno_t +compare_sdap_attr_maps(struct sdap_attr_map *map1, size_t size1, + struct sdap_attr_map *map2); + +/* A common test structure for tests that require a domain to be set up. */ +struct sss_test_ctx { + struct sysdb_ctx *sysdb; + struct confdb_ctx *confdb; + struct tevent_context *ev; + struct sss_domain_info *dom; + struct sss_names_ctx *nctx; + char *confdb_path; + char *conf_dom_path; + + bool done; + int error; +}; + +struct sss_test_conf_param { + const char *key; + const char *value; +}; + +struct sss_test_ctx *create_ev_test_ctx(TALLOC_CTX *mem_ctx); + +void reset_ldb_errstrings(struct sss_domain_info *dom); + +struct sss_test_ctx * +create_multidom_test_ctx(TALLOC_CTX *mem_ctx, + const char *tests_path, + const char *cdb_file, + const char **domains, + const char *id_provider, + struct sss_test_conf_param **params); + +struct sss_test_ctx * +create_dom_test_ctx(TALLOC_CTX *mem_ctx, + const char *tests_path, + const char *confdb_path, + const char *domain_name, + const char *id_provider, + struct sss_test_conf_param *params); + +void test_dom_suite_setup(const char *tests_path); + +void test_multidom_suite_cleanup(const char *tests_path, + const char *cdb_file, + const char **domains); + +void test_dom_suite_cleanup(const char *tests_path, + const char *cdb_file, + const char *domain); + +struct tevent_req * +test_request_send(TALLOC_CTX *mem_ctx, struct tevent_context *ev, errno_t err); + +#define test_req_succeed_send(mem_ctx, ev) test_request_send(mem_ctx, ev, 0) + +errno_t test_request_recv(struct tevent_req *req); + +int test_ev_loop(struct sss_test_ctx *tctx); + +/* Mark the test as done with an error code */ +void test_ev_done(struct sss_test_ctx *tctx, errno_t ret); + +bool ldb_modules_path_is_set(void); + +struct sss_domain_info *named_domain(TALLOC_CTX *mem_ctx, + const char *name, + struct sss_domain_info *parent); + +/* Returns true if all values are in array (else returns false) */ +bool are_values_in_array(const char **values, size_t values_len, + const char **array, size_t array_len); + +#define tc_are_values_in_array(values, array) \ + are_values_in_array(values, talloc_array_length(values), \ + array, talloc_array_length(array)) + +#endif /* !__TESTS_COMMON_H__ */ |