torture/ndr: make check functions typesafe
authorStefan Metzmacher <metze@samba.org>
Fri, 31 Jul 2020 11:20:09 +0000 (13:20 +0200)
committerStefan Metzmacher <metze@samba.org>
Thu, 8 Jul 2021 09:30:40 +0000 (09:30 +0000)
BUG: https://bugzilla.samba.org/show_bug.cgi?id=14452

Signed-off-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Samuel Cabrero <scabrero@samba.org>
source4/torture/ndr/lsa.c
source4/torture/ndr/ndr.h

index c83c5247d59dbfb376abe75a2d933724ef06d22d..6b9a5bcc53d9921b6a01b85f73c2ef74ea8de76d 100644 (file)
@@ -1631,8 +1631,7 @@ static const uint8_t lsarlookupnames3_in_data[] = {
   0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
 };
 
-static bool lsarlookupnames3_in_check(struct torture_context *tctx,
-                                                                         struct lsa_LookupNames2 *r)
+static bool lsarlookupnames3_in_check(struct torture_context *tctx, struct lsa_LookupNames3 *r)
 {
        /* FIXME: Handle */
        torture_assert_int_equal(tctx, r->in.num_names, 7, "num names");
index 0cc21825fb4777231bf0aa607b0d534cd87297df..84d691e6ced86a3b5ec3e162d928befe44d2b600 100644 (file)
@@ -59,6 +59,11 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
        enum ndr_err_code ndr_err);
 
 #define torture_suite_add_ndr_pull_test(suite,name,data,check_fn) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pullpush_test(suite, #name, \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         NULL, \
@@ -67,7 +72,8 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         data_blob_const(data, sizeof(data)), \
                         sizeof(struct name), \
                         NDR_SCALARS|NDR_BUFFERS, 0, \
-                        (bool (*) (struct torture_context *, void *)) check_fn);
+                        check_fn_anon); \
+       } while(0)
 
 #define torture_suite_add_ndr_pull_invalid_data_test(suite,name,data,ndr_err) \
                _torture_suite_add_ndr_pull_invalid_data_test( \
@@ -80,6 +86,11 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                        ndr_err);
 
 #define torture_suite_add_ndr_pull_fn_test(suite,name,data,flags,check_fn) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pullpush_test(suite, #name "_" #flags, \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         NULL, \
@@ -88,9 +99,15 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         data_blob_const(data, sizeof(data)), \
                         sizeof(struct name), \
                         flags, 0, \
-                        (bool (*) (struct torture_context *, void *)) check_fn);
+                        check_fn_anon); \
+       } while(0)
 
 #define torture_suite_add_ndr_pull_fn_test_flags(suite,name,data,flags,flags2,check_fn) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pullpush_test(suite, #name "_" #flags "_" #flags2, \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         NULL, \
@@ -99,9 +116,15 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         data_blob_const(data, sizeof(data)), \
                         sizeof(struct name), \
                         flags, flags2, \
-                        (bool (*) (struct torture_context *, void *)) check_fn);
+                        check_fn_anon); \
+       } while(0)
 
 #define torture_suite_add_ndr_pull_validate_test(suite,name,data,check_fn) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pullpush_test(suite, #name "_VALIDATE", \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         (ndr_push_flags_fn_t)ndr_push_ ## name, \
@@ -110,9 +133,15 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         data_blob_const(data, sizeof(data)), \
                         sizeof(struct name), \
                         NDR_SCALARS|NDR_BUFFERS, 0, \
-                        (bool (*) (struct torture_context *, void *)) check_fn);
+                        check_fn_anon); \
+       } while(0)
 
 #define torture_suite_add_ndr_pull_validate_test_blob(suite,name,data_blob,check_fn) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pullpush_test(suite, #name "_VALIDATE", \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         (ndr_push_flags_fn_t)ndr_push_ ## name, \
@@ -121,9 +150,15 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         data_blob, \
                         sizeof(struct name), \
                         NDR_SCALARS|NDR_BUFFERS, 0, \
-                        (bool (*) (struct torture_context *, void *)) check_fn);
+                        check_fn_anon); \
+       } while(0)
 
 #define torture_suite_add_ndr_pull_validate_test_b64(suite,name,tname,b64,check_fn) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pullpush_test(suite, #name "_" tname, \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         (ndr_push_flags_fn_t)ndr_push_ ## name, \
@@ -132,9 +167,15 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         base64_decode_data_blob_talloc(suite, b64), \
                         sizeof(struct name), \
                         NDR_SCALARS|NDR_BUFFERS, 0, \
-                        (bool (*) (struct torture_context *, void *)) check_fn);
+                        check_fn_anon); \
+       } while(0)
 
 #define torture_suite_add_ndr_pullpush_fn_test_flags(suite,name,data,flags,flags2,check_fn) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pullpush_test(suite, #name, \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         (ndr_push_flags_fn_t)ndr_push_ ## name, \
@@ -143,9 +184,15 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         data_blob_const(data, sizeof(data)), \
                         sizeof(struct name), \
                         flags, flags2, \
-                        (bool (*) (struct torture_context *, void *)) check_fn);
+                        check_fn_anon); \
+       } while(0)
 
 #define torture_suite_add_ndr_pull_io_test(suite,name,data_in,data_out,check_fn_out) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn_out; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pull_inout_test(suite, #name "_INOUT", \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         (ndr_print_function_t)ndr_print_ ## name, \
@@ -153,9 +200,15 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         data_blob_const(data_out, sizeof(data_out)), \
                         sizeof(struct name), \
                         0, \
-                        (bool (*) (struct torture_context *, void *)) check_fn_out);
+                        check_fn_anon); \
+       } while(0)
 
 #define torture_suite_add_ndr_pull_io_test_flags(suite,name,data_in,data_out,flags,check_fn_out) \
+       do { \
+               bool (*check_fn_typed) (struct torture_context *, struct name *) = \
+                       check_fn_out; \
+               bool (*check_fn_anon) (struct torture_context *, void *) = \
+                       (bool (*) (struct torture_context *, void *)) check_fn_typed; \
                _torture_suite_add_ndr_pull_inout_test(suite, #name "_INOUT_" #flags, \
                         (ndr_pull_flags_fn_t)ndr_pull_ ## name, \
                         (ndr_print_function_t)ndr_print_ ## name, \
@@ -163,5 +216,7 @@ _PUBLIC_ struct torture_test *_torture_suite_add_ndr_pull_invalid_data_test(
                         data_blob_const(data_out, sizeof(data_out)), \
                         sizeof(struct name), \
                         flags, \
-                        (bool (*) (struct torture_context *, void *)) check_fn_out);
+                        check_fn_anon); \
+       } while(0)
+
 #endif /* __TORTURE_NDR_H__ */