diff options
author | Jelmer Vernooij <jelmer@samba.org> | 2007-11-11 23:36:50 +0100 |
---|---|---|
committer | Stefan Metzmacher <metze@samba.org> | 2007-12-21 05:45:05 +0100 |
commit | 6ee570c327a210a065823b308a7badfff6239a5f (patch) | |
tree | 731a9b7868f8576cc163b429fbd4506e80d4a5d2 /source4/torture | |
parent | a86920600a59ddf2b534e3c66c477a6f9be8de5b (diff) | |
download | samba-6ee570c327a210a065823b308a7badfff6239a5f.tar.gz samba-6ee570c327a210a065823b308a7badfff6239a5f.tar.bz2 samba-6ee570c327a210a065823b308a7badfff6239a5f.zip |
r25927: Move share tests to param directory.
(This used to be commit f12f623da52aefdf49df9b77d87b9b0d48177c14)
Diffstat (limited to 'source4/torture')
-rw-r--r-- | source4/torture/local/config.mk | 2 | ||||
-rw-r--r-- | source4/torture/local/share.c | 210 |
2 files changed, 1 insertions, 211 deletions
diff --git a/source4/torture/local/config.mk b/source4/torture/local/config.mk index 1c97e81a35..987029e7e9 100644 --- a/source4/torture/local/config.mk +++ b/source4/torture/local/config.mk @@ -36,7 +36,7 @@ OBJ_FILES = \ ../../libcli/security/tests/sddl.o \ ../../lib/tdr/testsuite.o \ ../../lib/events/testsuite.o \ - share.o \ + ../../param/tests/share.o \ local.o \ dbspeed.o \ torture.o diff --git a/source4/torture/local/share.c b/source4/torture/local/share.c deleted file mode 100644 index de93e3c591..0000000000 --- a/source4/torture/local/share.c +++ /dev/null @@ -1,210 +0,0 @@ -/* - Unix SMB/CIFS implementation. - - local testing of share code - - Copyright (C) Jelmer Vernooij 2007 - - 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 "param/share.h" -#include "torture/torture.h" - -static bool test_list_empty(struct torture_context *tctx, - const void *tcase_data, - const void *test_data) -{ - struct share_context *ctx = (struct share_context *)discard_const(tcase_data); - int count; - const char **names; - - torture_assert_ntstatus_ok(tctx, share_list_all(tctx, ctx, &count, &names), - "share_list_all failed"); - - return true; -} - -static bool test_create(struct torture_context *tctx, - const void *tcase_data, - const void *test_data) -{ - struct share_context *ctx = (struct share_context *)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 = (struct share_context *)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 = (struct share_context *)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(tctx, 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 = (struct share_context *)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 = (struct share_context *)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_OBJECT_NAME_COLLISION, - 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", (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", (struct share_context **)data)); -} - -static bool teardown(struct torture_context *tctx, void *data) -{ - talloc_free(data); - return true; -} - -struct torture_suite *torture_local_share(TALLOC_CTX *mem_ctx) -{ - struct torture_suite *suite = torture_suite_create(mem_ctx, "SHARE"); - struct torture_tcase *tcase; - - share_init(); - - tcase = torture_suite_add_tcase(suite, "ldb"); - torture_tcase_set_fixture(tcase, setup_ldb, teardown); - tcase_add_share_tests(tcase); - - tcase = torture_suite_add_tcase(suite, "classic"); - torture_tcase_set_fixture(tcase, setup_classic, teardown); - tcase_add_share_tests(tcase); - - return suite; -} |