Linux server1.dn-server.com 4.18.0-553.89.1.lve.el8.x86_64 #1 SMP Wed Dec 10 13:58:50 UTC 2025 x86_64
LiteSpeed
Server IP : 195.201.204.189 & Your IP : 216.73.216.198
Domains :
Cant Read [ /etc/named.conf ]
User : beriska1
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
python313 /
lib64 /
python3.13 /
test /
Delete
Unzip
Name
Size
Permission
Date
Action
__pycache__
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
archivetestdata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
audiodata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
certdata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
cjkencodings
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
configdata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
crashers
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
data
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
decimaltestdata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
dtracedata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
encoded_modules
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
leakers
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
libregrtest
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
mathdata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
regrtestdata
[ DIR ]
drwxr-xr-x
2026-03-26 17:37
subprocessdata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
support
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_ast
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_asyncio
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_capi
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_cext
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_concurrent_futures
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_cppext
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_ctypes
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_dataclasses
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_doctest
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_email
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_free_threading
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_future_stmt
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_gdb
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_import
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_importlib
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_inspect
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_interpreters
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_json
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_module
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_multiprocessing_fork
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_multiprocessing_forkserver
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_multiprocessing_spawn
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_pathlib
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_peg_generator
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_pydoc
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_pyrepl
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_sqlite3
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_tkinter
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_tomllib
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_tools
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_ttk
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_unittest
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_warnings
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_zipfile
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
test_zoneinfo
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
tkinterdata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
tokenizedata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
tracedmodules
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
translationdata
[ DIR ]
drwxr-xr-x
2026-03-26 17:37
typinganndata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
wheeldata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
xmltestdata
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
zipimport_data
[ DIR ]
drwxr-xr-x
2026-05-05 23:06
NormalizationTest-3.2.0.txt
1.93
MB
-rw-r--r--
2026-02-03 21:23
__init__.py
47
B
-rw-r--r--
2026-03-26 17:22
__main__.py
67
B
-rw-r--r--
2026-03-26 17:22
_test_atexit.py
5.32
KB
-rw-r--r--
2026-03-26 17:22
_test_eintr.py
17.83
KB
-rw-r--r--
2026-03-26 17:22
_test_embed_set_config.py
9.32
KB
-rw-r--r--
2026-03-26 17:22
_test_embed_structseq.py
1.99
KB
-rw-r--r--
2026-03-26 17:22
_test_monitoring_shutdown.py
704
B
-rw-r--r--
2026-03-26 17:39
_test_multiprocessing.py
228.26
KB
-rw-r--r--
2026-03-26 17:22
_test_venv_multiprocessing.py
796
B
-rw-r--r--
2026-03-26 17:22
archiver_tests.py
7.06
KB
-rw-r--r--
2026-03-26 17:22
audiotests.py
12.13
KB
-rw-r--r--
2026-03-26 17:22
audit-tests.py
14.81
KB
-rw-r--r--
2026-03-26 17:22
autotest.py
214
B
-rw-r--r--
2026-03-26 17:22
bisect_cmd.py
5.36
KB
-rwxr-xr-x
2026-03-26 17:22
clinic.test.c
161.63
KB
-rw-r--r--
2026-02-03 21:23
cov.py
1.26
KB
-rw-r--r--
2026-03-26 17:22
curses_tests.py
1.23
KB
-rwxr-xr-x
2026-03-26 17:22
datetimetester.py
274.67
KB
-rw-r--r--
2026-03-26 17:22
dis_module.py
76
B
-rw-r--r--
2026-03-26 17:22
empty.vbs
70
B
-rw-r--r--
2026-02-03 21:23
exception_hierarchy.txt
2.38
KB
-rw-r--r--
2026-02-03 21:23
fork_wait.py
2.29
KB
-rw-r--r--
2026-03-26 17:22
levenshtein_examples.json
406.44
KB
-rw-r--r--
2026-02-03 21:23
list_tests.py
17.11
KB
-rw-r--r--
2026-03-26 17:22
lock_tests.py
35.64
KB
-rw-r--r--
2026-03-26 17:22
mapping_tests.py
21.87
KB
-rw-r--r--
2026-03-26 17:22
memory_watchdog.py
711
B
-rw-r--r--
2026-03-26 17:22
mime.types
47.37
KB
-rw-r--r--
2026-02-03 21:23
mock_socket.py
3.69
KB
-rw-r--r--
2026-03-26 17:22
mp_fork_bomb.py
448
B
-rw-r--r--
2026-03-26 17:22
mp_preload.py
351
B
-rw-r--r--
2026-03-26 17:22
mp_preload_flush.py
291
B
-rw-r--r--
2026-03-26 17:22
mp_preload_main.py
287
B
-rw-r--r--
2026-03-26 17:22
mp_preload_sysargv.py
567
B
-rw-r--r--
2026-03-26 17:22
multibytecodec_support.py
14.91
KB
-rw-r--r--
2026-03-26 17:22
picklecommon.py
9.4
KB
-rw-r--r--
2026-03-26 17:22
pickletester.py
179.95
KB
-rw-r--r--
2026-03-26 17:22
profilee.py
2.97
KB
-rw-r--r--
2026-03-26 17:22
pstats.pck
65.05
KB
-rw-r--r--
2026-02-03 21:23
pyclbr_input.py
1.63
KB
-rw-r--r--
2026-03-26 17:22
pythoninfo.py
28.65
KB
-rw-r--r--
2026-03-26 17:22
randv2_32.pck
7.34
KB
-rw-r--r--
2026-02-03 21:23
randv2_64.pck
7.19
KB
-rw-r--r--
2026-02-03 21:23
randv3.pck
7.82
KB
-rw-r--r--
2026-02-03 21:23
re_tests.py
25.94
KB
-rwxr-xr-x
2026-03-26 17:22
regrtest.py
1.28
KB
-rwxr-xr-x
2026-03-26 17:22
relimport.py
27
B
-rw-r--r--
2026-03-26 17:22
reperf.py
538
B
-rw-r--r--
2026-03-26 17:22
seq_tests.py
15
KB
-rw-r--r--
2026-03-26 17:22
signalinterproctester.py
3.12
KB
-rw-r--r--
2026-03-26 17:22
ssl_servers.py
7.12
KB
-rw-r--r--
2026-03-26 17:22
ssltests.py
1.01
KB
-rw-r--r--
2026-03-26 17:22
string_tests.py
72.29
KB
-rw-r--r--
2026-03-26 17:22
test___all__.py
4.89
KB
-rw-r--r--
2026-03-26 17:22
test__colorize.py
6.51
KB
-rw-r--r--
2026-03-26 17:22
test__interpchannels.py
61.88
KB
-rw-r--r--
2026-03-26 17:22
test__interpreters.py
36.56
KB
-rw-r--r--
2026-03-26 17:22
test__locale.py
12.52
KB
-rw-r--r--
2026-03-26 17:22
test__opcode.py
5.82
KB
-rw-r--r--
2026-03-26 17:22
test__osx_support.py
13.53
KB
-rw-r--r--
2026-03-26 17:22
test_abc.py
23.81
KB
-rw-r--r--
2026-03-26 17:22
test_abstract_numbers.py
5.81
KB
-rw-r--r--
2026-03-26 17:22
test_android.py
18.37
KB
-rw-r--r--
2026-03-26 17:22
test_apple.py
4.66
KB
-rw-r--r--
2026-03-26 17:22
test_argparse.py
233.02
KB
-rw-r--r--
2026-03-26 17:22
test_array.py
58.79
KB
-rw-r--r--
2026-03-26 17:22
test_asdl_parser.py
4.44
KB
-rw-r--r--
2026-03-26 17:22
test_asyncgen.py
58.05
KB
-rw-r--r--
2026-03-26 17:22
test_atexit.py
3.2
KB
-rw-r--r--
2026-03-26 17:22
test_audit.py
10.24
KB
-rw-r--r--
2026-03-26 17:22
test_augassign.py
7.68
KB
-rw-r--r--
2026-03-26 17:22
test_base64.py
40.3
KB
-rw-r--r--
2026-03-26 17:22
test_baseexception.py
7.92
KB
-rw-r--r--
2026-03-26 17:22
test_bdb.py
44.6
KB
-rw-r--r--
2026-03-26 17:22
test_bigaddrspace.py
2.83
KB
-rw-r--r--
2026-03-26 17:22
test_bigmem.py
45.01
KB
-rw-r--r--
2026-03-26 17:22
test_binascii.py
22.16
KB
-rw-r--r--
2026-03-26 17:22
test_binop.py
14.14
KB
-rw-r--r--
2026-03-26 17:22
test_bisect.py
16.63
KB
-rw-r--r--
2026-03-26 17:22
test_bool.py
14.25
KB
-rw-r--r--
2026-03-26 17:22
test_buffer.py
173.64
KB
-rw-r--r--
2026-03-26 17:22
test_bufio.py
2.56
KB
-rw-r--r--
2026-03-26 17:22
test_builtin.py
101.42
KB
-rw-r--r--
2026-03-26 17:22
test_bytes.py
88.54
KB
-rw-r--r--
2026-03-26 17:22
test_bz2.py
45.25
KB
-rw-r--r--
2026-03-26 17:22
test_c_locale_coercion.py
20.96
KB
-rw-r--r--
2026-03-26 17:22
test_calendar.py
57.9
KB
-rw-r--r--
2026-03-26 17:22
test_call.py
39.54
KB
-rw-r--r--
2026-03-26 17:22
test_charmapcodec.py
1.77
KB
-rw-r--r--
2026-03-26 17:22
test_class.py
28.72
KB
-rw-r--r--
2026-03-26 17:22
test_clinic.py
146.98
KB
-rw-r--r--
2026-03-26 17:22
test_cmath.py
22.47
KB
-rw-r--r--
2026-03-26 17:22
test_cmd.py
7.82
KB
-rw-r--r--
2026-03-26 17:22
test_cmd_line.py
43.25
KB
-rw-r--r--
2026-03-26 17:22
test_cmd_line_script.py
36.12
KB
-rw-r--r--
2026-03-26 17:22
test_code.py
28.35
KB
-rw-r--r--
2026-03-26 17:22
test_code_module.py
13.46
KB
-rw-r--r--
2026-03-26 17:22
test_codeccallbacks.py
49.23
KB
-rw-r--r--
2026-03-26 17:22
test_codecencodings_cn.py
3.86
KB
-rw-r--r--
2026-03-26 17:22
test_codecencodings_hk.py
701
B
-rw-r--r--
2026-03-26 17:22
test_codecencodings_iso2022.py
3.65
KB
-rw-r--r--
2026-03-26 17:22
test_codecencodings_jp.py
4.79
KB
-rw-r--r--
2026-03-26 17:22
test_codecencodings_kr.py
2.96
KB
-rw-r--r--
2026-03-26 17:22
test_codecencodings_tw.py
681
B
-rw-r--r--
2026-03-26 17:22
test_codecmaps_cn.py
746
B
-rw-r--r--
2026-03-26 17:22
test_codecmaps_hk.py
386
B
-rw-r--r--
2026-03-26 17:22
test_codecmaps_jp.py
1.7
KB
-rw-r--r--
2026-03-26 17:22
test_codecmaps_kr.py
1.16
KB
-rw-r--r--
2026-03-26 17:22
test_codecmaps_tw.py
705
B
-rw-r--r--
2026-03-26 17:22
test_codecs.py
147.37
KB
-rw-r--r--
2026-03-26 17:22
test_codeop.py
8.68
KB
-rw-r--r--
2026-03-26 17:22
test_collections.py
93.72
KB
-rw-r--r--
2026-03-26 17:22
test_colorsys.py
4.27
KB
-rw-r--r--
2026-03-26 17:22
test_compare.py
17.46
KB
-rw-r--r--
2026-03-26 17:22
test_compile.py
95.51
KB
-rw-r--r--
2026-03-26 17:22
test_compileall.py
49.53
KB
-rw-r--r--
2026-03-26 17:22
test_compiler_assemble.py
4.79
KB
-rw-r--r--
2026-03-26 17:22
test_compiler_codegen.py
5.24
KB
-rw-r--r--
2026-03-26 17:22
test_complex.py
35.29
KB
-rw-r--r--
2026-03-26 17:22
test_configparser.py
87.21
KB
-rw-r--r--
2026-03-26 17:22
test_contains.py
3.35
KB
-rw-r--r--
2026-03-26 17:22
test_context.py
32.03
KB
-rw-r--r--
2026-03-26 17:22
test_contextlib.py
43.35
KB
-rw-r--r--
2026-03-26 17:22
test_contextlib_async.py
23.45
KB
-rw-r--r--
2026-03-26 17:22
test_copy.py
29.45
KB
-rw-r--r--
2026-03-26 17:22
test_copyreg.py
4.36
KB
-rw-r--r--
2026-03-26 17:22
test_coroutines.py
67.59
KB
-rw-r--r--
2026-03-26 17:22
test_cprofile.py
9.74
KB
-rw-r--r--
2026-03-26 17:22
test_csv.py
64.09
KB
-rw-r--r--
2026-03-26 17:22
test_curses.py
50.42
KB
-rw-r--r--
2026-03-26 17:22
test_datetime.py
2.67
KB
-rw-r--r--
2026-03-26 17:22
test_dbm.py
8.26
KB
-rw-r--r--
2026-03-26 17:22
test_dbm_dumb.py
14.29
KB
-rw-r--r--
2026-03-26 17:22
test_dbm_gnu.py
8.03
KB
-rw-r--r--
2026-03-26 17:22
test_dbm_ndbm.py
6.3
KB
-rw-r--r--
2026-03-26 17:22
test_dbm_sqlite3.py
10.84
KB
-rw-r--r--
2026-03-26 17:22
test_decimal.py
216.81
KB
-rw-r--r--
2026-03-26 17:22
test_decorators.py
10.73
KB
-rw-r--r--
2026-03-26 17:22
test_defaultdict.py
6.56
KB
-rw-r--r--
2026-03-26 17:22
test_deque.py
33.16
KB
-rw-r--r--
2026-03-26 17:22
test_descr.py
197.53
KB
-rw-r--r--
2026-03-26 17:22
test_descrtut.py
11.02
KB
-rw-r--r--
2026-03-26 17:22
test_devpoll.py
4.44
KB
-rw-r--r--
2026-03-26 17:22
test_dict.py
55.39
KB
-rw-r--r--
2026-03-26 17:22
test_dict_version.py
6.1
KB
-rw-r--r--
2026-03-26 17:22
test_dictcomps.py
6.55
KB
-rw-r--r--
2026-03-26 17:22
test_dictviews.py
14.82
KB
-rw-r--r--
2026-03-26 17:22
test_difflib.py
22.99
KB
-rw-r--r--
2026-03-26 17:22
test_difflib_expect.html
100.9
KB
-rw-r--r--
2026-02-03 21:23
test_dis.py
105.91
KB
-rw-r--r--
2026-03-26 17:22
test_docxmlrpc.py
9.1
KB
-rw-r--r--
2026-03-26 17:22
test_dtrace.py
7.98
KB
-rw-r--r--
2026-03-26 17:22
test_dynamic.py
6.08
KB
-rw-r--r--
2026-03-26 17:22
test_dynamicclassattribute.py
9.57
KB
-rw-r--r--
2026-03-26 17:22
test_eintr.py
627
B
-rw-r--r--
2026-03-26 17:22
test_embed.py
74.88
KB
-rw-r--r--
2026-03-26 17:22
test_ensurepip.py
11.49
KB
-rw-r--r--
2026-03-26 17:22
test_enum.py
196.11
KB
-rw-r--r--
2026-03-26 17:22
test_enumerate.py
9.14
KB
-rw-r--r--
2026-03-26 17:22
test_eof.py
8.01
KB
-rw-r--r--
2026-03-26 17:22
test_epoll.py
9.4
KB
-rw-r--r--
2026-03-26 17:22
test_errno.py
1.04
KB
-rw-r--r--
2026-03-26 17:22
test_except_star.py
39.7
KB
-rw-r--r--
2026-03-26 17:22
test_exception_group.py
37.06
KB
-rw-r--r--
2026-03-26 17:22
test_exception_hierarchy.py
7.54
KB
-rw-r--r--
2026-03-26 17:22
test_exception_variations.py
13.74
KB
-rw-r--r--
2026-03-26 17:22
test_exceptions.py
87.23
KB
-rw-r--r--
2026-03-26 17:22
test_extcall.py
14.69
KB
-rw-r--r--
2026-03-26 17:22
test_external_inspection.py
2.96
KB
-rw-r--r--
2026-03-26 17:22
test_faulthandler.py
31.47
KB
-rw-r--r--
2026-03-26 17:22
test_fcntl.py
8.59
KB
-rw-r--r--
2026-03-26 17:22
test_file.py
11.78
KB
-rw-r--r--
2026-03-26 17:22
test_file_eintr.py
10.74
KB
-rw-r--r--
2026-03-26 17:22
test_filecmp.py
15.66
KB
-rw-r--r--
2026-03-26 17:22
test_fileinput.py
37.86
KB
-rw-r--r--
2026-03-26 17:22
test_fileio.py
20.72
KB
-rw-r--r--
2026-03-26 17:22
test_fileutils.py
951
B
-rw-r--r--
2026-03-26 17:22
test_finalization.py
14.67
KB
-rw-r--r--
2026-03-26 17:22
test_float.py
65.38
KB
-rw-r--r--
2026-03-26 17:22
test_flufl.py
2.81
KB
-rw-r--r--
2026-03-26 17:22
test_fnmatch.py
10.68
KB
-rw-r--r--
2026-03-26 17:22
test_fork1.py
3.3
KB
-rw-r--r--
2026-03-26 17:22
test_format.py
28.54
KB
-rw-r--r--
2026-03-26 17:22
test_fractions.py
67.44
KB
-rw-r--r--
2026-03-26 17:22
test_frame.py
23.28
KB
-rw-r--r--
2026-03-26 17:22
test_frozen.py
2.2
KB
-rw-r--r--
2026-03-26 17:22
test_fstring.py
70.92
KB
-rw-r--r--
2026-03-26 17:22
test_ftplib.py
42.06
KB
-rw-r--r--
2026-03-26 17:22
test_funcattrs.py
17.29
KB
-rw-r--r--
2026-03-26 17:22
test_functools.py
118.41
KB
-rw-r--r--
2026-03-26 17:22
test_gc.py
52.16
KB
-rw-r--r--
2026-03-26 17:22
test_generated_cases.py
27.14
KB
-rw-r--r--
2026-03-26 17:22
test_generator_stop.py
943
B
-rw-r--r--
2026-03-26 17:22
test_generators.py
74.12
KB
-rw-r--r--
2026-03-26 17:22
test_genericalias.py
20
KB
-rw-r--r--
2026-03-26 17:22
test_genericclass.py
9.57
KB
-rw-r--r--
2026-03-26 17:22
test_genericpath.py
23.37
KB
-rw-r--r--
2026-03-26 17:22
test_genexps.py
7.3
KB
-rw-r--r--
2026-03-26 17:22
test_getopt.py
6.94
KB
-rw-r--r--
2026-03-26 17:22
test_getpass.py
6.36
KB
-rw-r--r--
2026-03-26 17:22
test_getpath.py
44.84
KB
-rw-r--r--
2026-03-26 17:22
test_gettext.py
45.41
KB
-rw-r--r--
2026-03-26 17:22
test_glob.py
24.29
KB
-rw-r--r--
2026-03-26 17:22
test_global.py
1.2
KB
-rw-r--r--
2026-03-26 17:22
test_grammar.py
64.9
KB
-rw-r--r--
2026-03-26 17:22
test_graphlib.py
8.31
KB
-rw-r--r--
2026-03-26 17:22
test_grp.py
3.67
KB
-rw-r--r--
2026-03-26 17:22
test_gzip.py
41.97
KB
-rw-r--r--
2026-03-26 17:22
test_hash.py
12.11
KB
-rw-r--r--
2026-03-26 17:22
test_hashlib.py
50.69
KB
-rw-r--r--
2026-03-26 17:22
test_heapq.py
16.42
KB
-rw-r--r--
2026-03-26 17:22
test_hmac.py
26.49
KB
-rw-r--r--
2026-03-26 17:22
test_html.py
4.23
KB
-rw-r--r--
2026-03-26 17:22
test_htmlparser.py
51.09
KB
-rw-r--r--
2026-03-26 17:22
test_http_cookiejar.py
81.84
KB
-rw-r--r--
2026-03-26 17:22
test_http_cookies.py
23.65
KB
-rw-r--r--
2026-03-26 17:22
test_httplib.py
99.32
KB
-rw-r--r--
2026-03-26 17:22
test_httpservers.py
62.86
KB
-rw-r--r--
2026-03-26 17:22
test_idle.py
862
B
-rw-r--r--
2026-03-26 17:22
test_imaplib.py
39.24
KB
-rw-r--r--
2026-03-26 17:22
test_index.py
8.37
KB
-rw-r--r--
2026-03-26 17:22
test_int.py
34.84
KB
-rw-r--r--
2026-03-26 17:22
test_int_literal.py
6.89
KB
-rw-r--r--
2026-03-26 17:22
test_io.py
186.35
KB
-rw-r--r--
2026-03-26 17:22
test_ioctl.py
8.42
KB
-rw-r--r--
2026-03-26 17:22
test_ipaddress.py
128.86
KB
-rw-r--r--
2026-03-26 17:22
test_isinstance.py
12.96
KB
-rw-r--r--
2026-03-26 17:22
test_iter.py
38.22
KB
-rw-r--r--
2026-03-26 17:22
test_iterlen.py
7.1
KB
-rw-r--r--
2026-03-26 17:22
test_itertools.py
114.87
KB
-rw-r--r--
2026-03-26 17:22
test_keyword.py
2
KB
-rw-r--r--
2026-03-26 17:22
test_keywordonlyarg.py
6.89
KB
-rw-r--r--
2026-03-26 17:22
test_kqueue.py
9.36
KB
-rw-r--r--
2026-03-26 17:22
test_largefile.py
11.02
KB
-rw-r--r--
2026-03-26 17:22
test_launcher.py
30.61
KB
-rw-r--r--
2026-03-26 17:22
test_linecache.py
14.18
KB
-rw-r--r--
2026-03-26 17:22
test_list.py
10.94
KB
-rw-r--r--
2026-03-26 17:22
test_listcomps.py
23.53
KB
-rw-r--r--
2026-03-26 17:22
test_lltrace.py
3.71
KB
-rw-r--r--
2026-03-26 17:22
test_locale.py
26.37
KB
-rw-r--r--
2026-03-26 17:22
test_logging.py
261.1
KB
-rw-r--r--
2026-03-26 17:22
test_long.py
64.49
KB
-rw-r--r--
2026-03-26 17:22
test_longexp.py
233
B
-rw-r--r--
2026-03-26 17:22
test_lzma.py
95.71
KB
-rw-r--r--
2026-03-26 17:22
test_mailbox.py
99.06
KB
-rw-r--r--
2026-03-26 17:22
test_marshal.py
25.23
KB
-rw-r--r--
2026-03-26 17:22
test_math.py
120.29
KB
-rw-r--r--
2026-03-26 17:22
test_math_property.py
1.15
KB
-rw-r--r--
2026-03-26 17:22
test_memoryio.py
35.23
KB
-rw-r--r--
2026-03-26 17:22
test_memoryview.py
24.12
KB
-rw-r--r--
2026-03-26 17:22
test_metaclass.py
6.97
KB
-rw-r--r--
2026-03-26 17:22
test_mimetypes.py
17.91
KB
-rw-r--r--
2026-03-26 17:22
test_minidom.py
72.31
KB
-rw-r--r--
2026-03-26 17:22
test_mmap.py
45.55
KB
-rw-r--r--
2026-03-26 17:22
test_modulefinder.py
12.21
KB
-rw-r--r--
2026-03-26 17:22
test_monitoring.py
69.38
KB
-rw-r--r--
2026-03-26 17:22
test_msvcrt.py
3.39
KB
-rw-r--r--
2026-03-26 17:22
test_multibytecodec.py
15.87
KB
-rw-r--r--
2026-03-26 17:22
test_multiprocessing_main_handling.py
11.48
KB
-rw-r--r--
2026-03-26 17:22
test_named_expressions.py
29.62
KB
-rw-r--r--
2026-03-26 17:22
test_netrc.py
12.09
KB
-rw-r--r--
2026-03-26 17:22
test_ntpath.py
75.9
KB
-rw-r--r--
2026-03-26 17:22
test_numeric_tower.py
8
KB
-rw-r--r--
2026-03-26 17:22
test_opcache.py
29.7
KB
-rw-r--r--
2026-03-26 17:22
test_opcodes.py
3.62
KB
-rw-r--r--
2026-03-26 17:22
test_openpty.py
600
B
-rw-r--r--
2026-03-26 17:22
test_operator.py
27.71
KB
-rw-r--r--
2026-03-26 17:22
test_optimizer.py
2.61
KB
-rw-r--r--
2026-03-26 17:22
test_optparse.py
61.39
KB
-rw-r--r--
2026-03-26 17:22
test_ordered_dict.py
40.01
KB
-rw-r--r--
2026-03-26 17:22
test_os.py
202.8
KB
-rw-r--r--
2026-03-26 17:22
test_osx_env.py
1.31
KB
-rw-r--r--
2026-03-26 17:22
test_patma.py
94.55
KB
-rw-r--r--
2026-03-26 17:22
test_pdb.py
133.58
KB
-rw-r--r--
2026-03-26 17:22
test_peepholer.py
43.65
KB
-rw-r--r--
2026-03-26 17:22
test_pep646_syntax.py
7.79
KB
-rw-r--r--
2026-03-26 17:22
test_perf_profiler.py
18.83
KB
-rw-r--r--
2026-03-26 17:22
test_perfmaps.py
773
B
-rw-r--r--
2026-03-26 17:22
test_pickle.py
27.61
KB
-rw-r--r--
2026-03-26 17:22
test_picklebuffer.py
4.99
KB
-rw-r--r--
2026-03-26 17:22
test_pickletools.py
16.78
KB
-rw-r--r--
2026-03-26 17:22
test_pkg.py
9.58
KB
-rw-r--r--
2026-03-26 17:22
test_pkgutil.py
26.22
KB
-rw-r--r--
2026-03-26 17:22
test_platform.py
26.69
KB
-rw-r--r--
2026-03-26 17:22
test_plistlib.py
48.91
KB
-rw-r--r--
2026-03-26 17:22
test_poll.py
7.49
KB
-rw-r--r--
2026-03-26 17:22
test_popen.py
2.36
KB
-rw-r--r--
2026-03-26 17:22
test_poplib.py
18.07
KB
-rw-r--r--
2026-03-26 17:22
test_positional_only_arg.py
18.44
KB
-rw-r--r--
2026-03-26 17:22
test_posix.py
99.63
KB
-rw-r--r--
2026-03-26 17:22
test_posixpath.py
51.64
KB
-rw-r--r--
2026-03-26 17:22
test_pow.py
6.38
KB
-rw-r--r--
2026-03-26 17:22
test_pprint.py
39.08
KB
-rw-r--r--
2026-03-26 17:22
test_print.py
8.05
KB
-rw-r--r--
2026-03-26 17:22
test_profile.py
8.95
KB
-rw-r--r--
2026-03-26 17:22
test_property.py
20.12
KB
-rw-r--r--
2026-03-26 17:22
test_pstats.py
5.38
KB
-rw-r--r--
2026-03-26 17:22
test_pty.py
16.18
KB
-rw-r--r--
2026-03-26 17:22
test_pulldom.py
12.33
KB
-rw-r--r--
2026-03-26 17:22
test_pwd.py
4.32
KB
-rw-r--r--
2026-03-26 17:22
test_py_compile.py
11.93
KB
-rw-r--r--
2026-03-26 17:22
test_pyclbr.py
10.11
KB
-rw-r--r--
2026-03-26 17:22
test_pyexpat.py
39.85
KB
-rw-r--r--
2026-03-26 17:22
test_queue.py
33.55
KB
-rw-r--r--
2026-03-26 17:22
test_quopri.py
7.87
KB
-rw-r--r--
2026-03-26 17:22
test_raise.py
13.85
KB
-rw-r--r--
2026-03-26 17:22
test_random.py
60.35
KB
-rw-r--r--
2026-03-26 17:22
test_range.py
26.99
KB
-rw-r--r--
2026-03-26 17:22
test_re.py
147.27
KB
-rw-r--r--
2026-03-26 17:22
test_readline.py
16.15
KB
-rw-r--r--
2026-03-26 17:22
test_regrtest.py
98.35
KB
-rw-r--r--
2026-03-26 17:22
test_repl.py
14.52
KB
-rw-r--r--
2026-03-26 17:22
test_reprlib.py
30.43
KB
-rw-r--r--
2026-03-26 17:22
test_resource.py
11.12
KB
-rw-r--r--
2026-03-26 17:22
test_richcmp.py
11.95
KB
-rw-r--r--
2026-03-26 17:22
test_rlcompleter.py
7.96
KB
-rw-r--r--
2026-03-26 17:22
test_robotparser.py
15.6
KB
-rw-r--r--
2026-03-26 17:22
test_runpy.py
34.12
KB
-rw-r--r--
2026-03-26 17:22
test_sax.py
54.63
KB
-rw-r--r--
2026-03-26 17:22
test_sched.py
7.38
KB
-rw-r--r--
2026-03-26 17:22
test_scope.py
21.94
KB
-rw-r--r--
2026-03-26 17:22
test_script_helper.py
5.82
KB
-rw-r--r--
2026-03-26 17:22
test_secrets.py
4.28
KB
-rw-r--r--
2026-03-26 17:22
test_select.py
3.42
KB
-rw-r--r--
2026-03-26 17:22
test_selectors.py
19.87
KB
-rw-r--r--
2026-03-26 17:22
test_set.py
73.22
KB
-rw-r--r--
2026-03-26 17:22
test_setcomps.py
5.24
KB
-rw-r--r--
2026-03-26 17:22
test_shelve.py
6.42
KB
-rw-r--r--
2026-03-26 17:22
test_shlex.py
13.39
KB
-rw-r--r--
2026-03-26 17:22
test_shutil.py
140.16
KB
-rw-r--r--
2026-03-26 17:22
test_signal.py
52.78
KB
-rw-r--r--
2026-03-26 17:22
test_site.py
36.06
KB
-rw-r--r--
2026-03-26 17:22
test_slice.py
9.46
KB
-rw-r--r--
2026-03-26 17:22
test_smtplib.py
62.33
KB
-rw-r--r--
2026-03-26 17:22
test_smtpnet.py
3.11
KB
-rw-r--r--
2026-03-26 17:22
test_socket.py
271.05
KB
-rw-r--r--
2026-03-26 17:22
test_socketserver.py
17.39
KB
-rw-r--r--
2026-03-26 17:22
test_sort.py
14.48
KB
-rw-r--r--
2026-03-26 17:22
test_source_encoding.py
15.94
KB
-rw-r--r--
2026-03-26 17:22
test_ssl.py
229.41
KB
-rw-r--r--
2026-03-26 17:22
test_stable_abi_ctypes.py
26.22
KB
-rw-r--r--
2026-03-26 17:22
test_startfile.py
1.7
KB
-rw-r--r--
2026-03-26 17:22
test_stat.py
13.25
KB
-rw-r--r--
2026-03-26 17:22
test_statistics.py
131.36
KB
-rw-r--r--
2026-03-26 17:22
test_str.py
126.35
KB
-rw-r--r--
2026-03-26 17:22
test_strftime.py
7.87
KB
-rw-r--r--
2026-03-26 17:22
test_string.py
21.86
KB
-rw-r--r--
2026-03-26 17:22
test_string_literals.py
14.1
KB
-rw-r--r--
2026-03-26 17:22
test_stringprep.py
3.04
KB
-rw-r--r--
2026-03-26 17:22
test_strptime.py
42.79
KB
-rw-r--r--
2026-03-26 17:22
test_strtod.py
20.06
KB
-rw-r--r--
2026-03-26 17:22
test_struct.py
40.47
KB
-rw-r--r--
2026-03-26 17:22
test_structseq.py
14.19
KB
-rw-r--r--
2026-03-26 17:22
test_subclassinit.py
8.04
KB
-rw-r--r--
2026-03-26 17:22
test_subprocess.py
172.83
KB
-rw-r--r--
2026-03-26 17:22
test_sundry.py
1.02
KB
-rw-r--r--
2026-03-26 17:22
test_super.py
15.68
KB
-rw-r--r--
2026-03-26 17:22
test_support.py
27.95
KB
-rw-r--r--
2026-03-26 17:22
test_symtable.py
20.65
KB
-rw-r--r--
2026-03-26 17:22
test_syntax.py
80.5
KB
-rw-r--r--
2026-03-26 17:22
test_sys.py
74.12
KB
-rw-r--r--
2026-03-26 17:22
test_sys_setprofile.py
14.77
KB
-rw-r--r--
2026-03-26 17:22
test_sys_settrace.py
86.74
KB
-rw-r--r--
2026-03-26 17:22
test_sysconfig.py
29.64
KB
-rw-r--r--
2026-03-26 17:22
test_syslog.py
4.7
KB
-rw-r--r--
2026-03-26 17:22
test_tabnanny.py
13.9
KB
-rw-r--r--
2026-03-26 17:22
test_tarfile.py
187.4
KB
-rw-r--r--
2026-03-26 17:22
test_tcl.py
31.6
KB
-rw-r--r--
2026-03-26 17:22
test_tempfile.py
75.5
KB
-rw-r--r--
2026-03-26 17:22
test_termios.py
13.02
KB
-rw-r--r--
2026-03-26 17:22
test_textwrap.py
41.88
KB
-rw-r--r--
2026-03-26 17:22
test_thread.py
14.35
KB
-rw-r--r--
2026-03-26 17:22
test_threadedtempfile.py
2.03
KB
-rw-r--r--
2026-03-26 17:22
test_threading.py
79.5
KB
-rw-r--r--
2026-03-26 17:22
test_threading_local.py
7.01
KB
-rw-r--r--
2026-03-26 17:22
test_threadsignals.py
9.87
KB
-rw-r--r--
2026-03-26 17:22
test_time.py
45.07
KB
-rw-r--r--
2026-03-26 17:22
test_timeit.py
15.2
KB
-rw-r--r--
2026-03-26 17:22
test_timeout.py
10.65
KB
-rw-r--r--
2026-03-26 17:22
test_tokenize.py
121.49
KB
-rw-r--r--
2026-03-26 17:22
test_trace.py
21.72
KB
-rw-r--r--
2026-03-26 17:22
test_traceback.py
187.96
KB
-rw-r--r--
2026-03-26 17:22
test_tracemalloc.py
41.3
KB
-rw-r--r--
2026-03-26 17:22
test_ttk_textonly.py
17.45
KB
-rw-r--r--
2026-03-26 17:22
test_tty.py
3.63
KB
-rw-r--r--
2026-03-26 17:22
test_tuple.py
19.8
KB
-rw-r--r--
2026-03-26 17:22
test_turtle.py
16.42
KB
-rw-r--r--
2026-03-26 17:22
test_type_aliases.py
12.74
KB
-rw-r--r--
2026-03-26 17:22
test_type_annotations.py
6.23
KB
-rw-r--r--
2026-03-26 17:22
test_type_cache.py
7.58
KB
-rw-r--r--
2026-03-26 17:22
test_type_comments.py
11.01
KB
-rw-r--r--
2026-03-26 17:22
test_type_params.py
44.45
KB
-rw-r--r--
2026-03-26 17:22
test_typechecks.py
2.55
KB
-rw-r--r--
2026-03-26 17:22
test_types.py
87.9
KB
-rw-r--r--
2026-03-26 17:22
test_typing.py
373.85
KB
-rw-r--r--
2026-03-26 17:22
test_ucn.py
9.71
KB
-rw-r--r--
2026-03-26 17:22
test_unary.py
1.52
KB
-rw-r--r--
2026-03-26 17:22
test_unicode_file.py
5.72
KB
-rw-r--r--
2026-03-26 17:22
test_unicode_file_functions.py
6.91
KB
-rw-r--r--
2026-03-26 17:22
test_unicode_identifiers.py
997
B
-rw-r--r--
2026-03-26 17:22
test_unicodedata.py
32.39
KB
-rw-r--r--
2026-03-26 17:22
test_univnewlines.py
3.85
KB
-rw-r--r--
2026-03-26 17:22
test_unpack.py
3.51
KB
-rw-r--r--
2026-03-26 17:22
test_unpack_ex.py
9.98
KB
-rw-r--r--
2026-03-26 17:22
test_unparse.py
30
KB
-rw-r--r--
2026-03-26 17:22
test_urllib.py
72.58
KB
-rw-r--r--
2026-03-26 17:22
test_urllib2.py
81.34
KB
-rw-r--r--
2026-03-26 17:22
test_urllib2_localnet.py
24.22
KB
-rw-r--r--
2026-03-26 17:22
test_urllib2net.py
15.6
KB
-rw-r--r--
2026-03-26 17:22
test_urllib_response.py
2.04
KB
-rw-r--r--
2026-03-26 17:22
test_urllibnet.py
9.37
KB
-rw-r--r--
2026-03-26 17:22
test_urlparse.py
79.89
KB
-rw-r--r--
2026-03-26 17:22
test_userdict.py
7.82
KB
-rw-r--r--
2026-03-26 17:22
test_userlist.py
2.23
KB
-rw-r--r--
2026-03-26 17:22
test_userstring.py
2.48
KB
-rw-r--r--
2026-03-26 17:22
test_utf8_mode.py
10.31
KB
-rw-r--r--
2026-03-26 17:22
test_utf8source.py
1.08
KB
-rw-r--r--
2026-03-26 17:22
test_uuid.py
45.51
KB
-rw-r--r--
2026-03-26 17:22
test_venv.py
43.4
KB
-rw-r--r--
2026-03-26 17:22
test_wait3.py
1.74
KB
-rw-r--r--
2026-03-26 17:22
test_wait4.py
1.14
KB
-rw-r--r--
2026-03-26 17:22
test_wave.py
9.12
KB
-rw-r--r--
2026-03-26 17:22
test_weakref.py
78.11
KB
-rw-r--r--
2026-03-26 17:22
test_weakset.py
16.28
KB
-rw-r--r--
2026-03-26 17:22
test_webbrowser.py
17.31
KB
-rw-r--r--
2026-03-26 17:22
test_winapi.py
5.8
KB
-rw-r--r--
2026-03-26 17:22
test_winconsoleio.py
8.06
KB
-rw-r--r--
2026-03-26 17:22
test_winreg.py
23.71
KB
-rw-r--r--
2026-03-26 17:22
test_winsound.py
5.17
KB
-rw-r--r--
2026-03-26 17:22
test_with.py
27.77
KB
-rw-r--r--
2026-03-26 17:22
test_wmi.py
3.31
KB
-rw-r--r--
2026-03-26 17:22
test_wsgiref.py
29.89
KB
-rw-r--r--
2026-03-26 17:22
test_xml_dom_minicompat.py
4.18
KB
-rw-r--r--
2026-03-26 17:22
test_xml_dom_xmlbuilder.py
3.1
KB
-rw-r--r--
2026-03-26 17:22
test_xml_etree.py
176.35
KB
-rw-r--r--
2026-03-26 17:22
test_xml_etree_c.py
9.34
KB
-rw-r--r--
2026-03-26 17:22
test_xmlrpc.py
58.32
KB
-rw-r--r--
2026-03-26 17:22
test_xpickle.py
9.9
KB
-rw-r--r--
2026-03-26 17:22
test_xxlimited.py
2.46
KB
-rw-r--r--
2026-03-26 17:22
test_xxtestfuzz.py
690
B
-rw-r--r--
2026-03-26 17:22
test_yield_from.py
50.36
KB
-rw-r--r--
2026-03-26 17:22
test_zipapp.py
17.58
KB
-rw-r--r--
2026-03-26 17:22
test_zipfile64.py
5.78
KB
-rw-r--r--
2026-03-26 17:22
test_zipimport.py
39.21
KB
-rw-r--r--
2026-03-26 17:22
test_zipimport_support.py
10.61
KB
-rw-r--r--
2026-03-26 17:22
test_zlib.py
41.65
KB
-rw-r--r--
2026-03-26 17:22
testcodec.py
1.02
KB
-rw-r--r--
2026-03-26 17:22
tf_inherit_check.py
714
B
-rw-r--r--
2026-03-26 17:22
win_console_handler.py
1.38
KB
-rw-r--r--
2026-03-26 17:22
xmltests.py
435
B
-rw-r--r--
2026-03-26 17:22
xpickle_worker.py
2.06
KB
-rw-r--r--
2026-03-26 17:22
Save
Rename
import copy import ntpath import pathlib import posixpath import unittest from test.support import verbose try: # If we are in a source tree, use the original source file for tests SOURCE = (pathlib.Path(__file__).absolute().parent.parent.parent / "Modules/getpath.py").read_bytes() except FileNotFoundError: # Try from _testcapimodule instead from _testinternalcapi import get_getpath_codeobject SOURCE = get_getpath_codeobject() class MockGetPathTests(unittest.TestCase): def __init__(self, *a, **kw): super().__init__(*a, **kw) self.maxDiff = None def test_normal_win32(self): "Test a 'standard' install layout on Windows." ns = MockNTNamespace( argv0=r"C:\Python\python.exe", real_executable=r"C:\Python\python.exe", ) ns.add_known_xfile(r"C:\Python\python.exe") ns.add_known_file(r"C:\Python\Lib\os.py") ns.add_known_dir(r"C:\Python\DLLs") expected = dict( executable=r"C:\Python\python.exe", base_executable=r"C:\Python\python.exe", prefix=r"C:\Python", exec_prefix=r"C:\Python", module_search_paths_set=1, module_search_paths=[ r"C:\Python\python98.zip", r"C:\Python\DLLs", r"C:\Python\Lib", r"C:\Python", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_buildtree_win32(self): "Test an in-build-tree layout on Windows." ns = MockNTNamespace( argv0=r"C:\CPython\PCbuild\amd64\python.exe", real_executable=r"C:\CPython\PCbuild\amd64\python.exe", ) ns.add_known_xfile(r"C:\CPython\PCbuild\amd64\python.exe") ns.add_known_file(r"C:\CPython\Lib\os.py") ns.add_known_file(r"C:\CPython\PCbuild\amd64\pybuilddir.txt", [""]) expected = dict( executable=r"C:\CPython\PCbuild\amd64\python.exe", base_executable=r"C:\CPython\PCbuild\amd64\python.exe", prefix=r"C:\CPython", exec_prefix=r"C:\CPython", build_prefix=r"C:\CPython", _is_python_build=1, module_search_paths_set=1, module_search_paths=[ r"C:\CPython\PCbuild\amd64\python98.zip", r"C:\CPython\PCbuild\amd64", r"C:\CPython\Lib", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_venv_win32(self): """Test a venv layout on Windows. This layout is discovered by the presence of %__PYVENV_LAUNCHER__%, specifying the original launcher executable. site.py is responsible for updating prefix and exec_prefix. """ ns = MockNTNamespace( argv0=r"C:\Python\python.exe", ENV___PYVENV_LAUNCHER__=r"C:\venv\Scripts\python.exe", real_executable=r"C:\Python\python.exe", ) ns.add_known_xfile(r"C:\Python\python.exe") ns.add_known_xfile(r"C:\venv\Scripts\python.exe") ns.add_known_file(r"C:\Python\Lib\os.py") ns.add_known_dir(r"C:\Python\DLLs") ns.add_known_file(r"C:\venv\pyvenv.cfg", [ r"home = C:\Python" ]) expected = dict( executable=r"C:\venv\Scripts\python.exe", prefix=r"C:\Python", exec_prefix=r"C:\Python", base_executable=r"C:\Python\python.exe", base_prefix=r"C:\Python", base_exec_prefix=r"C:\Python", module_search_paths_set=1, module_search_paths=[ r"C:\Python\python98.zip", r"C:\Python\DLLs", r"C:\Python\Lib", r"C:\Python", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_registry_win32(self): """Test registry lookup on Windows. On Windows there are registry entries that are intended for other applications to register search paths. """ hkey = rf"HKLM\Software\Python\PythonCore\9.8-XY\PythonPath" winreg = MockWinreg({ hkey: None, f"{hkey}\\Path1": "path1-dir", f"{hkey}\\Path1\\Subdir": "not-subdirs", }) ns = MockNTNamespace( argv0=r"C:\Python\python.exe", real_executable=r"C:\Python\python.exe", winreg=winreg, ) ns.add_known_xfile(r"C:\Python\python.exe") ns.add_known_file(r"C:\Python\Lib\os.py") ns.add_known_dir(r"C:\Python\DLLs") expected = dict( module_search_paths_set=1, module_search_paths=[ r"C:\Python\python98.zip", "path1-dir", # should not contain not-subdirs r"C:\Python\DLLs", r"C:\Python\Lib", r"C:\Python", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) ns["config"]["use_environment"] = 0 ns["config"]["module_search_paths_set"] = 0 ns["config"]["module_search_paths"] = None expected = dict( module_search_paths_set=1, module_search_paths=[ r"C:\Python\python98.zip", r"C:\Python\DLLs", r"C:\Python\Lib", r"C:\Python", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_symlink_normal_win32(self): "Test a 'standard' install layout via symlink on Windows." ns = MockNTNamespace( argv0=r"C:\LinkedFrom\python.exe", real_executable=r"C:\Python\python.exe", ) ns.add_known_xfile(r"C:\LinkedFrom\python.exe") ns.add_known_xfile(r"C:\Python\python.exe") ns.add_known_link(r"C:\LinkedFrom\python.exe", r"C:\Python\python.exe") ns.add_known_file(r"C:\Python\Lib\os.py") ns.add_known_dir(r"C:\Python\DLLs") expected = dict( executable=r"C:\LinkedFrom\python.exe", base_executable=r"C:\LinkedFrom\python.exe", prefix=r"C:\Python", exec_prefix=r"C:\Python", module_search_paths_set=1, module_search_paths=[ r"C:\Python\python98.zip", r"C:\Python\DLLs", r"C:\Python\Lib", r"C:\Python", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_symlink_buildtree_win32(self): "Test an in-build-tree layout via symlink on Windows." ns = MockNTNamespace( argv0=r"C:\LinkedFrom\python.exe", real_executable=r"C:\CPython\PCbuild\amd64\python.exe", ) ns.add_known_xfile(r"C:\LinkedFrom\python.exe") ns.add_known_xfile(r"C:\CPython\PCbuild\amd64\python.exe") ns.add_known_link(r"C:\LinkedFrom\python.exe", r"C:\CPython\PCbuild\amd64\python.exe") ns.add_known_file(r"C:\CPython\Lib\os.py") ns.add_known_file(r"C:\CPython\PCbuild\amd64\pybuilddir.txt", [""]) expected = dict( executable=r"C:\LinkedFrom\python.exe", base_executable=r"C:\LinkedFrom\python.exe", prefix=r"C:\CPython", exec_prefix=r"C:\CPython", build_prefix=r"C:\CPython", _is_python_build=1, module_search_paths_set=1, module_search_paths=[ r"C:\CPython\PCbuild\amd64\python98.zip", r"C:\CPython\PCbuild\amd64", r"C:\CPython\Lib", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_buildtree_pythonhome_win32(self): "Test an out-of-build-tree layout on Windows with PYTHONHOME override." ns = MockNTNamespace( argv0=r"C:\Out\python.exe", real_executable=r"C:\Out\python.exe", ENV_PYTHONHOME=r"C:\CPython", ) ns.add_known_xfile(r"C:\Out\python.exe") ns.add_known_file(r"C:\CPython\Lib\os.py") ns.add_known_file(r"C:\Out\pybuilddir.txt", [""]) expected = dict( executable=r"C:\Out\python.exe", base_executable=r"C:\Out\python.exe", prefix=r"C:\CPython", exec_prefix=r"C:\CPython", # This build_prefix is a miscalculation, because we have # moved the output direction out of the prefix. # Specify PYTHONHOME to get the correct prefix/exec_prefix build_prefix="C:\\", _is_python_build=1, module_search_paths_set=1, module_search_paths=[ r"C:\Out\python98.zip", r"C:\Out", r"C:\CPython\Lib", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_no_dlls_win32(self): "Test a layout on Windows with no DLLs directory." ns = MockNTNamespace( argv0=r"C:\Python\python.exe", real_executable=r"C:\Python\python.exe", ) ns.add_known_xfile(r"C:\Python\python.exe") ns.add_known_file(r"C:\Python\Lib\os.py") expected = dict( executable=r"C:\Python\python.exe", base_executable=r"C:\Python\python.exe", prefix=r"C:\Python", exec_prefix=r"C:\Python", module_search_paths_set=1, module_search_paths=[ r"C:\Python\python98.zip", r"C:\Python", r"C:\Python\Lib", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_normal_posix(self): "Test a 'standard' install layout on *nix" ns = MockPosixNamespace( PREFIX="/usr", argv0="python", ENV_PATH="/usr/bin", ) ns.add_known_xfile("/usr/bin/python") ns.add_known_file("/usr/lib/python9.8/os.py") ns.add_known_dir("/usr/lib/python9.8/lib-dynload") expected = dict( executable="/usr/bin/python", base_executable="/usr/bin/python", prefix="/usr", exec_prefix="/usr", module_search_paths_set=1, module_search_paths=[ "/usr/lib/python98.zip", "/usr/lib/python9.8", "/usr/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_buildpath_posix(self): """Test an in-build-tree layout on POSIX. This layout is discovered from the presence of pybuilddir.txt, which contains the relative path from the executable's directory to the platstdlib path. """ ns = MockPosixNamespace( argv0=r"/home/cpython/python", PREFIX="/usr/local", ) ns.add_known_xfile("/home/cpython/python") ns.add_known_xfile("/usr/local/bin/python") ns.add_known_file("/home/cpython/pybuilddir.txt", ["build/lib.linux-x86_64-9.8"]) ns.add_known_file("/home/cpython/Lib/os.py") ns.add_known_dir("/home/cpython/lib-dynload") expected = dict( executable="/home/cpython/python", prefix="/usr/local", exec_prefix="/usr/local", base_executable="/home/cpython/python", build_prefix="/home/cpython", _is_python_build=1, module_search_paths_set=1, module_search_paths=[ "/usr/local/lib/python98.zip", "/home/cpython/Lib", "/home/cpython/build/lib.linux-x86_64-9.8", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_venv_posix(self): "Test a venv layout on *nix." ns = MockPosixNamespace( argv0="python", PREFIX="/usr", ENV_PATH="/venv/bin:/usr/bin", ) ns.add_known_xfile("/usr/bin/python") ns.add_known_xfile("/venv/bin/python") ns.add_known_file("/usr/lib/python9.8/os.py") ns.add_known_dir("/usr/lib/python9.8/lib-dynload") ns.add_known_file("/venv/pyvenv.cfg", [ r"home = /usr/bin" ]) expected = dict( executable="/venv/bin/python", prefix="/usr", exec_prefix="/usr", base_executable="/usr/bin/python", base_prefix="/usr", base_exec_prefix="/usr", module_search_paths_set=1, module_search_paths=[ "/usr/lib/python98.zip", "/usr/lib/python9.8", "/usr/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_venv_changed_name_posix(self): "Test a venv layout on *nix." ns = MockPosixNamespace( argv0="python", PREFIX="/usr", ENV_PATH="/venv/bin:/usr/bin", ) ns.add_known_xfile("/usr/bin/python3") ns.add_known_xfile("/venv/bin/python") ns.add_known_link("/venv/bin/python", "/usr/bin/python3") ns.add_known_file("/usr/lib/python9.8/os.py") ns.add_known_dir("/usr/lib/python9.8/lib-dynload") ns.add_known_file("/venv/pyvenv.cfg", [ r"home = /usr/bin" ]) expected = dict( executable="/venv/bin/python", prefix="/usr", exec_prefix="/usr", base_executable="/usr/bin/python3", base_prefix="/usr", base_exec_prefix="/usr", module_search_paths_set=1, module_search_paths=[ "/usr/lib/python98.zip", "/usr/lib/python9.8", "/usr/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_venv_non_installed_zip_path_posix(self): "Test a venv created from non-installed python has correct zip path.""" ns = MockPosixNamespace( argv0="/venv/bin/python", PREFIX="/usr", ENV_PATH="/venv/bin:/usr/bin", ) ns.add_known_xfile("/path/to/non-installed/bin/python") ns.add_known_xfile("/venv/bin/python") ns.add_known_link("/venv/bin/python", "/path/to/non-installed/bin/python") ns.add_known_file("/path/to/non-installed/lib/python9.8/os.py") ns.add_known_dir("/path/to/non-installed/lib/python9.8/lib-dynload") ns.add_known_file("/venv/pyvenv.cfg", [ r"home = /path/to/non-installed" ]) expected = dict( executable="/venv/bin/python", prefix="/path/to/non-installed", exec_prefix="/path/to/non-installed", base_executable="/path/to/non-installed/bin/python", base_prefix="/path/to/non-installed", base_exec_prefix="/path/to/non-installed", module_search_paths_set=1, module_search_paths=[ "/path/to/non-installed/lib/python98.zip", "/path/to/non-installed/lib/python9.8", "/path/to/non-installed/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_venv_changed_name_copy_posix(self): "Test a venv --copies layout on *nix that lacks a distributed 'python'" ns = MockPosixNamespace( argv0="python", PREFIX="/usr", ENV_PATH="/venv/bin:/usr/bin", ) ns.add_known_xfile("/usr/bin/python9") ns.add_known_xfile("/venv/bin/python") ns.add_known_file("/usr/lib/python9.8/os.py") ns.add_known_dir("/usr/lib/python9.8/lib-dynload") ns.add_known_file("/venv/pyvenv.cfg", [ r"home = /usr/bin" ]) expected = dict( executable="/venv/bin/python", prefix="/usr", exec_prefix="/usr", base_executable="/usr/bin/python9", base_prefix="/usr", base_exec_prefix="/usr", module_search_paths_set=1, module_search_paths=[ "/usr/lib/python98.zip", "/usr/lib/python9.8", "/usr/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_symlink_normal_posix(self): "Test a 'standard' install layout via symlink on *nix" ns = MockPosixNamespace( PREFIX="/usr", argv0="/linkfrom/python", ) ns.add_known_xfile("/linkfrom/python") ns.add_known_xfile("/usr/bin/python") ns.add_known_link("/linkfrom/python", "/usr/bin/python") ns.add_known_file("/usr/lib/python9.8/os.py") ns.add_known_dir("/usr/lib/python9.8/lib-dynload") expected = dict( executable="/linkfrom/python", base_executable="/linkfrom/python", prefix="/usr", exec_prefix="/usr", module_search_paths_set=1, module_search_paths=[ "/usr/lib/python98.zip", "/usr/lib/python9.8", "/usr/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_symlink_buildpath_posix(self): """Test an in-build-tree layout on POSIX. This layout is discovered from the presence of pybuilddir.txt, which contains the relative path from the executable's directory to the platstdlib path. """ ns = MockPosixNamespace( argv0=r"/linkfrom/python", PREFIX="/usr/local", ) ns.add_known_xfile("/linkfrom/python") ns.add_known_xfile("/home/cpython/python") ns.add_known_link("/linkfrom/python", "/home/cpython/python") ns.add_known_xfile("/usr/local/bin/python") ns.add_known_file("/home/cpython/pybuilddir.txt", ["build/lib.linux-x86_64-9.8"]) ns.add_known_file("/home/cpython/Lib/os.py") ns.add_known_dir("/home/cpython/lib-dynload") expected = dict( executable="/linkfrom/python", prefix="/usr/local", exec_prefix="/usr/local", base_executable="/linkfrom/python", build_prefix="/home/cpython", _is_python_build=1, module_search_paths_set=1, module_search_paths=[ "/usr/local/lib/python98.zip", "/home/cpython/Lib", "/home/cpython/build/lib.linux-x86_64-9.8", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_custom_platlibdir_posix(self): "Test an install with custom platlibdir on *nix" ns = MockPosixNamespace( PREFIX="/usr", argv0="/linkfrom/python", PLATLIBDIR="lib64", ) ns.add_known_xfile("/usr/bin/python") ns.add_known_file("/usr/lib64/python9.8/os.py") ns.add_known_dir("/usr/lib64/python9.8/lib-dynload") expected = dict( executable="/linkfrom/python", base_executable="/linkfrom/python", prefix="/usr", exec_prefix="/usr", module_search_paths_set=1, module_search_paths=[ "/usr/lib64/python98.zip", "/usr/lib64/python9.8", "/usr/lib64/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_framework_macos(self): """ Test framework layout on macOS This layout is primarily detected using a compile-time option (WITH_NEXT_FRAMEWORK). """ ns = MockPosixNamespace( os_name="darwin", argv0="/Library/Frameworks/Python.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/Python", WITH_NEXT_FRAMEWORK=1, PREFIX="/Library/Frameworks/Python.framework/Versions/9.8", EXEC_PREFIX="/Library/Frameworks/Python.framework/Versions/9.8", ENV___PYVENV_LAUNCHER__="/Library/Frameworks/Python.framework/Versions/9.8/bin/python9.8", real_executable="/Library/Frameworks/Python.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/Python", library="/Library/Frameworks/Python.framework/Versions/9.8/Python", ) ns.add_known_xfile("/Library/Frameworks/Python.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/Python") ns.add_known_xfile("/Library/Frameworks/Python.framework/Versions/9.8/bin/python9.8") ns.add_known_dir("/Library/Frameworks/Python.framework/Versions/9.8/lib/python9.8/lib-dynload") ns.add_known_file("/Library/Frameworks/Python.framework/Versions/9.8/lib/python9.8/os.py") # This is definitely not the stdlib (see discussion in bpo-46890) #ns.add_known_file("/Library/Frameworks/lib/python98.zip") expected = dict( executable="/Library/Frameworks/Python.framework/Versions/9.8/bin/python9.8", prefix="/Library/Frameworks/Python.framework/Versions/9.8", exec_prefix="/Library/Frameworks/Python.framework/Versions/9.8", base_executable="/Library/Frameworks/Python.framework/Versions/9.8/bin/python9.8", base_prefix="/Library/Frameworks/Python.framework/Versions/9.8", base_exec_prefix="/Library/Frameworks/Python.framework/Versions/9.8", module_search_paths_set=1, module_search_paths=[ "/Library/Frameworks/Python.framework/Versions/9.8/lib/python98.zip", "/Library/Frameworks/Python.framework/Versions/9.8/lib/python9.8", "/Library/Frameworks/Python.framework/Versions/9.8/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_alt_framework_macos(self): """ Test framework layout on macOS with alternate framework name ``--with-framework-name=DebugPython`` This layout is primarily detected using a compile-time option (WITH_NEXT_FRAMEWORK). """ ns = MockPosixNamespace( argv0="/Library/Frameworks/DebugPython.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/DebugPython", os_name="darwin", WITH_NEXT_FRAMEWORK=1, PREFIX="/Library/Frameworks/DebugPython.framework/Versions/9.8", EXEC_PREFIX="/Library/Frameworks/DebugPython.framework/Versions/9.8", ENV___PYVENV_LAUNCHER__="/Library/Frameworks/DebugPython.framework/Versions/9.8/bin/python9.8", real_executable="/Library/Frameworks/DebugPython.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/DebugPython", library="/Library/Frameworks/DebugPython.framework/Versions/9.8/DebugPython", PYTHONPATH=None, ENV_PYTHONHOME=None, ENV_PYTHONEXECUTABLE=None, executable_dir=None, py_setpath=None, ) ns.add_known_xfile("/Library/Frameworks/DebugPython.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/DebugPython") ns.add_known_xfile("/Library/Frameworks/DebugPython.framework/Versions/9.8/bin/python9.8") ns.add_known_dir("/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python9.8/lib-dynload") ns.add_known_xfile("/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python9.8/os.py") # This is definitely not the stdlib (see discussion in bpo-46890) #ns.add_known_xfile("/Library/lib/python98.zip") expected = dict( executable="/Library/Frameworks/DebugPython.framework/Versions/9.8/bin/python9.8", prefix="/Library/Frameworks/DebugPython.framework/Versions/9.8", exec_prefix="/Library/Frameworks/DebugPython.framework/Versions/9.8", base_executable="/Library/Frameworks/DebugPython.framework/Versions/9.8/bin/python9.8", base_prefix="/Library/Frameworks/DebugPython.framework/Versions/9.8", base_exec_prefix="/Library/Frameworks/DebugPython.framework/Versions/9.8", module_search_paths_set=1, module_search_paths=[ "/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python98.zip", "/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python9.8", "/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_venv_framework_macos(self): """Test a venv layout on macOS using a framework build """ venv_path = "/tmp/workdir/venv" ns = MockPosixNamespace( os_name="darwin", argv0="/Library/Frameworks/Python.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/Python", WITH_NEXT_FRAMEWORK=1, PREFIX="/Library/Frameworks/Python.framework/Versions/9.8", EXEC_PREFIX="/Library/Frameworks/Python.framework/Versions/9.8", ENV___PYVENV_LAUNCHER__=f"{venv_path}/bin/python", real_executable="/Library/Frameworks/Python.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/Python", library="/Library/Frameworks/Python.framework/Versions/9.8/Python", ) ns.add_known_dir(venv_path) ns.add_known_dir(f"{venv_path}/bin") ns.add_known_dir(f"{venv_path}/lib") ns.add_known_dir(f"{venv_path}/lib/python9.8") ns.add_known_xfile(f"{venv_path}/bin/python") ns.add_known_xfile("/Library/Frameworks/Python.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/Python") ns.add_known_xfile("/Library/Frameworks/Python.framework/Versions/9.8/bin/python9.8") ns.add_known_dir("/Library/Frameworks/Python.framework/Versions/9.8/lib/python9.8/lib-dynload") ns.add_known_xfile("/Library/Frameworks/Python.framework/Versions/9.8/lib/python9.8/os.py") ns.add_known_file(f"{venv_path}/pyvenv.cfg", [ "home = /Library/Frameworks/Python.framework/Versions/9.8/bin" ]) expected = dict( executable=f"{venv_path}/bin/python", prefix="/Library/Frameworks/Python.framework/Versions/9.8", exec_prefix="/Library/Frameworks/Python.framework/Versions/9.8", base_executable="/Library/Frameworks/Python.framework/Versions/9.8/bin/python9.8", base_prefix="/Library/Frameworks/Python.framework/Versions/9.8", base_exec_prefix="/Library/Frameworks/Python.framework/Versions/9.8", module_search_paths_set=1, module_search_paths=[ "/Library/Frameworks/Python.framework/Versions/9.8/lib/python98.zip", "/Library/Frameworks/Python.framework/Versions/9.8/lib/python9.8", "/Library/Frameworks/Python.framework/Versions/9.8/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_venv_alt_framework_macos(self): """Test a venv layout on macOS using a framework build ``--with-framework-name=DebugPython`` """ venv_path = "/tmp/workdir/venv" ns = MockPosixNamespace( os_name="darwin", argv0="/Library/Frameworks/DebugPython.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/DebugPython", WITH_NEXT_FRAMEWORK=1, PREFIX="/Library/Frameworks/DebugPython.framework/Versions/9.8", EXEC_PREFIX="/Library/Frameworks/DebugPython.framework/Versions/9.8", ENV___PYVENV_LAUNCHER__=f"{venv_path}/bin/python", real_executable="/Library/Frameworks/DebugPython.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/DebugPython", library="/Library/Frameworks/DebugPython.framework/Versions/9.8/DebugPython", ) ns.add_known_dir(venv_path) ns.add_known_dir(f"{venv_path}/bin") ns.add_known_dir(f"{venv_path}/lib") ns.add_known_dir(f"{venv_path}/lib/python9.8") ns.add_known_xfile(f"{venv_path}/bin/python") ns.add_known_xfile("/Library/Frameworks/DebugPython.framework/Versions/9.8/Resources/Python.app/Contents/MacOS/DebugPython") ns.add_known_xfile("/Library/Frameworks/DebugPython.framework/Versions/9.8/bin/python9.8") ns.add_known_dir("/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python9.8/lib-dynload") ns.add_known_xfile("/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python9.8/os.py") ns.add_known_file(f"{venv_path}/pyvenv.cfg", [ "home = /Library/Frameworks/DebugPython.framework/Versions/9.8/bin" ]) expected = dict( executable=f"{venv_path}/bin/python", prefix="/Library/Frameworks/DebugPython.framework/Versions/9.8", exec_prefix="/Library/Frameworks/DebugPython.framework/Versions/9.8", base_executable="/Library/Frameworks/DebugPython.framework/Versions/9.8/bin/python9.8", base_prefix="/Library/Frameworks/DebugPython.framework/Versions/9.8", base_exec_prefix="/Library/Frameworks/DebugPython.framework/Versions/9.8", module_search_paths_set=1, module_search_paths=[ "/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python98.zip", "/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python9.8", "/Library/Frameworks/DebugPython.framework/Versions/9.8/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_venv_macos(self): """Test a venv layout on macOS. This layout is discovered when 'executable' and 'real_executable' match, but $__PYVENV_LAUNCHER__ has been set to the original process. """ ns = MockPosixNamespace( os_name="darwin", argv0="/usr/bin/python", PREFIX="/usr", ENV___PYVENV_LAUNCHER__="/framework/Python9.8/python", real_executable="/usr/bin/python", ) ns.add_known_xfile("/usr/bin/python") ns.add_known_xfile("/framework/Python9.8/python") ns.add_known_file("/usr/lib/python9.8/os.py") ns.add_known_dir("/usr/lib/python9.8/lib-dynload") ns.add_known_file("/framework/Python9.8/pyvenv.cfg", [ "home = /usr/bin" ]) expected = dict( executable="/framework/Python9.8/python", prefix="/usr", exec_prefix="/usr", base_executable="/usr/bin/python", base_prefix="/usr", base_exec_prefix="/usr", module_search_paths_set=1, module_search_paths=[ "/usr/lib/python98.zip", "/usr/lib/python9.8", "/usr/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_symlink_normal_macos(self): "Test a 'standard' install layout via symlink on macOS" ns = MockPosixNamespace( os_name="darwin", PREFIX="/usr", argv0="python", ENV_PATH="/linkfrom:/usr/bin", # real_executable on macOS matches the invocation path real_executable="/linkfrom/python", ) ns.add_known_xfile("/linkfrom/python") ns.add_known_xfile("/usr/bin/python") ns.add_known_link("/linkfrom/python", "/usr/bin/python") ns.add_known_file("/usr/lib/python9.8/os.py") ns.add_known_dir("/usr/lib/python9.8/lib-dynload") expected = dict( executable="/linkfrom/python", base_executable="/linkfrom/python", prefix="/usr", exec_prefix="/usr", module_search_paths_set=1, module_search_paths=[ "/usr/lib/python98.zip", "/usr/lib/python9.8", "/usr/lib/python9.8/lib-dynload", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_symlink_buildpath_macos(self): """Test an in-build-tree layout via symlink on macOS. This layout is discovered from the presence of pybuilddir.txt, which contains the relative path from the executable's directory to the platstdlib path. """ ns = MockPosixNamespace( os_name="darwin", argv0=r"python", ENV_PATH="/linkfrom:/usr/bin", PREFIX="/usr/local", # real_executable on macOS matches the invocation path real_executable="/linkfrom/python", ) ns.add_known_xfile("/linkfrom/python") ns.add_known_xfile("/home/cpython/python") ns.add_known_link("/linkfrom/python", "/home/cpython/python") ns.add_known_xfile("/usr/local/bin/python") ns.add_known_file("/home/cpython/pybuilddir.txt", ["build/lib.macos-9.8"]) ns.add_known_file("/home/cpython/Lib/os.py") ns.add_known_dir("/home/cpython/lib-dynload") expected = dict( executable="/linkfrom/python", prefix="/usr/local", exec_prefix="/usr/local", base_executable="/linkfrom/python", build_prefix="/home/cpython", _is_python_build=1, module_search_paths_set=1, module_search_paths=[ "/usr/local/lib/python98.zip", "/home/cpython/Lib", "/home/cpython/build/lib.macos-9.8", ], ) actual = getpath(ns, expected) self.assertEqual(expected, actual) def test_explicitly_set_stdlib_dir(self): """Test the explicitly set stdlib_dir in the config is respected.""" ns = MockPosixNamespace( PREFIX="/usr", argv0="python", ENV_PATH="/usr/bin", ) ns["config"]["stdlib_dir"] = "/custom_stdlib_dir" expected = dict( stdlib_dir="/custom_stdlib_dir", ) actual = getpath(ns, expected) self.assertEqual(expected, actual) # ****************************************************************************** DEFAULT_NAMESPACE = dict( PREFIX="", EXEC_PREFIX="", PYTHONPATH="", VPATH="", PLATLIBDIR="", PYDEBUGEXT="", VERSION_MAJOR=9, # fixed version number for ease VERSION_MINOR=8, # of testing ABI_THREAD="", PYWINVER=None, EXE_SUFFIX=None, ENV_PATH="", ENV_PYTHONHOME="", ENV_PYTHONEXECUTABLE="", ENV___PYVENV_LAUNCHER__="", argv0="", py_setpath="", real_executable="", executable_dir="", library="", winreg=None, build_prefix=None, venv_prefix=None, ) DEFAULT_CONFIG = dict( home=None, platlibdir=None, pythonpath=None, program_name=None, prefix=None, exec_prefix=None, base_prefix=None, base_exec_prefix=None, executable=None, base_executable="", stdlib_dir=None, platstdlib_dir=None, module_search_paths=None, module_search_paths_set=0, pythonpath_env=None, argv=None, orig_argv=None, isolated=0, use_environment=1, use_site=1, ) class MockNTNamespace(dict): def __init__(self, *a, argv0=None, config=None, **kw): self.update(DEFAULT_NAMESPACE) self["config"] = DEFAULT_CONFIG.copy() self["os_name"] = "nt" self["PLATLIBDIR"] = "DLLs" self["PYWINVER"] = "9.8-XY" self["VPATH"] = r"..\.." super().__init__(*a, **kw) if argv0: self["config"]["orig_argv"] = [argv0] if config: self["config"].update(config) self._files = {} self._links = {} self._dirs = set() self._warnings = [] def add_known_file(self, path, lines=None): self._files[path.casefold()] = list(lines or ()) self.add_known_dir(path.rpartition("\\")[0]) def add_known_xfile(self, path): self.add_known_file(path) def add_known_link(self, path, target): self._links[path.casefold()] = target def add_known_dir(self, path): p = path.rstrip("\\").casefold() while p: self._dirs.add(p) p = p.rpartition("\\")[0] def __missing__(self, key): try: return getattr(self, key) except AttributeError: raise KeyError(key) from None def abspath(self, path): if self.isabs(path): return path return self.joinpath("C:\\Absolute", path) def basename(self, path): return path.rpartition("\\")[2] def dirname(self, path): name = path.rstrip("\\").rpartition("\\")[0] if name[1:] == ":": return name + "\\" return name def hassuffix(self, path, suffix): return path.casefold().endswith(suffix.casefold()) def isabs(self, path): return path[1:3] == ":\\" def isdir(self, path): if verbose: print("Check if", path, "is a dir") return path.casefold() in self._dirs def isfile(self, path): if verbose: print("Check if", path, "is a file") return path.casefold() in self._files def ismodule(self, path): if verbose: print("Check if", path, "is a module") path = path.casefold() return path in self._files and path.rpartition(".")[2] == "py".casefold() def isxfile(self, path): if verbose: print("Check if", path, "is a executable") path = path.casefold() return path in self._files and path.rpartition(".")[2] == "exe".casefold() def joinpath(self, *path): return ntpath.normpath(ntpath.join(*path)) def readlines(self, path): try: return self._files[path.casefold()] except KeyError: raise FileNotFoundError(path) from None def realpath(self, path, _trail=None): if verbose: print("Read link from", path) try: link = self._links[path.casefold()] except KeyError: return path if _trail is None: _trail = set() elif link.casefold() in _trail: raise OSError("circular link") _trail.add(link.casefold()) return self.realpath(link, _trail) def warn(self, message): self._warnings.append(message) if verbose: print(message) class MockWinreg: HKEY_LOCAL_MACHINE = "HKLM" HKEY_CURRENT_USER = "HKCU" def __init__(self, keys): self.keys = {k.casefold(): v for k, v in keys.items()} self.open = {} def __repr__(self): return "<MockWinreg>" def __eq__(self, other): return isinstance(other, type(self)) def open_keys(self): return list(self.open) def OpenKeyEx(self, hkey, subkey): if verbose: print(f"OpenKeyEx({hkey}, {subkey})") key = f"{hkey}\\{subkey}".casefold() if key in self.keys: self.open[key] = self.open.get(key, 0) + 1 return key raise FileNotFoundError() def CloseKey(self, hkey): if verbose: print(f"CloseKey({hkey})") hkey = hkey.casefold() if hkey not in self.open: raise RuntimeError("key is not open") self.open[hkey] -= 1 if not self.open[hkey]: del self.open[hkey] def EnumKey(self, hkey, i): if verbose: print(f"EnumKey({hkey}, {i})") hkey = hkey.casefold() if hkey not in self.open: raise RuntimeError("key is not open") prefix = f'{hkey}\\' subkeys = [k[len(prefix):] for k in sorted(self.keys) if k.startswith(prefix)] subkeys[:] = [k for k in subkeys if '\\' not in k] for j, n in enumerate(subkeys): if j == i: return n.removeprefix(prefix) raise OSError("end of enumeration") def QueryValue(self, hkey, subkey): if verbose: print(f"QueryValue({hkey}, {subkey})") hkey = hkey.casefold() if hkey not in self.open: raise RuntimeError("key is not open") if subkey: subkey = subkey.casefold() hkey = f'{hkey}\\{subkey}' try: return self.keys[hkey] except KeyError: raise OSError() class MockPosixNamespace(dict): def __init__(self, *a, argv0=None, config=None, **kw): self.update(DEFAULT_NAMESPACE) self["config"] = DEFAULT_CONFIG.copy() self["os_name"] = "posix" self["PLATLIBDIR"] = "lib" self["WITH_NEXT_FRAMEWORK"] = 0 super().__init__(*a, **kw) if argv0: self["config"]["orig_argv"] = [argv0] if config: self["config"].update(config) self._files = {} self._xfiles = set() self._links = {} self._dirs = set() self._warnings = [] def add_known_file(self, path, lines=None): self._files[path] = list(lines or ()) self.add_known_dir(path.rpartition("/")[0]) def add_known_xfile(self, path): self.add_known_file(path) self._xfiles.add(path) def add_known_link(self, path, target): self._links[path] = target def add_known_dir(self, path): p = path.rstrip("/") while p: self._dirs.add(p) p = p.rpartition("/")[0] def __missing__(self, key): try: return getattr(self, key) except AttributeError: raise KeyError(key) from None def abspath(self, path): if self.isabs(path): return path return self.joinpath("/Absolute", path) def basename(self, path): return path.rpartition("/")[2] def dirname(self, path): return path.rstrip("/").rpartition("/")[0] def hassuffix(self, path, suffix): return path.endswith(suffix) def isabs(self, path): return path[0:1] == "/" def isdir(self, path): if verbose: print("Check if", path, "is a dir") return path in self._dirs def isfile(self, path): if verbose: print("Check if", path, "is a file") return path in self._files def ismodule(self, path): if verbose: print("Check if", path, "is a module") return path in self._files and path.rpartition(".")[2] == "py" def isxfile(self, path): if verbose: print("Check if", path, "is an xfile") return path in self._xfiles def joinpath(self, *path): return posixpath.normpath(posixpath.join(*path)) def readlines(self, path): try: return self._files[path] except KeyError: raise FileNotFoundError(path) from None def realpath(self, path, _trail=None): if verbose: print("Read link from", path) try: link = self._links[path] except KeyError: return path if _trail is None: _trail = set() elif link in _trail: raise OSError("circular link") _trail.add(link) return self.realpath(link, _trail) def warn(self, message): self._warnings.append(message) if verbose: print(message) def diff_dict(before, after, prefix="global"): diff = [] for k in sorted(before): if k[:2] == "__": continue if k == "config": diff_dict(before[k], after[k], prefix="config") continue if k in after and after[k] != before[k]: diff.append((k, before[k], after[k])) if not diff: return max_k = max(len(k) for k, _, _ in diff) indent = " " * (len(prefix) + 1 + max_k) if verbose: for k, b, a in diff: if b: print("{}.{} -{!r}\n{} +{!r}".format(prefix, k.ljust(max_k), b, indent, a)) else: print("{}.{} +{!r}".format(prefix, k.ljust(max_k), a)) def dump_dict(before, after, prefix="global"): if not verbose or not after: return max_k = max(len(k) for k in after) for k, v in sorted(after.items(), key=lambda i: i[0]): if k[:2] == "__": continue if k == "config": dump_dict(before[k], after[k], prefix="config") continue try: if v != before[k]: print("{}.{} {!r} (was {!r})".format(prefix, k.ljust(max_k), v, before[k])) continue except KeyError: pass print("{}.{} {!r}".format(prefix, k.ljust(max_k), v)) def getpath(ns, keys): before = copy.deepcopy(ns) failed = True try: exec(SOURCE, ns) failed = False finally: if failed: dump_dict(before, ns) else: diff_dict(before, ns) return { k: ns['config'].get(k, ns.get(k, ...)) for k in keys }