diff options
-rw-r--r-- | source4/param/share.c | 11 | ||||
-rw-r--r-- | source4/torture/local/config.mk | 4 | ||||
-rw-r--r-- | source4/torture/local/local.c | 1 | ||||
-rw-r--r-- | source4/torture/local/share.c | 79 |
4 files changed, 92 insertions, 3 deletions
diff --git a/source4/param/share.c b/source4/param/share.c index 7cbaa8a85c..75b63cef73 100644 --- a/source4/param/share.c +++ b/source4/param/share.c @@ -131,11 +131,13 @@ NTSTATUS share_register(const struct share_ops *ops) return NT_STATUS_OK; } -NTSTATUS share_get_context(TALLOC_CTX *mem_ctx, struct share_context **ctx) +NTSTATUS share_get_context_by_name(TALLOC_CTX *mem_ctx, + const char *backend_name, + struct share_context **ctx) { const struct share_ops *ops; - ops = share_backend_by_name(lp_share_backend()); + ops = share_backend_by_name(backend_name); if (!ops) { DEBUG(0, ("share_init_connection: share backend [%s] not found!\n", lp_share_backend())); return NT_STATUS_INTERNAL_ERROR; @@ -144,6 +146,11 @@ NTSTATUS share_get_context(TALLOC_CTX *mem_ctx, struct share_context **ctx) return ops->init(mem_ctx, ops, ctx); } +NTSTATUS share_get_context(TALLOC_CTX *mem_ctx, struct share_context **ctx) +{ + return share_get_context_by_name(mem_ctx, lp_share_backend(), ctx); +} + /* initialise the SHARE subsystem */ diff --git a/source4/torture/local/config.mk b/source4/torture/local/config.mk index 801c5e1117..27b9f90fa0 100644 --- a/source4/torture/local/config.mk +++ b/source4/torture/local/config.mk @@ -32,6 +32,7 @@ OBJ_FILES = \ sddl.o \ ../../lib/tdr/testsuite.o \ event.o \ + share.o \ local.o \ dbspeed.o \ torture.o @@ -46,7 +47,8 @@ PUBLIC_DEPENDENCIES = \ POPT_CREDENTIALS \ TORTURE_AUTH \ TORTURE_UTIL -PRIVATE_DEPENDENCIES = TORTURE_NDR +PRIVATE_DEPENDENCIES = TORTURE_NDR \ + share # End SUBSYSTEM TORTURE_LOCAL ################################# diff --git a/source4/torture/local/local.c b/source4/torture/local/local.c index 84dca5fcfa..ccdb7b3af5 100644 --- a/source4/torture/local/local.c +++ b/source4/torture/local/local.c @@ -45,6 +45,7 @@ torture_local_sddl, torture_local_ndr, torture_local_tdr, + torture_local_share, torture_local_charset, torture_local_compression, torture_local_event, diff --git a/source4/torture/local/share.c b/source4/torture/local/share.c new file mode 100644 index 0000000000..0f50dbc4ad --- /dev/null +++ b/source4/torture/local/share.c @@ -0,0 +1,79 @@ +/* + 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 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 "param/share.h" +#include "torture/torture.h" + +static bool test_list_empty(struct torture_context *tctx, + void *tcase_data, + void *test_data) +{ + struct share_context *ctx = 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 void tcase_add_share_tests(struct torture_tcase *tcase) +{ + torture_tcase_add_test(tcase, "list_empty", test_list_empty, NULL); +} + +static BOOL setup_ldb(struct torture_context *tctx, void **data) +{ + return NT_STATUS_IS_OK(share_get_context_by_name(tctx, "ldb", data)); +} + +static BOOL setup_classic(struct torture_context *tctx, void **data) +{ + return NT_STATUS_IS_OK(share_get_context_by_name(tctx, "classic", 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; +} |