mirror of
https://github.com/samba-team/samba.git
synced 2025-01-11 05:18:09 +03:00
7415f712db
This is a confusing hold-over from the NTVFS fileserver that never became part of the merged architecture. Signed-off-by: Andrew Bartlett <abartlet@samba.org> Reviewed-by: Jeremy Allison <jra@samba.org>
208 lines
6.0 KiB
C
208 lines
6.0 KiB
C
/*
|
|
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 "param/param.h"
|
|
#include "torture/torture.h"
|
|
#include "torture/local/proto.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, "nonexistent");
|
|
|
|
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_const(tcase, "list_empty", test_list_empty,NULL);
|
|
torture_tcase_add_test_const(tcase, "share_create", test_create, NULL);
|
|
torture_tcase_add_test_const(tcase, "share_remove", test_share_remove,
|
|
NULL);
|
|
torture_tcase_add_test_const(tcase, "share_remove_invalid",
|
|
test_share_remove_invalid, NULL);
|
|
torture_tcase_add_test_const(tcase, "share_create_invalid",
|
|
test_create_invalid, NULL);
|
|
torture_tcase_add_test_const(tcase, "share_double_create",
|
|
test_double_create, NULL);
|
|
}
|
|
|
|
static bool setup_classic(struct torture_context *tctx, void **data)
|
|
{
|
|
return NT_STATUS_IS_OK(share_get_context(tctx, tctx->lp_ctx, (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, "classic");
|
|
torture_tcase_set_fixture(tcase, setup_classic, teardown);
|
|
tcase_add_share_tests(tcase);
|
|
|
|
return suite;
|
|
}
|