File: ziptools/ziptools/docetc/1.2-upgrades/more-platform-demos/windows-noadminperm-unzip.txt

##################################################################################
# Demo how unzipping symlinks on Windows without admin permission yields output 
# messages and dummy "stub" files.  It's debatable whether an abort should happen
# instead (as one does when trying to overwrite a read-only file), but the current
# policy is to continue a run whenever metadata propagation fails, and symlinks 
# arguably fall into this category (the real content referenced is elsewhere).
###################################################################################


#
# Extract a symlink-ful zip in Python 3.X, without admin permission
#

C:\Users\me\Desktop>py -3 ziptools\zip-extract.py cgi.zip cgi3np -permissions
Unzipping from cgi.zip to cgi3np
Extracted cgi/
                => cgi3np\cgi
Extracted cgi/.htaccess
                => cgi3np\cgi\.htaccess
Extracted cgi/__prior-sitesearch-savedterms.txt
                => cgi3np\cgi\__prior-sitesearch-savedterms.txt
Extracted cgi/_prior-sitesearch-savedterms.txt
                => cgi3np\cgi\_prior-sitesearch-savedterms.txt
Extracted cgi/dev/
                => cgi3np\cgi\dev
Extracted cgi/dev/orig-sitesearch.py
                => cgi3np\cgi\dev\orig-sitesearch.py
Extracted cgi/dev/other-sitesearch.py
                => cgi3np\cgi\dev\other-sitesearch.py
Extracted cgi/dev/py2-mock-out.txt
                => cgi3np\cgi\dev\py2-mock-out.txt
Extracted cgi/dev/py3-mock-out.txt
                => cgi3np\cgi\dev\py3-mock-out.txt
Extracted cgi/dev/sitesearch-savedterms-live.txt
                => cgi3np\cgi\dev\sitesearch-savedterms-live.txt
Extracted cgi/dev/sitesearch-savedterms.txt
                => cgi3np\cgi\dev\sitesearch-savedterms.txt
Extracted cgi/DIFFS-with-offline-june2017.txt
                => cgi3np\cgi\DIFFS-with-offline-june2017.txt
(Link) --Symlink not supported
Extracted cgi/DIRLINK1
                => cgi3np\cgi\DIRLINK1
(Link) --Symlink not supported
Extracted cgi/DIRLINK2
                => cgi3np\cgi\DIRLINK2
(Link) --Symlink not supported
Extracted cgi/FILELINK1
                => cgi3np\cgi\FILELINK1
(Link) --Symlink not supported
Extracted cgi/FILELINK2
                => cgi3np\cgi\FILELINK2
Extracted cgi/HOW-INSTALL-CGI-SCRIPTS.txt
                => cgi3np\cgi\HOW-INSTALL-CGI-SCRIPTS.txt
Extracted cgi/HOW.txt
                => cgi3np\cgi\HOW.txt
Extracted cgi/index.html
                => cgi3np\cgi\index.html
Extracted cgi/LIVE-Aug2017/
                => cgi3np\cgi\LIVE-Aug2017
Extracted cgi/LIVE-Aug2017/sitesearch-savedterms.txt
                => cgi3np\cgi\LIVE-Aug2017\sitesearch-savedterms.txt
Extracted cgi/LIVE-June2017/
                => cgi3np\cgi\LIVE-June2017
Extracted cgi/LIVE-June2017/gdform.cgi
                => cgi3np\cgi\LIVE-June2017\gdform.cgi
Extracted cgi/LIVE-June2017/gdformssl.cgi
                => cgi3np\cgi\LIVE-June2017\gdformssl.cgi
Extracted cgi/LIVE-June2017/pylotto-players.txt
                => cgi3np\cgi\LIVE-June2017\pylotto-players.txt
Extracted cgi/LIVE-June2017/pylotto.pswd
                => cgi3np\cgi\LIVE-June2017\pylotto.pswd
Extracted cgi/LIVE-June2017/pylotto.py
                => cgi3np\cgi\LIVE-June2017\pylotto.py
Extracted cgi/LIVE-June2017/pylotto24.py
                => cgi3np\cgi\LIVE-June2017\pylotto24.py
Extracted cgi/LIVE-June2017/sitesearch-savedterms.txt
                => cgi3np\cgi\LIVE-June2017\sitesearch-savedterms.txt
Extracted cgi/LIVE-June2017/sitesearch.html
                => cgi3np\cgi\LIVE-June2017\sitesearch.html
Extracted cgi/LIVE-June2017/sitesearch.py
                => cgi3np\cgi\LIVE-June2017\sitesearch.py
Extracted cgi/pylotto-full.py
                => cgi3np\cgi\pylotto-full.py
Extracted cgi/pylotto.py
                => cgi3np\cgi\pylotto.py
Extracted cgi/showcode-template.txt
                => cgi3np\cgi\showcode-template.txt
Extracted cgi/showcode-unicode-demo.txt
                => cgi3np\cgi\showcode-unicode-demo.txt
Extracted cgi/showcode.py
                => cgi3np\cgi\showcode.py
Extracted cgi/sitesearch-savedterms.txt
                => cgi3np\cgi\sitesearch-savedterms.txt
Extracted cgi/sitesearch.py
                => cgi3np\cgi\sitesearch.py
Extracted cgi/temp.html
                => cgi3np\cgi\temp.html
Extracted cgi/test.py
                => cgi3np\cgi\test.py
Extracted cgi/xreadonly.txt
                => cgi3np\cgi\xreadonly.txt
Extracted cgi/xwriteonly.txt
                => cgi3np\cgi\xwriteonly.txt
Extract finished: files=38, folders=4, links=0, unknowns=0.


#
# Same effect under Python 2.X (the symlink create fails before all else)
#

C:\Users\me\Desktop>py -2 ziptools\zip-extract.py cgi.zip cgi2np -permissions
Unzipping from cgi.zip to cgi2np
Extracted cgi/
                => cgi2np\cgi
Extracted cgi/.htaccess
                => cgi2np\cgi\.htaccess
Extracted cgi/__prior-sitesearch-savedterms.txt
                => cgi2np\cgi\__prior-sitesearch-savedterms.txt
Extracted cgi/_prior-sitesearch-savedterms.txt
                => cgi2np\cgi\_prior-sitesearch-savedterms.txt
Extracted cgi/dev/
                => cgi2np\cgi\dev
Extracted cgi/dev/orig-sitesearch.py
                => cgi2np\cgi\dev\orig-sitesearch.py
Extracted cgi/dev/other-sitesearch.py
                => cgi2np\cgi\dev\other-sitesearch.py
Extracted cgi/dev/py2-mock-out.txt
                => cgi2np\cgi\dev\py2-mock-out.txt
Extracted cgi/dev/py3-mock-out.txt
                => cgi2np\cgi\dev\py3-mock-out.txt
Extracted cgi/dev/sitesearch-savedterms-live.txt
                => cgi2np\cgi\dev\sitesearch-savedterms-live.txt
Extracted cgi/dev/sitesearch-savedterms.txt
                => cgi2np\cgi\dev\sitesearch-savedterms.txt
Extracted cgi/DIFFS-with-offline-june2017.txt
                => cgi2np\cgi\DIFFS-with-offline-june2017.txt
(Link) --Symlink not supported
Extracted cgi/DIRLINK1
                => cgi2np\cgi\DIRLINK1
(Link) --Symlink not supported
Extracted cgi/DIRLINK2
                => cgi2np\cgi\DIRLINK2
(Link) --Symlink not supported
Extracted cgi/FILELINK1
                => cgi2np\cgi\FILELINK1
(Link) --Symlink not supported
Extracted cgi/FILELINK2
                => cgi2np\cgi\FILELINK2
Extracted cgi/HOW-INSTALL-CGI-SCRIPTS.txt
                => cgi2np\cgi\HOW-INSTALL-CGI-SCRIPTS.txt
Extracted cgi/HOW.txt
                => cgi2np\cgi\HOW.txt
Extracted cgi/index.html
                => cgi2np\cgi\index.html
Extracted cgi/LIVE-Aug2017/
                => cgi2np\cgi\LIVE-Aug2017
Extracted cgi/LIVE-Aug2017/sitesearch-savedterms.txt
                => cgi2np\cgi\LIVE-Aug2017\sitesearch-savedterms.txt
Extracted cgi/LIVE-June2017/
                => cgi2np\cgi\LIVE-June2017
Extracted cgi/LIVE-June2017/gdform.cgi
                => cgi2np\cgi\LIVE-June2017\gdform.cgi
Extracted cgi/LIVE-June2017/gdformssl.cgi
                => cgi2np\cgi\LIVE-June2017\gdformssl.cgi
Extracted cgi/LIVE-June2017/pylotto-players.txt
                => cgi2np\cgi\LIVE-June2017\pylotto-players.txt
Extracted cgi/LIVE-June2017/pylotto.pswd
                => cgi2np\cgi\LIVE-June2017\pylotto.pswd
Extracted cgi/LIVE-June2017/pylotto.py
                => cgi2np\cgi\LIVE-June2017\pylotto.py
Extracted cgi/LIVE-June2017/pylotto24.py
                => cgi2np\cgi\LIVE-June2017\pylotto24.py
Extracted cgi/LIVE-June2017/sitesearch-savedterms.txt
                => cgi2np\cgi\LIVE-June2017\sitesearch-savedterms.txt
Extracted cgi/LIVE-June2017/sitesearch.html
                => cgi2np\cgi\LIVE-June2017\sitesearch.html
Extracted cgi/LIVE-June2017/sitesearch.py
                => cgi2np\cgi\LIVE-June2017\sitesearch.py
Extracted cgi/pylotto-full.py
                => cgi2np\cgi\pylotto-full.py
Extracted cgi/pylotto.py
                => cgi2np\cgi\pylotto.py
Extracted cgi/showcode-template.txt
                => cgi2np\cgi\showcode-template.txt
Extracted cgi/showcode-unicode-demo.txt
                => cgi2np\cgi\showcode-unicode-demo.txt
Extracted cgi/showcode.py
                => cgi2np\cgi\showcode.py
Extracted cgi/sitesearch-savedterms.txt
                => cgi2np\cgi\sitesearch-savedterms.txt
Extracted cgi/sitesearch.py
                => cgi2np\cgi\sitesearch.py
Extracted cgi/temp.html
                => cgi2np\cgi\temp.html
Extracted cgi/test.py
                => cgi2np\cgi\test.py
Extracted cgi/xreadonly.txt
                => cgi2np\cgi\xreadonly.txt
Extracted cgi/xwriteonly.txt
                => cgi2np\cgi\xwriteonly.txt
Extract finished: files=38, folders=4, links=0, unknowns=0.


#
# Same content results with 3.X and 2.X
#

C:\Users\me\Desktop>py -2 Mergeall-source\Mergeall-source\diffall.py cgi3np cgi2np -skipcruft
--------------------
Comparing cgi3np to cgi2np
Directory lists are identical
Comparing contents
--------------------
Comparing cgi3np\cgi to cgi2np\cgi
Directory lists are identical
Comparing contents
.htaccess matches
DIFFS-with-offline-june2017.txt matches
DIRLINK1 matches
DIRLINK2 matches
FILELINK1 matches
FILELINK2 matches
...etc...
================================================================================
Runtime hrs:mins:secs = 0:0:1.35
Dirs checked 5, Files checked: 38, Files skipped: 0
System metadata (cruft) files were skipped
No diffs found.
End of report.


#
# Same modtime results with 3.X and 2.X
#

C:\Users\me\Desktop>py -2 Mergeall-source\Mergeall-source\mergeall.py cgi3np cgi2np -skipcruft -report
Starting.
-------------------------------------------------------------------------------
*Collecting tree differences
Skipping system cruft (metadata) files in both FROM and TO
comparing [cgi3np] [cgi2np]
comparing [cgi3np\cgi] [cgi2np\cgi]
comparing [cgi3np\cgi\dev] [cgi2np\cgi\dev]
comparing [cgi3np\cgi\LIVE-Aug2017] [cgi2np\cgi\LIVE-Aug2017]
comparing [cgi3np\cgi\LIVE-June2017] [cgi2np\cgi\LIVE-June2017]
Phase runtime: 0.026829
-------------------------------------------------------------------------------
*Reporting tree differences
-------------------------------------------------------------------------------
SAMEFILE DIFFERENCES: (name, dirfrom, dirto, why)
**These items will be replaced in dirto by automatic resolution**

[]
-------------------------------------------------------------------------------
UNIQUE ITEMS IN DIRTO: (names, dirfrom, dirto)
**These items will be deleted from dirto by automatic resolution**

[]
-------------------------------------------------------------------------------
UNIQUE ITEMS IN DIRFROM: (names, dirfrom, dirto)
**These items will be copied over to dirto by automatic resolution**

[]
-------------------------------------------------------------------------------
MIXED MODE NAMES: (name, dirfrom, dirto)
**These items will be replaced in dirto by automatic resolution**

[]
-------------------------------------------------------------------------------
*Summary
Compared    => files: 38, folders: 5
Differences => samefile: 0, uniqueto: 0, uniquefrom: 0, mixedmode: 0
Changed:
files   => created: 0, deleted: 0, replaced: 0
folders => created: 0, deleted: 0, replaced: 0
-------------------------------------------------------------------------------
Finished.


#
# But the link stub files differ from original links on E: (edited for space)
#

C:\Users\me\Desktop>dir cgi3np\cgi\FILELINK1 E:\_test\cgi\FILELINK1

Directory of C:\Users\me\Desktop\cgi3np\cgi
03/21/2020  01:36 PM                11 FILELINK1
               1 File(s)             11 bytes
               0 Dir(s)  650,821,984,256 bytes free

Directory of E:\_test\cgi
03/21/2020  01:36 PM             1,067 FILELINK1
               1 File(s)          1,067 bytes
               0 Dir(s)  51,860,799,488 bytes free

C:\Users\me\Desktop>type cgi3np\cgi\FILELINK1 E:\_test\cgi\FILELINK1

cgi3np\cgi\FILELINK1
showcode.py

E:\_test\cgi\FILELINK1
XSym
0011
f67d36fa88bde9cb2fa4bbd07e3d5e66
showcode.py



[Home page] Books Code Blog Python Author Train Find ©M.Lutz