summaryrefslogtreecommitdiffstats
path: root/source4
diff options
context:
space:
mode:
authorJelmer Vernooij <jelmer@samba.org>2005-09-28 22:16:30 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 13:39:09 -0500
commit3b12c3bd34879d3682a7456d209d3ffdffa02069 (patch)
treea1e74fcff845d027a3541a87444c3a172b74c276 /source4
parent40e214e919f8be01d1a2e83968577ecfee85dfb9 (diff)
downloadsamba-3b12c3bd34879d3682a7456d209d3ffdffa02069.tar.gz
samba-3b12c3bd34879d3682a7456d209d3ffdffa02069.tar.xz
samba-3b12c3bd34879d3682a7456d209d3ffdffa02069.zip
r10594: Add initial framework for lib/registry torture tests
(This used to be commit 985c6a8fcc9977553d714a7d5e272b0791d45d1e)
Diffstat (limited to 'source4')
-rw-r--r--source4/torture/config.mk4
-rw-r--r--source4/torture/local/registry.c96
-rw-r--r--source4/torture/torture.c1
3 files changed, 100 insertions, 1 deletions
diff --git a/source4/torture/config.mk b/source4/torture/config.mk
index 2aac08e3ada..7675a07c40e 100644
--- a/source4/torture/config.mk
+++ b/source4/torture/config.mk
@@ -148,12 +148,14 @@ ADD_OBJ_FILES = \
torture/local/idtree.o \
torture/local/socket.o \
torture/local/irpc.o \
+ torture/local/registry.o \
torture/local/resolve.o \
torture/local/util_strlist.o \
torture/local/util_file.o
REQUIRED_SUBSYSTEMS = \
LIBSMB \
- MESSAGING
+ MESSAGING \
+ REGISTRY
# End SUBSYSTEM TORTURE_LOCAL
#################################
diff --git a/source4/torture/local/registry.c b/source4/torture/local/registry.c
new file mode 100644
index 00000000000..e2990bcc2e2
--- /dev/null
+++ b/source4/torture/local/registry.c
@@ -0,0 +1,96 @@
+/*
+ Unix SMB/CIFS implementation.
+
+ local testing of registry library
+
+ Copyright (C) Jelmer Vernooij 2005
+
+ 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 2 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, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+#include "includes.h"
+#include "librpc/gen_ndr/security.h"
+#include "librpc/gen_ndr/ndr_epmapper.h"
+
+static BOOL test_hive(TALLOC_CTX *mem_ctx, const char *backend, const char *location)
+{
+ WERROR error;
+ struct registry_key *root, *subkey;
+ uint32_t count;
+
+ if (!reg_has_backend(backend)) {
+ printf("Backend '%s' support not compiled in, ignoring\n", backend);
+ return True;
+ }
+
+ error = reg_open_hive(mem_ctx, backend, location, NULL, &root);
+ if (!W_ERROR_IS_OK(error)) {
+ printf("reg_open_hive() failed\n");
+ return False;
+ }
+
+ /* This is a new backend. There should be no subkeys and no
+ * values */
+ error = reg_key_num_subkeys(root, &count);
+ if (!W_ERROR_IS_OK(error)) {
+ printf("reg_key_num_subkeys failed\n");
+ return False;
+ }
+
+ if (count != 0) {
+ printf("New key has non-zero subkey count\n");
+ return False;
+ }
+
+ error = reg_key_num_values(root, &count);
+ if (!W_ERROR_IS_OK(error)) {
+ printf("reg_key_num_values failed\n");
+ return False;
+ }
+
+ if (count != 0) {
+ printf("New key has non-zero value count\n");
+ return False;
+ }
+
+ error = reg_key_add_name(mem_ctx, root, "Nested\\Key", SEC_MASK_GENERIC, NULL, &subkey);
+ if (!W_ERROR_IS_OK(error)) {
+ return False;
+ }
+
+ error = reg_key_del(root, "Nested\\Key");
+ if (!W_ERROR_IS_OK(error)) {
+ return False;
+ }
+
+ talloc_free(root);
+
+ return True;
+}
+
+BOOL torture_registry(void)
+{
+ BOOL ret = True;
+ TALLOC_CTX *mem_ctx = talloc_init("torture_registry");
+
+ ret &= test_hive(mem_ctx, "nt4", "TEST.DAT");
+ ret &= test_hive(mem_ctx, "ldb", "test.ldb");
+ ret &= test_hive(mem_ctx, "gconf", ".");
+ ret &= test_hive(mem_ctx, "dir", ".");
+
+ talloc_free(mem_ctx);
+
+ return ret;
+}
diff --git a/source4/torture/torture.c b/source4/torture/torture.c
index dfc63e6bd60..ca348e841b0 100644
--- a/source4/torture/torture.c
+++ b/source4/torture/torture.c
@@ -2326,6 +2326,7 @@ static struct {
{"LOCAL-IDTREE", torture_local_idtree, 0},
{"LOCAL-SOCKET", torture_local_socket, 0},
{"LOCAL-PAC", torture_pac, 0},
+ {"LOCAL-REGISTRY", torture_registry, 0},
{"LOCAL-RESOLVE", torture_local_resolve, 0},
/* COM (Component Object Model) testers */