mirror of
https://github.com/samba-team/samba.git
synced 2025-01-03 01:18:10 +03:00
s4:torture/smb2: better error handling in create.c
BUG: https://bugzilla.samba.org/show_bug.cgi?id=15656 Signed-off-by: Stefan Metzmacher <metze@samba.org> Reviewed-by: Volker Lendecke <vl@samba.org> Autobuild-User(master): Volker Lendecke <vl@samba.org> Autobuild-Date(master): Thu Aug 29 19:47:54 UTC 2024 on atb-devel-224
This commit is contained in:
parent
3fd40cb8a9
commit
e2c8f718ca
@ -114,18 +114,18 @@
|
|||||||
ret = false; \
|
ret = false; \
|
||||||
}} while (0)
|
}} while (0)
|
||||||
|
|
||||||
#define SET_ATTRIB(sattrib) do { \
|
#define SET_ATTRIB(sattrib, expected_status) do { \
|
||||||
union smb_setfileinfo sfinfo; \
|
union smb_setfileinfo sfinfo; \
|
||||||
ZERO_STRUCT(sfinfo.basic_info.in); \
|
ZERO_STRUCT(sfinfo.basic_info.in); \
|
||||||
sfinfo.basic_info.level = RAW_SFILEINFO_BASIC_INFORMATION; \
|
sfinfo.basic_info.level = RAW_SFILEINFO_BASIC_INFORMATION; \
|
||||||
sfinfo.basic_info.in.file.handle = h1; \
|
sfinfo.basic_info.in.file.handle = h1; \
|
||||||
sfinfo.basic_info.in.attrib = sattrib; \
|
sfinfo.basic_info.in.attrib = sattrib; \
|
||||||
status = smb2_setinfo_file(tree, &sfinfo); \
|
status = smb2_setinfo_file(tree, &sfinfo); \
|
||||||
if (!NT_STATUS_IS_OK(status)) { \
|
torture_assert_ntstatus_equal(tctx, status, expected_status, \
|
||||||
torture_comment(tctx, \
|
talloc_asprintf(tctx, \
|
||||||
"(%s) Failed to set attrib 0x%x on %s\n", \
|
"(%s) Failed to set attrib 0x%x on %s\n", \
|
||||||
__location__, (unsigned int)(sattrib), fname); \
|
__location__, (unsigned int)(sattrib), fname)); \
|
||||||
}} while (0)
|
} while (0)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
test some interesting combinations found by gentest
|
test some interesting combinations found by gentest
|
||||||
@ -759,30 +759,21 @@ static bool test_smb2_open(struct torture_context *tctx,
|
|||||||
if (open_funcs[i].with_file) {
|
if (open_funcs[i].with_file) {
|
||||||
io.smb2.in.create_disposition = NTCREATEX_DISP_CREATE;
|
io.smb2.in.create_disposition = NTCREATEX_DISP_CREATE;
|
||||||
status= smb2_create(tree, tctx, &(io.smb2));
|
status= smb2_create(tree, tctx, &(io.smb2));
|
||||||
if (!NT_STATUS_IS_OK(status)) {
|
torture_assert_ntstatus_ok_goto(tctx, status, ret, done,
|
||||||
torture_comment(tctx,
|
talloc_asprintf(tctx,
|
||||||
"Failed to create file %s status %s %zu\n",
|
"Failed to create file %s status %s %zu\n",
|
||||||
fname, nt_errstr(status), i);
|
fname, nt_errstr(status), i));
|
||||||
|
|
||||||
ret = false;
|
|
||||||
goto done;
|
|
||||||
}
|
|
||||||
smb2_util_close(tree, io.smb2.out.file.handle);
|
smb2_util_close(tree, io.smb2.out.file.handle);
|
||||||
}
|
}
|
||||||
io.smb2.in.create_disposition = open_funcs[i].create_disp;
|
io.smb2.in.create_disposition = open_funcs[i].create_disp;
|
||||||
status = smb2_create(tree, tctx, &(io.smb2));
|
status = smb2_create(tree, tctx, &(io.smb2));
|
||||||
if (!NT_STATUS_EQUAL(status, open_funcs[i].correct_status)) {
|
torture_assert_ntstatus_equal_goto(tctx, status,
|
||||||
torture_comment(tctx,
|
open_funcs[i].correct_status,
|
||||||
"(%s) incorrect status %s should be %s (i=%zu "
|
ret, done,
|
||||||
"with_file=%d open_disp=%d)\n",
|
talloc_asprintf(tctx,
|
||||||
__location__, nt_errstr(status),
|
"(i=%zu with_file=%d open_disp=%d)\n",
|
||||||
nt_errstr(open_funcs[i].correct_status),
|
i, (int)open_funcs[i].with_file,
|
||||||
i, (int)open_funcs[i].with_file,
|
(int)open_funcs[i].create_disp));
|
||||||
(int)open_funcs[i].create_disp);
|
|
||||||
|
|
||||||
ret = false;
|
|
||||||
goto done;
|
|
||||||
}
|
|
||||||
if (NT_STATUS_IS_OK(status) || open_funcs[i].with_file) {
|
if (NT_STATUS_IS_OK(status) || open_funcs[i].with_file) {
|
||||||
smb2_util_close(tree, io.smb2.out.file.handle);
|
smb2_util_close(tree, io.smb2.out.file.handle);
|
||||||
smb2_util_unlink(tree, fname);
|
smb2_util_unlink(tree, fname);
|
||||||
@ -991,8 +982,7 @@ static bool test_smb2_open_multi(struct torture_context *tctx,
|
|||||||
if (!torture_smb2_connection(tctx, &(trees[i]))) {
|
if (!torture_smb2_connection(tctx, &(trees[i]))) {
|
||||||
torture_comment(tctx,
|
torture_comment(tctx,
|
||||||
"Could not open %d'th connection\n", i);
|
"Could not open %d'th connection\n", i);
|
||||||
ret = false;
|
torture_assert_goto(tctx, false, ret, done, __location__);
|
||||||
goto done;
|
|
||||||
}
|
}
|
||||||
trees[i]->session->transport->options.request_timeout = 60;
|
trees[i]->session->transport->options.request_timeout = 60;
|
||||||
}
|
}
|
||||||
@ -1024,8 +1014,7 @@ static bool test_smb2_open_multi(struct torture_context *tctx,
|
|||||||
if (requests[i] == NULL) {
|
if (requests[i] == NULL) {
|
||||||
torture_comment(tctx,
|
torture_comment(tctx,
|
||||||
"could not send %d'th request\n", i);
|
"could not send %d'th request\n", i);
|
||||||
ret = false;
|
torture_assert_goto(tctx, false, ret, done, __location__);
|
||||||
goto done;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1064,13 +1053,12 @@ static bool test_smb2_open_multi(struct torture_context *tctx,
|
|||||||
|
|
||||||
if (tevent_loop_once(tctx->ev) != 0) {
|
if (tevent_loop_once(tctx->ev) != 0) {
|
||||||
torture_comment(tctx, "tevent_loop_once failed\n");
|
torture_comment(tctx, "tevent_loop_once failed\n");
|
||||||
ret = false;
|
torture_assert_goto(tctx, false, ret, done, __location__);
|
||||||
goto done;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((num_ok != 1) || (num_ok + num_collision != num_files)) {
|
if ((num_ok != 1) || (num_ok + num_collision != num_files)) {
|
||||||
ret = false;
|
torture_assert_goto(tctx, false, ret, done, __location__);
|
||||||
}
|
}
|
||||||
done:
|
done:
|
||||||
smb2_deltree(tree, fname);
|
smb2_deltree(tree, fname);
|
||||||
@ -1143,7 +1131,7 @@ static bool test_smb2_open_for_delete(struct torture_context *tctx,
|
|||||||
status = smb2_create(tree, tctx, &(io.smb2));
|
status = smb2_create(tree, tctx, &(io.smb2));
|
||||||
CHECK_STATUS(status, NT_STATUS_OK);
|
CHECK_STATUS(status, NT_STATUS_OK);
|
||||||
h1 = io.smb2.out.file.handle;
|
h1 = io.smb2.out.file.handle;
|
||||||
SET_ATTRIB(FILE_ATTRIBUTE_ARCHIVE);
|
SET_ATTRIB(FILE_ATTRIBUTE_ARCHIVE, NT_STATUS_OK);
|
||||||
smb2_util_close(tree, h1);
|
smb2_util_close(tree, h1);
|
||||||
|
|
||||||
smb2_util_close(tree, h);
|
smb2_util_close(tree, h);
|
||||||
@ -3705,12 +3693,7 @@ static bool test_dosattr_tmp_dir(struct torture_context *tctx,
|
|||||||
h1 = c.out.file.handle;
|
h1 = c.out.file.handle;
|
||||||
|
|
||||||
/* Try to set temporary attribute on directory */
|
/* Try to set temporary attribute on directory */
|
||||||
SET_ATTRIB(FILE_ATTRIBUTE_TEMPORARY);
|
SET_ATTRIB(FILE_ATTRIBUTE_TEMPORARY, NT_STATUS_INVALID_PARAMETER);
|
||||||
|
|
||||||
torture_assert_ntstatus_equal_goto(tctx, status,
|
|
||||||
NT_STATUS_INVALID_PARAMETER,
|
|
||||||
ret, done,
|
|
||||||
"Unexpected setinfo result\n");
|
|
||||||
|
|
||||||
done:
|
done:
|
||||||
if (!smb2_util_handle_empty(h1)) {
|
if (!smb2_util_handle_empty(h1)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user