1
0
mirror of https://github.com/samba-team/samba.git synced 2025-03-05 20:58:40 +03:00

tests: SMB2 rename fails to check del-on-close on dst dir

Signed-off-by: Volker Lendecke <vl@samba.org>
Reviewed-by: Jeremy Allison <jra@samba.org>
This commit is contained in:
Volker Lendecke 2020-11-17 15:24:43 +01:00 committed by Jeremy Allison
parent d680d39268
commit 0f67dd540f
2 changed files with 35 additions and 1 deletions

View File

@ -20,7 +20,8 @@
from samba.samba3 import libsmb_samba_internal as libsmb
from samba.dcerpc import security
from samba.samba3 import param as s3param
from samba import credentials
from samba import (credentials,NTSTATUSError)
from samba.ntstatus import NT_STATUS_DELETE_PENDING
from samba.credentials import SMB_ENCRYPTION_REQUIRED
import samba.tests
import threading
@ -107,6 +108,38 @@ class LibsmbTestCase(samba.tests.TestCase):
c.mkdir(test_dir)
c.rmdir(test_dir)
def test_RenameDstDelOnClose(self):
(lp,creds) = self.prep_creds()
dstdir = "\\dst-subdir"
c1 = libsmb.Conn(os.getenv("SERVER_IP"), "tmp", lp, creds)
c2 = libsmb.Conn(os.getenv("SERVER_IP"), "tmp", lp, creds)
try:
c1.deltree(dstdir)
except:
pass
c1.mkdir(dstdir)
dnum = c1.create(dstdir, DesiredAccess=security.SEC_STD_DELETE)
c1.delete_on_close(dnum,1)
c2.savefile("\\src.txt", b"Content")
with self.assertRaises(NTSTATUSError) as cm:
c2.rename("\\src.txt", dstdir + "\\dst.txt")
if (cm.exception.args[0] != NT_STATUS_DELETE_PENDING):
raise AssertionError("Rename must fail with DELETE_PENDING")
c1.delete_on_close(dnum,0)
c1.close(dnum)
try:
c1.deltree(dstdir)
c1.unlink("\\src.txt")
except:
pass
if __name__ == "__main__":
import unittest
unittest.main()

View File

@ -0,0 +1 @@
^samba.tests.libsmb.samba.tests.libsmb.LibsmbTestCase.test_RenameDstDelOnClose\(nt4_dc_smb1\)