diff options
author | Volker Lendecke <vl@samba.org> | 2012-11-07 21:24:27 +0100 |
---|---|---|
committer | Michael Adam <obnox@samba.org> | 2012-11-29 17:41:15 +0100 |
commit | 24c36e748414d70ede930e8418455a2c11068d49 (patch) | |
tree | ff65020a7f1291d34ecaf260c8aaef04fc160b38 /source3 | |
parent | 8300791a6765499bcc8b892863d319f59332d9e3 (diff) | |
download | samba-24c36e748414d70ede930e8418455a2c11068d49.tar.gz samba-24c36e748414d70ede930e8418455a2c11068d49.tar.bz2 samba-24c36e748414d70ede930e8418455a2c11068d49.zip |
s3: test dbwrap_ctdb
Reviewed-by: Michael Adam <obnox@samba.org>
Diffstat (limited to 'source3')
-rw-r--r-- | source3/Makefile.in | 1 | ||||
-rw-r--r-- | source3/torture/proto.h | 1 | ||||
-rw-r--r-- | source3/torture/test_dbwrap_ctdb.c | 149 | ||||
-rw-r--r-- | source3/torture/torture.c | 1 | ||||
-rwxr-xr-x | source3/wscript_build | 1 |
5 files changed, 153 insertions, 0 deletions
diff --git a/source3/Makefile.in b/source3/Makefile.in index a2d7906e03..35556873ae 100644 --- a/source3/Makefile.in +++ b/source3/Makefile.in @@ -1267,6 +1267,7 @@ SMBTORTURE_OBJ1 = torture/torture.o torture/nbio.o torture/scanner.o torture/uta torture/test_notify.o \ torture/test_dbwrap_watch.o \ torture/test_idmap_tdb_common.o \ + torture/test_dbwrap_ctdb.o \ torture/t_strappend.o SMBTORTURE_OBJ = $(SMBTORTURE_OBJ1) $(PARAM_OBJ) $(TLDAP_OBJ) \ diff --git a/source3/torture/proto.h b/source3/torture/proto.h index 0c6fc70c28..4f4c9e2718 100644 --- a/source3/torture/proto.h +++ b/source3/torture/proto.h @@ -110,5 +110,6 @@ bool run_notify_bench2(int dummy); bool run_notify_bench3(int dummy); bool run_dbwrap_watch1(int dummy); bool run_idmap_tdb_common_test(int dummy); +bool run_local_dbwrap_ctdb(int dummy); #endif /* __TORTURE_H__ */ diff --git a/source3/torture/test_dbwrap_ctdb.c b/source3/torture/test_dbwrap_ctdb.c new file mode 100644 index 0000000000..f7672ba4ff --- /dev/null +++ b/source3/torture/test_dbwrap_ctdb.c @@ -0,0 +1,149 @@ +/* + * Unix SMB/CIFS implementation. + * Test dbwrap_ctdb API + * Copyright (C) Volker Lendecke 2012 + * + * 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/>. + */ + +#include "includes.h" +#include "torture/proto.h" +#include "system/filesys.h" +#include "lib/dbwrap/dbwrap.h" +#include "lib/dbwrap/dbwrap_ctdb.h" + +bool run_local_dbwrap_ctdb(int dummy) +{ + struct db_context *db; + int res; + bool ret = false; + NTSTATUS status; + uint32_t val; + + db = db_open_ctdb(talloc_tos(), "torture.tdb", 0, TDB_DEFAULT, + O_RDWR, 0755, DBWRAP_LOCK_ORDER_1); + if (db == NULL) { + perror("db_open_ctdb failed"); + goto fail; + } + + res = dbwrap_transaction_start(db); + if (res != 0) { + fprintf(stderr, "dbwrap_transaction_start failed"); + goto fail; + } + res = dbwrap_transaction_cancel(db); + if (res != 0) { + fprintf(stderr, "dbwrap_transaction_cancel failed"); + goto fail; + } + + res = dbwrap_transaction_start(db); + if (res != 0) { + fprintf(stderr, "dbwrap_transaction_start failed"); + goto fail; + } + + status = dbwrap_store_uint32_bystring(db, "foo", 1); + if (!NT_STATUS_IS_OK(status)) { + fprintf(stderr, "store_uint32 failed: %s\n", + nt_errstr(status)); + goto fail; + } + status = dbwrap_fetch_uint32_bystring(db, "foo", &val); + if (!NT_STATUS_IS_OK(status)) { + fprintf(stderr, "fetch_uint32 failed: %s\n", + nt_errstr(status)); + goto fail; + } + if (val != 1) { + fprintf(stderr, "fetch_uint32 gave %u, expected 1", + (unsigned)val); + goto fail; + } + + status = dbwrap_store_uint32_bystring(db, "bar", 5); + if (!NT_STATUS_IS_OK(status)) { + fprintf(stderr, "store_uint32 failed: %s\n", + nt_errstr(status)); + goto fail; + } + status = dbwrap_fetch_uint32_bystring(db, "bar", &val); + if (!NT_STATUS_IS_OK(status)) { + fprintf(stderr, "fetch_uint32 failed: %s\n", + nt_errstr(status)); + goto fail; + } + if (val != 5) { + fprintf(stderr, "fetch_uint32 gave %u, expected 5", + (unsigned)val); + goto fail; + } + + status = dbwrap_store_uint32_bystring(db, "foo", 2); + if (!NT_STATUS_IS_OK(status)) { + fprintf(stderr, "store_uint32 failed: %s\n", + nt_errstr(status)); + goto fail; + } + status = dbwrap_fetch_uint32_bystring(db, "foo", &val); + if (!NT_STATUS_IS_OK(status)) { + fprintf(stderr, "fetch_uint32 failed: %s\n", + nt_errstr(status)); + goto fail; + } + if (val != 2) { + fprintf(stderr, "fetch_uint32 gave %u, expected 2", + (unsigned)val); + goto fail; + } + + res = dbwrap_transaction_commit(db); + if (res != 0) { + fprintf(stderr, "dbwrap_transaction_commit failed"); + goto fail; + } + + /* + * check that the values have reached the disk + */ + status = dbwrap_fetch_uint32_bystring(db, "foo", &val); + if (!NT_STATUS_IS_OK(status)) { + fprintf(stderr, "fetch_uint32 failed: %s\n", + nt_errstr(status)); + goto fail; + } + if (val != 2) { + fprintf(stderr, "fetch_uint32 gave %u, expected 1", + (unsigned)val); + goto fail; + } + + status = dbwrap_fetch_uint32_bystring(db, "bar", &val); + if (!NT_STATUS_IS_OK(status)) { + fprintf(stderr, "fetch_uint32 failed: %s\n", + nt_errstr(status)); + goto fail; + } + if (val != 5) { + fprintf(stderr, "fetch_uint32 gave %u, expected 1", + (unsigned)val); + goto fail; + } + + ret = true; +fail: + TALLOC_FREE(db); + return ret; +} diff --git a/source3/torture/torture.c b/source3/torture/torture.c index 0cca680f6b..89b34e4da0 100644 --- a/source3/torture/torture.c +++ b/source3/torture/torture.c @@ -9150,6 +9150,7 @@ static struct { { "LOCAL-remove_duplicate_addrs2", run_local_remove_duplicate_addrs2, 0}, { "local-tdb-opener", run_local_tdb_opener, 0 }, { "local-tdb-writer", run_local_tdb_writer, 0 }, + { "LOCAL-DBWRAP-CTDB", run_local_dbwrap_ctdb, 0 }, {NULL, NULL, 0}}; diff --git a/source3/wscript_build b/source3/wscript_build index b87b4d1fd6..b9984fe98b 100755 --- a/source3/wscript_build +++ b/source3/wscript_build @@ -557,6 +557,7 @@ SMBTORTURE_SRC1 = '''torture/torture.c torture/nbio.c torture/scanner.c torture/ lib/tevent_barrier.c torture/test_dbwrap_watch.c torture/test_idmap_tdb_common.c + torture/test_dbwrap_ctdb.c torture/t_strappend.c''' SMBTORTURE_SRC = '''${SMBTORTURE_SRC1} |