diff options
Diffstat (limited to 'source4/torture')
-rw-r--r-- | source4/torture/raw/unlink.c | 49 |
1 files changed, 28 insertions, 21 deletions
diff --git a/source4/torture/raw/unlink.c b/source4/torture/raw/unlink.c index d73b7abacf..c4f08beb7f 100644 --- a/source4/torture/raw/unlink.c +++ b/source4/torture/raw/unlink.c @@ -252,34 +252,41 @@ static BOOL test_delete_on_close(struct smbcli_state *cli, TALLOC_CTX *mem_ctx) CHECK_STATUS(status, NT_STATUS_OBJECT_NAME_NOT_FOUND); - printf("Testing with non-empty directory delete_on_close\n"); - status = create_directory_handle(cli->tree, dname, &fnum); - CHECK_STATUS(status, NT_STATUS_OK); - - fnum2 = create_complex_file(cli, mem_ctx, inside); + if (!lp_parm_bool(-1, "torture", "samba3", False)) { - sfinfo.disposition_info.in.file.fnum = fnum; - sfinfo.disposition_info.in.delete_on_close = 1; - status = smb_raw_setfileinfo(cli->tree, &sfinfo); - CHECK_STATUS(status, NT_STATUS_DIRECTORY_NOT_EMPTY); + /* + * Known deficiency, also skipped in base-delete. + */ - sfinfo.disposition_info.in.file.fnum = fnum2; - status = smb_raw_setfileinfo(cli->tree, &sfinfo); - CHECK_STATUS(status, NT_STATUS_OK); + printf("Testing with non-empty directory delete_on_close\n"); + status = create_directory_handle(cli->tree, dname, &fnum); + CHECK_STATUS(status, NT_STATUS_OK); - sfinfo.disposition_info.in.file.fnum = fnum; - status = smb_raw_setfileinfo(cli->tree, &sfinfo); - CHECK_STATUS(status, NT_STATUS_DIRECTORY_NOT_EMPTY); + fnum2 = create_complex_file(cli, mem_ctx, inside); - smbcli_close(cli->tree, fnum2); + sfinfo.disposition_info.in.file.fnum = fnum; + sfinfo.disposition_info.in.delete_on_close = 1; + status = smb_raw_setfileinfo(cli->tree, &sfinfo); + CHECK_STATUS(status, NT_STATUS_DIRECTORY_NOT_EMPTY); - status = smb_raw_setfileinfo(cli->tree, &sfinfo); - CHECK_STATUS(status, NT_STATUS_OK); + sfinfo.disposition_info.in.file.fnum = fnum2; + status = smb_raw_setfileinfo(cli->tree, &sfinfo); + CHECK_STATUS(status, NT_STATUS_OK); - smbcli_close(cli->tree, fnum); + sfinfo.disposition_info.in.file.fnum = fnum; + status = smb_raw_setfileinfo(cli->tree, &sfinfo); + CHECK_STATUS(status, NT_STATUS_DIRECTORY_NOT_EMPTY); - status = smb_raw_rmdir(cli->tree, &dio); - CHECK_STATUS(status, NT_STATUS_OBJECT_NAME_NOT_FOUND); + smbcli_close(cli->tree, fnum2); + + status = smb_raw_setfileinfo(cli->tree, &sfinfo); + CHECK_STATUS(status, NT_STATUS_OK); + + smbcli_close(cli->tree, fnum); + + status = smb_raw_rmdir(cli->tree, &dio); + CHECK_STATUS(status, NT_STATUS_OBJECT_NAME_NOT_FOUND); + } printf("Testing open dir with delete_on_close\n"); status = create_directory_handle(cli->tree, dname, &fnum); |