r9003: add testing for non-empty directory delete on close
authorAndrew Tridgell <tridge@samba.org>
Wed, 3 Aug 2005 16:50:12 +0000 (16:50 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 18:31:06 +0000 (13:31 -0500)
(This used to be commit caca1f191d23ef848d3c8da76e8a0e80a06dacef)

source4/torture/raw/unlink.c

index e8808957c64fa78eef545c958f59e696188c7f17..b2eb7eae601fed0c999c0481d9bcb0cb69933142 100644 (file)
@@ -173,9 +173,10 @@ static BOOL test_delete_on_close(struct smbcli_state *cli, TALLOC_CTX *mem_ctx)
        struct smb_rmdir dio;
        NTSTATUS status;
        BOOL ret = True;
-       int fnum;
+       int fnum, fnum2;
        const char *fname = BASEDIR "\\test.txt";
        const char *dname = BASEDIR "\\test.dir";
+       const char *inside = BASEDIR "\\test.dir\\test.txt";
        union smb_setfileinfo sfinfo;
 
        if (!torture_setup_dir(cli, BASEDIR)) {
@@ -242,6 +243,34 @@ static BOOL test_delete_on_close(struct smbcli_state *cli, TALLOC_CTX *mem_ctx)
        status = smb_raw_rmdir(cli->tree, &dio);
        CHECK_STATUS(status, NT_STATUS_OBJECT_NAME_NOT_FOUND);
 
+
+       printf("Testing with non-empty directory delete_on_close\n");
+       fnum = create_directory_handle(cli->tree, dname);
+       fnum2 = create_complex_file(cli, mem_ctx, inside);
+
+       sfinfo.disposition_info.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);
+
+       sfinfo.disposition_info.file.fnum = fnum2;
+       status = smb_raw_setfileinfo(cli->tree, &sfinfo);
+       CHECK_STATUS(status, NT_STATUS_OK);
+
+       sfinfo.disposition_info.file.fnum = fnum;
+       status = smb_raw_setfileinfo(cli->tree, &sfinfo);
+       CHECK_STATUS(status, NT_STATUS_DIRECTORY_NOT_EMPTY);
+
+       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);
+
 done:
        smb_raw_exit(cli->session);
        smbcli_deltree(cli->tree, BASEDIR);