plexpy/lib/win32comext/shell/test/testSHFileOperation.py
dependabot[bot] faef9a94c4
Bump cherrypy from 18.8.0 to 18.9.0 (#2266)
* Bump cherrypy from 18.8.0 to 18.9.0

Bumps [cherrypy](https://github.com/cherrypy/cherrypy) from 18.8.0 to 18.9.0.
- [Changelog](https://github.com/cherrypy/cherrypy/blob/main/CHANGES.rst)
- [Commits](https://github.com/cherrypy/cherrypy/compare/v18.8.0...v18.9.0)

---
updated-dependencies:
- dependency-name: cherrypy
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>

* Update cherrypy==18.9.0

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: JonnyWong16 <9099342+JonnyWong16@users.noreply.github.com>

[skip ci]
2024-03-24 15:25:44 -07:00

75 lines
2 KiB
Python

import os
import win32api
from win32com.shell import shell, shellcon
def testSHFileOperation(file_cnt):
temp_dir = os.environ["temp"]
orig_fnames = [
win32api.GetTempFileName(temp_dir, "sfo")[0] for x in range(file_cnt)
]
new_fnames = [
os.path.join(temp_dir, "copy of " + os.path.split(orig_fnames[x])[1])
for x in range(file_cnt)
]
pFrom = "\0".join(orig_fnames)
pTo = "\0".join(new_fnames)
shell.SHFileOperation(
(
0,
shellcon.FO_MOVE,
pFrom,
pTo,
shellcon.FOF_MULTIDESTFILES | shellcon.FOF_NOCONFIRMATION,
)
)
for fname in orig_fnames:
assert not os.path.isfile(fname)
for fname in new_fnames:
assert os.path.isfile(fname)
shell.SHFileOperation(
(
0,
shellcon.FO_DELETE,
fname,
None,
shellcon.FOF_NOCONFIRMATION | shellcon.FOF_NOERRORUI,
)
)
def testSHNAMEMAPPINGS(file_cnt):
## attemps to move a set of files to names that already exist, and generated filenames should be returned
## as a sequence of 2-tuples created from SHNAMEMAPPINGS handle
temp_dir = os.environ["temp"]
orig_fnames = [
win32api.GetTempFileName(temp_dir, "sfo")[0] for x in range(file_cnt)
]
new_fnames = [win32api.GetTempFileName(temp_dir, "sfo")[0] for x in range(file_cnt)]
pFrom = "\0".join(orig_fnames)
pTo = "\0".join(new_fnames)
rc, banyaborted, NameMappings = shell.SHFileOperation(
(
0,
shellcon.FO_MOVE,
pFrom,
pTo,
shellcon.FOF_MULTIDESTFILES
| shellcon.FOF_NOCONFIRMATION
| shellcon.FOF_RENAMEONCOLLISION
| shellcon.FOF_WANTMAPPINGHANDLE,
)
)
for old_fname, new_fname in NameMappings:
print("Old:", old_fname, "New:", new_fname)
assert len(NameMappings) == file_cnt
testSHFileOperation(10)
testSHFileOperation(1)
testSHNAMEMAPPINGS(5)