]> git.ipfire.org Git - thirdparty/samba.git/commitdiff
smbtorture: Directory Leases vs setting creation date
authorRalph Boehme <slow@samba.org>
Fri, 18 Oct 2024 10:56:31 +0000 (12:56 +0200)
committerRalph Boehme <slow@samba.org>
Tue, 5 Nov 2024 14:39:31 +0000 (14:39 +0000)
Signed-off-by: Ralph Boehme <slow@samba.org>
Reviewed-by: Stefan Metzmacher <metze@samba.org>
source4/torture/smb2/lease.c

index fcd5c3062bfd1f7fbb2cf1508218cbd3f4984c73..57fca71b08b7406e0060b03238ae32d12863faba 100644 (file)
@@ -5848,6 +5848,7 @@ struct torture_suite *torture_smb2_lease_init(TALLOC_CTX *ctx)
 enum dirlease_test {
        DLT_SETEOF,
        DLT_SETDOS,
+       DLT_BTIME,
 };
 
 static void prepare_setinfo(enum dirlease_test t,
@@ -5866,6 +5867,11 @@ static void prepare_setinfo(enum dirlease_test t,
                        s->basic_info.in.attrib = FILE_ATTRIBUTE_NORMAL;
                }
                break;
+       case DLT_BTIME:
+               s->basic_info.in.create_time++;
+               break;
+       default:
+               break;
        }
 }
 
@@ -6146,6 +6152,58 @@ done:
        return ret;
 }
 
+/*
+ * TEST: Test setting creation date
+ */
+static bool test_dirlease_setbtime(struct torture_context *tctx,
+                                  struct smb2_tree *tree,
+                                  struct smb2_tree *tree2)
+{
+       TALLOC_CTX *mem_ctx = talloc_new(tctx);
+       struct smb2_create c;
+       struct smb2_lease dirlease;
+       struct smb2_handle dirh = {};
+       const char *dname = "test_dirlease_setbtime_dir";
+       const char *dnamefname = "test_dirlease_setbtime_dir\\lease.dat";
+       union smb_setfileinfo sfinfo = {};
+       NTSTATUS status;
+       bool ret = true;
+
+       smb2_deltree(tree, dname);
+
+       tree->session->transport->lease.handler = torture_lease_handler;
+       tree->session->transport->lease.private_data = tree;
+       torture_reset_lease_break_info(tctx, &lease_break_info);
+
+       /* Get an RH directory lease on the test directory */
+
+       smb2_lease_v2_create_share(&c, &dirlease, true, dname,
+                                  smb2_util_share_access("RWD"),
+                                  LEASE1, NULL,
+                                  smb2_util_lease_state("RHW"), 0);
+       status = smb2_create(tree, mem_ctx, &c);
+       torture_assert_ntstatus_ok_goto(tctx, status, ret, done,
+                                       "smb2_create failed\n");
+       dirh = c.out.file.handle;
+       CHECK_LEASE_V2(&c, "RH", true, LEASE1, 0, 0, ++dirlease.lease_epoch);
+
+       sfinfo.generic.level = RAW_SFILEINFO_BASIC_INFORMATION;
+       unix_to_nt_time(&sfinfo.basic_info.in.create_time, time(NULL) + 9*30*24*60*60);
+
+       ret = test_dirlease_setinfo(tctx, mem_ctx, DLT_BTIME, tree, tree2,
+                                   dname, dnamefname,
+                                   &dirh, &dirlease, &sfinfo);
+       torture_assert_goto(tctx, ret, ret, done, "setbtime test failed\n");
+
+done:
+       if (!smb2_util_handle_empty(dirh)) {
+               smb2_util_close(tree, dirh);
+       }
+       smb2_deltree(tree, dname);
+       talloc_free(mem_ctx);
+       return ret;
+}
+
 struct torture_suite *torture_smb2_dirlease_init(TALLOC_CTX *ctx)
 {
        struct torture_suite *suite =
@@ -6158,5 +6216,6 @@ struct torture_suite *torture_smb2_dirlease_init(TALLOC_CTX *ctx)
        torture_suite_add_1smb2_test(suite, "leases", test_dirlease_leases);
        torture_suite_add_2smb2_test(suite, "seteof", test_dirlease_seteof);
        torture_suite_add_2smb2_test(suite, "setdos", test_dirlease_setdos);
+       torture_suite_add_2smb2_test(suite, "setbtime", test_dirlease_setbtime);
        return suite;
 }