summaryrefslogtreecommitdiffstats
path: root/source4
diff options
context:
space:
mode:
authorJelmer Vernooij <jelmer@samba.org>2007-04-18 13:28:04 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 14:51:05 -0500
commit0fe8434b3b4fa0c7c56a6f2e04d3257cd4227e74 (patch)
treed600e3416a100f4b143b4a81a146149d5cfdbb3d /source4
parentcef04ba64f872c8d408dfcb952839139aee9c4b1 (diff)
downloadsamba-0fe8434b3b4fa0c7c56a6f2e04d3257cd4227e74.tar.gz
samba-0fe8434b3b4fa0c7c56a6f2e04d3257cd4227e74.tar.xz
samba-0fe8434b3b4fa0c7c56a6f2e04d3257cd4227e74.zip
r22336: Add some more share tests.
(This used to be commit dfc88ad698644fe90f0275c457e7b84ddde302a4)
Diffstat (limited to 'source4')
-rw-r--r--source4/param/share_ldb.c2
-rw-r--r--source4/torture/local/share.c148
2 files changed, 144 insertions, 6 deletions
diff --git a/source4/param/share_ldb.c b/source4/param/share_ldb.c
index 451d003a0de..2d865588a90 100644
--- a/source4/param/share_ldb.c
+++ b/source4/param/share_ldb.c
@@ -289,7 +289,7 @@ NTSTATUS sldb_create(struct share_context *ctx, const char *name, struct share_i
NTSTATUS ret;
int err, i, j;
- for (i = 0, j = 0; i < count || j != 0x03; i++) {
+ for (i = 0, j = 0; i < count && j != 0x03; i++) {
if (strcasecmp(info[i].name, SHARE_TYPE) == 0) j |= 0x02;
if (strcasecmp(info[i].name, SHARE_PATH) == 0) j |= 0x01;
if (strcasecmp(info[i].name, SHARE_NAME) == 0) {
diff --git a/source4/torture/local/share.c b/source4/torture/local/share.c
index 0f50dbc4ad6..3ef26f772eb 100644
--- a/source4/torture/local/share.c
+++ b/source4/torture/local/share.c
@@ -25,10 +25,10 @@
#include "torture/torture.h"
static bool test_list_empty(struct torture_context *tctx,
- void *tcase_data,
- void *test_data)
+ const void *tcase_data,
+ const void *test_data)
{
- struct share_context *ctx = tcase_data;
+ struct share_context *ctx = discard_const(tcase_data);
int count;
const char **names;
@@ -38,19 +38,157 @@ static bool test_list_empty(struct torture_context *tctx,
return true;
}
+static bool test_create(struct torture_context *tctx,
+ const void *tcase_data,
+ const void *test_data)
+{
+ struct share_context *ctx = discard_const(tcase_data);
+ int count;
+ const char **names;
+ int i;
+ bool found = false;
+ struct share_info inf[] = {
+ { SHARE_INFO_STRING, SHARE_TYPE, discard_const_p(void *, "IPC$") },
+ { SHARE_INFO_STRING, SHARE_PATH, discard_const_p(void *, "/tmp/bla") }
+ };
+ NTSTATUS status;
+
+ status = share_create(ctx, "bloe", inf, 2);
+
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_IMPLEMENTED))
+ torture_skip(tctx, "Not supported by backend");
+
+ torture_assert_ntstatus_ok(tctx, status, "create_share failed");
+
+ torture_assert_ntstatus_ok(tctx, share_list_all(tctx, ctx, &count, &names),
+ "share_list_all failed");
+
+ torture_assert(tctx, count >= 1, "creating share failed");
+
+
+ for (i = 0; i < count; i++) {
+ found |= strcmp(names[i], "bloe") == 0;
+ }
+
+ torture_assert(tctx, found, "created share found");
+
+ return true;
+}
+
+
+static bool test_create_invalid(struct torture_context *tctx,
+ const void *tcase_data,
+ const void *test_data)
+{
+ struct share_context *ctx = discard_const(tcase_data);
+ NTSTATUS status;
+
+ status = share_create(ctx, "bla", NULL, 0);
+
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_IMPLEMENTED))
+ torture_skip(tctx, "Not supported by backend");
+
+ torture_assert_ntstatus_equal(tctx, NT_STATUS_INVALID_PARAMETER,
+ status,
+ "create_share failed");
+
+ torture_assert_ntstatus_equal(tctx, NT_STATUS_INVALID_PARAMETER,
+ share_create(ctx, NULL, NULL, 0),
+ "create_share failed");
+
+ return true;
+}
+
+static bool test_share_remove_invalid(struct torture_context *tctx,
+ const void *tcase_data,
+ const void *test_data)
+{
+ struct share_context *ctx = discard_const(tcase_data);
+ NTSTATUS status;
+
+ status = share_remove(ctx, "nonexistant");
+
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_IMPLEMENTED))
+ torture_skip(tctx, "Not supported by backend");
+
+ torture_assert_ntstatus_equal(ctx, status, NT_STATUS_UNSUCCESSFUL,
+ "remove fails");
+
+ return true;
+}
+
+
+
+static bool test_share_remove(struct torture_context *tctx,
+ const void *tcase_data,
+ const void *test_data)
+{
+ struct share_context *ctx = discard_const(tcase_data);
+ struct share_info inf[] = {
+ { SHARE_INFO_STRING, SHARE_TYPE, discard_const_p(void *, "IPC$") },
+ { SHARE_INFO_STRING, SHARE_PATH, discard_const_p(void *, "/tmp/bla") }
+ };
+ NTSTATUS status;
+
+ status = share_create(ctx, "blie", inf, 2);
+
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_IMPLEMENTED))
+ torture_skip(tctx, "Not supported by backend");
+
+ torture_assert_ntstatus_ok(tctx, status,
+ "create_share failed");
+
+ torture_assert_ntstatus_ok(tctx, share_remove(ctx, "blie"),
+ "remove failed");
+
+ return true;
+}
+
+static bool test_double_create(struct torture_context *tctx,
+ const void *tcase_data,
+ const void *test_data)
+{
+ struct share_context *ctx = discard_const(tcase_data);
+ struct share_info inf[] = {
+ { SHARE_INFO_STRING, SHARE_TYPE, discard_const_p(void *, "IPC$") },
+ { SHARE_INFO_STRING, SHARE_PATH, discard_const_p(void *, "/tmp/bla") }
+ };
+ NTSTATUS status;
+
+ status = share_create(ctx, "bla", inf, 2);
+
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_IMPLEMENTED))
+ torture_skip(tctx, "Not supported by backend");
+
+ torture_assert_ntstatus_ok(tctx, status,
+ "create_share failed");
+
+ torture_assert_ntstatus_equal(tctx, NT_STATUS_UNSUCCESSFUL,
+ share_create(ctx, "bla", inf, 2),
+ "create_share failed");
+
+ return true;
+}
+
static void tcase_add_share_tests(struct torture_tcase *tcase)
{
torture_tcase_add_test(tcase, "list_empty", test_list_empty, NULL);
+ torture_tcase_add_test(tcase, "share_create", test_create, NULL);
+ torture_tcase_add_test(tcase, "share_remove", test_share_remove, NULL);
+ torture_tcase_add_test(tcase, "share_remove_invalid", test_share_remove_invalid, NULL);
+ torture_tcase_add_test(tcase, "share_create_invalid", test_create_invalid,
+ NULL);
+ torture_tcase_add_test(tcase, "share_double_create", test_double_create, NULL);
}
static BOOL setup_ldb(struct torture_context *tctx, void **data)
{
- return NT_STATUS_IS_OK(share_get_context_by_name(tctx, "ldb", data));
+ return NT_STATUS_IS_OK(share_get_context_by_name(tctx, "ldb", (struct share_context **)data));
}
static BOOL setup_classic(struct torture_context *tctx, void **data)
{
- return NT_STATUS_IS_OK(share_get_context_by_name(tctx, "classic", data));
+ return NT_STATUS_IS_OK(share_get_context_by_name(tctx, "classic", (struct share_context **)data));
}
static BOOL teardown(struct torture_context *tctx, void *data)