s4:dsdb/descriptor: make explicit that we don't support MOD_DELETE on nTSecurityDescr...
[Samba/gebeck_regimport.git] / lib / tdb / test / run-rwlock-check.c
blob8b8072db1e672c57d3748c641eded32d8b54285f
1 #include "../common/tdb_private.h"
2 #include "../common/io.c"
3 #include "../common/tdb.c"
4 #include "../common/lock.c"
5 #include "../common/freelist.c"
6 #include "../common/traverse.c"
7 #include "../common/transaction.c"
8 #include "../common/error.c"
9 #include "../common/open.c"
10 #include "../common/check.c"
11 #include "../common/hash.c"
12 #include "tap-interface.h"
13 #include <stdlib.h>
15 static void log_fn(struct tdb_context *tdb, enum tdb_debug_level level, const char *fmt, ...)
17 unsigned int *count = tdb_get_logging_private(tdb);
18 if (strstr(fmt, "spinlocks"))
19 (*count)++;
22 /* The code should barf on TDBs created with rwlocks. */
23 int main(int argc, char *argv[])
25 struct tdb_context *tdb;
26 unsigned int log_count;
27 struct tdb_logging_context log_ctx = { log_fn, &log_count };
29 plan_tests(4);
31 /* We should fail to open rwlock-using tdbs of either endian. */
32 log_count = 0;
33 tdb = tdb_open_ex("test/rwlock-le.tdb", 0, 0, O_RDWR, 0,
34 &log_ctx, NULL);
35 ok1(!tdb);
36 ok1(log_count == 1);
38 log_count = 0;
39 tdb = tdb_open_ex("test/rwlock-be.tdb", 0, 0, O_RDWR, 0,
40 &log_ctx, NULL);
41 ok1(!tdb);
42 ok1(log_count == 1);
44 return exit_status();