##// END OF EJS Templates
automation: drop support for Python 2.7 in Windows environment...
Gregory Szorc -
r49701:d7e064d5 default
parent child Browse files
Show More
@@ -158,7 +158,7 def build_all_windows_packages(
158
158
159 windows.synchronize_hg(SOURCE_ROOT, revision, instance)
159 windows.synchronize_hg(SOURCE_ROOT, revision, instance)
160
160
161 for py_version in ("2.7", "3.7", "3.8", "3.9", "3.10"):
161 for py_version in ("3.7", "3.8", "3.9", "3.10"):
162 for arch in ("x86", "x64"):
162 for arch in ("x86", "x64"):
163 windows.purge_hg(winrm_client)
163 windows.purge_hg(winrm_client)
164 windows.build_wheel(
164 windows.build_wheel(
@@ -342,7 +342,7 def get_parser():
342 sp.add_argument(
342 sp.add_argument(
343 '--python-version',
343 '--python-version',
344 help='Which version of Python to target',
344 help='Which version of Python to target',
345 choices={2, 3},
345 choices={3},
346 type=int,
346 type=int,
347 nargs='*',
347 nargs='*',
348 default=[3],
348 default=[3],
@@ -377,7 +377,7 def get_parser():
377 sp.add_argument(
377 sp.add_argument(
378 '--python-version',
378 '--python-version',
379 help='Python version to build for',
379 help='Python version to build for',
380 choices={'2.7', '3.7', '3.8', '3.9', '3.10'},
380 choices={'3.7', '3.8', '3.9', '3.10'},
381 nargs='*',
381 nargs='*',
382 default=['3.8'],
382 default=['3.8'],
383 )
383 )
@@ -404,7 +404,7 def get_parser():
404 sp.add_argument(
404 sp.add_argument(
405 '--python-version',
405 '--python-version',
406 help='Which version of Python to target',
406 help='Which version of Python to target',
407 choices={2, 3},
407 choices={3},
408 type=int,
408 type=int,
409 nargs='*',
409 nargs='*',
410 default=[3],
410 default=[3],
@@ -499,8 +499,8 def get_parser():
499 sp.add_argument(
499 sp.add_argument(
500 '--python-version',
500 '--python-version',
501 help='Python version to use',
501 help='Python version to use',
502 choices={'2.7', '3.5', '3.6', '3.7', '3.8', '3.9', '3.10'},
502 choices={'3.5', '3.6', '3.7', '3.8', '3.9', '3.10'},
503 default='2.7',
503 default='3.9',
504 )
504 )
505 sp.add_argument(
505 sp.add_argument(
506 '--arch',
506 '--arch',
@@ -19,30 +19,6 from .pypi import upload as pypi_upload
19 from .winrm import run_powershell
19 from .winrm import run_powershell
20
20
21
21
22 # PowerShell commands to activate a Visual Studio 2008 environment.
23 # This is essentially a port of vcvarsall.bat to PowerShell.
24 ACTIVATE_VC9_AMD64 = r'''
25 Write-Output "activating Visual Studio 2008 environment for AMD64"
26 $root = "$env:LOCALAPPDATA\Programs\Common\Microsoft\Visual C++ for Python\9.0"
27 $Env:VCINSTALLDIR = "${root}\VC\"
28 $Env:WindowsSdkDir = "${root}\WinSDK\"
29 $Env:PATH = "${root}\VC\Bin\amd64;${root}\WinSDK\Bin\x64;${root}\WinSDK\Bin;$Env:PATH"
30 $Env:INCLUDE = "${root}\VC\Include;${root}\WinSDK\Include;$Env:PATH"
31 $Env:LIB = "${root}\VC\Lib\amd64;${root}\WinSDK\Lib\x64;$Env:LIB"
32 $Env:LIBPATH = "${root}\VC\Lib\amd64;${root}\WinSDK\Lib\x64;$Env:LIBPATH"
33 '''.lstrip()
34
35 ACTIVATE_VC9_X86 = r'''
36 Write-Output "activating Visual Studio 2008 environment for x86"
37 $root = "$env:LOCALAPPDATA\Programs\Common\Microsoft\Visual C++ for Python\9.0"
38 $Env:VCINSTALLDIR = "${root}\VC\"
39 $Env:WindowsSdkDir = "${root}\WinSDK\"
40 $Env:PATH = "${root}\VC\Bin;${root}\WinSDK\Bin;$Env:PATH"
41 $Env:INCLUDE = "${root}\VC\Include;${root}\WinSDK\Include;$Env:INCLUDE"
42 $Env:LIB = "${root}\VC\Lib;${root}\WinSDK\Lib;$Env:LIB"
43 $Env:LIBPATH = "${root}\VC\lib;${root}\WinSDK\Lib;$Env:LIBPATH"
44 '''.lstrip()
45
46 HG_PURGE = r'''
22 HG_PURGE = r'''
47 $Env:PATH = "C:\hgdev\venv-bootstrap\Scripts;$Env:PATH"
23 $Env:PATH = "C:\hgdev\venv-bootstrap\Scripts;$Env:PATH"
48 Set-Location C:\hgdev\src
24 Set-Location C:\hgdev\src
@@ -78,14 +54,6 if ($LASTEXITCODE -ne 0) {{
78 }}
54 }}
79 '''
55 '''
80
56
81 BUILD_INNO_PYTHON2 = r'''
82 Set-Location C:\hgdev\src
83 $python = "C:\hgdev\python27-{arch}\python.exe"
84 C:\hgdev\python37-x64\python.exe contrib\packaging\packaging.py inno --python $python {extra_args}
85 if ($LASTEXITCODE -ne 0) {{
86 throw "process exited non-0: $LASTEXITCODE"
87 }}
88 '''.lstrip()
89
57
90 BUILD_WHEEL = r'''
58 BUILD_WHEEL = r'''
91 Set-Location C:\hgdev\src
59 Set-Location C:\hgdev\src
@@ -105,14 +73,6 if ($LASTEXITCODE -ne 0) {{
105 }}
73 }}
106 '''
74 '''
107
75
108 BUILD_WIX_PYTHON2 = r'''
109 Set-Location C:\hgdev\src
110 $python = "C:\hgdev\python27-{arch}\python.exe"
111 C:\hgdev\python37-x64\python.exe contrib\packaging\packaging.py wix --python $python {extra_args}
112 if ($LASTEXITCODE -ne 0) {{
113 throw "process exited non-0: $LASTEXITCODE"
114 }}
115 '''
116
76
117 RUN_TESTS = r'''
77 RUN_TESTS = r'''
118 C:\hgdev\MinGW\msys\1.0\bin\sh.exe --login -c "cd /c/hgdev/src/tests && /c/hgdev/{python_path}/python.exe run-tests.py {test_flags}"
78 C:\hgdev\MinGW\msys\1.0\bin\sh.exe --login -c "cd /c/hgdev/src/tests && /c/hgdev/{python_path}/python.exe run-tests.py {test_flags}"
@@ -121,8 +81,7 if ($LASTEXITCODE -ne 0) {{
121 }}
81 }}
122 '''
82 '''
123
83
124 WHEEL_FILENAME_PYTHON27_X86 = 'mercurial-{version}-cp27-cp27m-win32.whl'
84
125 WHEEL_FILENAME_PYTHON27_X64 = 'mercurial-{version}-cp27-cp27m-win_amd64.whl'
126 WHEEL_FILENAME_PYTHON37_X86 = 'mercurial-{version}-cp37-cp37m-win32.whl'
85 WHEEL_FILENAME_PYTHON37_X86 = 'mercurial-{version}-cp37-cp37m-win32.whl'
127 WHEEL_FILENAME_PYTHON37_X64 = 'mercurial-{version}-cp37-cp37m-win_amd64.whl'
86 WHEEL_FILENAME_PYTHON37_X64 = 'mercurial-{version}-cp37-cp37m-win_amd64.whl'
128 WHEEL_FILENAME_PYTHON38_X86 = 'mercurial-{version}-cp38-cp38-win32.whl'
87 WHEEL_FILENAME_PYTHON38_X86 = 'mercurial-{version}-cp38-cp38-win32.whl'
@@ -132,13 +91,9 WHEEL_FILENAME_PYTHON39_X64 = 'mercurial
132 WHEEL_FILENAME_PYTHON310_X86 = 'mercurial-{version}-cp310-cp310-win32.whl'
91 WHEEL_FILENAME_PYTHON310_X86 = 'mercurial-{version}-cp310-cp310-win32.whl'
133 WHEEL_FILENAME_PYTHON310_X64 = 'mercurial-{version}-cp310-cp310-win_amd64.whl'
92 WHEEL_FILENAME_PYTHON310_X64 = 'mercurial-{version}-cp310-cp310-win_amd64.whl'
134
93
135 EXE_FILENAME_PYTHON2_X86 = 'Mercurial-{version}-x86-python2.exe'
136 EXE_FILENAME_PYTHON2_X64 = 'Mercurial-{version}-x64-python2.exe'
137 EXE_FILENAME_PYTHON3_X86 = 'Mercurial-{version}-x86.exe'
94 EXE_FILENAME_PYTHON3_X86 = 'Mercurial-{version}-x86.exe'
138 EXE_FILENAME_PYTHON3_X64 = 'Mercurial-{version}-x64.exe'
95 EXE_FILENAME_PYTHON3_X64 = 'Mercurial-{version}-x64.exe'
139
96
140 MSI_FILENAME_PYTHON2_X86 = 'mercurial-{version}-x86-python2.msi'
141 MSI_FILENAME_PYTHON2_X64 = 'mercurial-{version}-x64-python2.msi'
142 MSI_FILENAME_PYTHON3_X86 = 'mercurial-{version}-x86.msi'
97 MSI_FILENAME_PYTHON3_X86 = 'mercurial-{version}-x86.msi'
143 MSI_FILENAME_PYTHON3_X64 = 'mercurial-{version}-x64.msi'
98 MSI_FILENAME_PYTHON3_X64 = 'mercurial-{version}-x64.msi'
144
99
@@ -147,14 +102,6 MERCURIAL_SCM_BASE_URL = 'https://mercur
147 X86_USER_AGENT_PATTERN = '.*Windows.*'
102 X86_USER_AGENT_PATTERN = '.*Windows.*'
148 X64_USER_AGENT_PATTERN = '.*Windows.*(WOW|x)64.*'
103 X64_USER_AGENT_PATTERN = '.*Windows.*(WOW|x)64.*'
149
104
150 EXE_PYTHON2_X86_DESCRIPTION = (
151 'Mercurial {version} Inno Setup installer - x86 Windows (Python 2) '
152 '- does not require admin rights'
153 )
154 EXE_PYTHON2_X64_DESCRIPTION = (
155 'Mercurial {version} Inno Setup installer - x64 Windows (Python 2) '
156 '- does not require admin rights'
157 )
158 # TODO remove Python version once Python 2 is dropped.
105 # TODO remove Python version once Python 2 is dropped.
159 EXE_PYTHON3_X86_DESCRIPTION = (
106 EXE_PYTHON3_X86_DESCRIPTION = (
160 'Mercurial {version} Inno Setup installer - x86 Windows (Python 3) '
107 'Mercurial {version} Inno Setup installer - x86 Windows (Python 3) '
@@ -164,14 +111,6 EXE_PYTHON3_X64_DESCRIPTION = (
164 'Mercurial {version} Inno Setup installer - x64 Windows (Python 3) '
111 'Mercurial {version} Inno Setup installer - x64 Windows (Python 3) '
165 '- does not require admin rights'
112 '- does not require admin rights'
166 )
113 )
167 MSI_PYTHON2_X86_DESCRIPTION = (
168 'Mercurial {version} MSI installer - x86 Windows (Python 2) '
169 '- requires admin rights'
170 )
171 MSI_PYTHON2_X64_DESCRIPTION = (
172 'Mercurial {version} MSI installer - x64 Windows (Python 2) '
173 '- requires admin rights'
174 )
175 MSI_PYTHON3_X86_DESCRIPTION = (
114 MSI_PYTHON3_X86_DESCRIPTION = (
176 'Mercurial {version} MSI installer - x86 Windows (Python 3) '
115 'Mercurial {version} MSI installer - x86 Windows (Python 3) '
177 '- requires admin rights'
116 '- requires admin rights'
@@ -182,15 +121,6 MSI_PYTHON3_X64_DESCRIPTION = (
182 )
121 )
183
122
184
123
185 def get_vc_prefix(arch):
186 if arch == 'x86':
187 return ACTIVATE_VC9_X86
188 elif arch == 'x64':
189 return ACTIVATE_VC9_AMD64
190 else:
191 raise ValueError('illegal arch: %s; must be x86 or x64' % arch)
192
193
194 def fix_authorized_keys_permissions(winrm_client, path):
124 def fix_authorized_keys_permissions(winrm_client, path):
195 commands = [
125 commands = [
196 '$ErrorActionPreference = "Stop"',
126 '$ErrorActionPreference = "Stop"',
@@ -349,12 +279,9 def build_inno_installer(
349 % (python_version, arch)
279 % (python_version, arch)
350 )
280 )
351
281
352 if python_version == 3:
353 # TODO fix this limitation in packaging code
282 # TODO fix this limitation in packaging code
354 if not version:
283 if not version:
355 raise Exception(
284 raise Exception("version string is required when building for Python 3")
356 "version string is required when building for Python 3"
357 )
358
285
359 if arch == "x86":
286 if arch == "x86":
360 target_triple = "i686-pc-windows-msvc"
287 target_triple = "i686-pc-windows-msvc"
@@ -367,14 +294,6 def build_inno_installer(
367 pyoxidizer_target=target_triple,
294 pyoxidizer_target=target_triple,
368 version=version,
295 version=version,
369 )
296 )
370 else:
371 extra_args = []
372 if version:
373 extra_args.extend(['--version', version])
374
375 ps = get_vc_prefix(arch) + BUILD_INNO_PYTHON2.format(
376 arch=arch, extra_args=' '.join(extra_args)
377 )
378
297
379 run_powershell(winrm_client, ps)
298 run_powershell(winrm_client, ps)
380 copy_latest_dist(winrm_client, '*.exe', dest_path)
299 copy_latest_dist(winrm_client, '*.exe', dest_path)
@@ -394,10 +313,6 def build_wheel(
394 python_version=python_version.replace(".", ""), arch=arch
313 python_version=python_version.replace(".", ""), arch=arch
395 )
314 )
396
315
397 # Python 2.7 requires an activated environment.
398 if python_version == "2.7":
399 ps = get_vc_prefix(arch) + ps
400
401 run_powershell(winrm_client, ps)
316 run_powershell(winrm_client, ps)
402 copy_latest_dist(winrm_client, '*.whl', dest_path)
317 copy_latest_dist(winrm_client, '*.whl', dest_path)
403
318
@@ -415,12 +330,9 def build_wix_installer(
415 """
330 """
416 print('Building WiX installer for Python %d %s' % (python_version, arch))
331 print('Building WiX installer for Python %d %s' % (python_version, arch))
417
332
418 if python_version == 3:
419 # TODO fix this limitation in packaging code
333 # TODO fix this limitation in packaging code
420 if not version:
334 if not version:
421 raise Exception(
335 raise Exception("version string is required when building for Python 3")
422 "version string is required when building for Python 3"
423 )
424
336
425 if arch == "x86":
337 if arch == "x86":
426 target_triple = "i686-pc-windows-msvc"
338 target_triple = "i686-pc-windows-msvc"
@@ -433,14 +345,6 def build_wix_installer(
433 pyoxidizer_target=target_triple,
345 pyoxidizer_target=target_triple,
434 version=version,
346 version=version,
435 )
347 )
436 else:
437 extra_args = []
438 if version:
439 extra_args.extend(['--version', version])
440
441 ps = get_vc_prefix(arch) + BUILD_WIX_PYTHON2.format(
442 arch=arch, extra_args=' '.join(extra_args)
443 )
444
348
445 run_powershell(winrm_client, ps)
349 run_powershell(winrm_client, ps)
446 copy_latest_dist(winrm_client, '*.msi', dest_path)
350 copy_latest_dist(winrm_client, '*.msi', dest_path)
@@ -474,8 +378,6 def run_tests(winrm_client, python_versi
474
378
475 def resolve_wheel_artifacts(dist_path: pathlib.Path, version: str):
379 def resolve_wheel_artifacts(dist_path: pathlib.Path, version: str):
476 return (
380 return (
477 dist_path / WHEEL_FILENAME_PYTHON27_X86.format(version=version),
478 dist_path / WHEEL_FILENAME_PYTHON27_X64.format(version=version),
479 dist_path / WHEEL_FILENAME_PYTHON37_X86.format(version=version),
381 dist_path / WHEEL_FILENAME_PYTHON37_X86.format(version=version),
480 dist_path / WHEEL_FILENAME_PYTHON37_X64.format(version=version),
382 dist_path / WHEEL_FILENAME_PYTHON37_X64.format(version=version),
481 dist_path / WHEEL_FILENAME_PYTHON38_X86.format(version=version),
383 dist_path / WHEEL_FILENAME_PYTHON38_X86.format(version=version),
@@ -489,8 +391,6 def resolve_wheel_artifacts(dist_path: p
489
391
490 def resolve_all_artifacts(dist_path: pathlib.Path, version: str):
392 def resolve_all_artifacts(dist_path: pathlib.Path, version: str):
491 return (
393 return (
492 dist_path / WHEEL_FILENAME_PYTHON27_X86.format(version=version),
493 dist_path / WHEEL_FILENAME_PYTHON27_X64.format(version=version),
494 dist_path / WHEEL_FILENAME_PYTHON37_X86.format(version=version),
394 dist_path / WHEEL_FILENAME_PYTHON37_X86.format(version=version),
495 dist_path / WHEEL_FILENAME_PYTHON37_X64.format(version=version),
395 dist_path / WHEEL_FILENAME_PYTHON37_X64.format(version=version),
496 dist_path / WHEEL_FILENAME_PYTHON38_X86.format(version=version),
396 dist_path / WHEEL_FILENAME_PYTHON38_X86.format(version=version),
@@ -499,24 +399,16 def resolve_all_artifacts(dist_path: pat
499 dist_path / WHEEL_FILENAME_PYTHON39_X64.format(version=version),
399 dist_path / WHEEL_FILENAME_PYTHON39_X64.format(version=version),
500 dist_path / WHEEL_FILENAME_PYTHON310_X86.format(version=version),
400 dist_path / WHEEL_FILENAME_PYTHON310_X86.format(version=version),
501 dist_path / WHEEL_FILENAME_PYTHON310_X64.format(version=version),
401 dist_path / WHEEL_FILENAME_PYTHON310_X64.format(version=version),
502 dist_path / EXE_FILENAME_PYTHON2_X86.format(version=version),
503 dist_path / EXE_FILENAME_PYTHON2_X64.format(version=version),
504 dist_path / EXE_FILENAME_PYTHON3_X86.format(version=version),
402 dist_path / EXE_FILENAME_PYTHON3_X86.format(version=version),
505 dist_path / EXE_FILENAME_PYTHON3_X64.format(version=version),
403 dist_path / EXE_FILENAME_PYTHON3_X64.format(version=version),
506 dist_path / MSI_FILENAME_PYTHON2_X86.format(version=version),
507 dist_path / MSI_FILENAME_PYTHON2_X64.format(version=version),
508 dist_path / MSI_FILENAME_PYTHON3_X86.format(version=version),
404 dist_path / MSI_FILENAME_PYTHON3_X86.format(version=version),
509 dist_path / MSI_FILENAME_PYTHON3_X64.format(version=version),
405 dist_path / MSI_FILENAME_PYTHON3_X64.format(version=version),
510 )
406 )
511
407
512
408
513 def generate_latest_dat(version: str):
409 def generate_latest_dat(version: str):
514 python2_x86_exe_filename = EXE_FILENAME_PYTHON2_X86.format(version=version)
515 python2_x64_exe_filename = EXE_FILENAME_PYTHON2_X64.format(version=version)
516 python3_x86_exe_filename = EXE_FILENAME_PYTHON3_X86.format(version=version)
410 python3_x86_exe_filename = EXE_FILENAME_PYTHON3_X86.format(version=version)
517 python3_x64_exe_filename = EXE_FILENAME_PYTHON3_X64.format(version=version)
411 python3_x64_exe_filename = EXE_FILENAME_PYTHON3_X64.format(version=version)
518 python2_x86_msi_filename = MSI_FILENAME_PYTHON2_X86.format(version=version)
519 python2_x64_msi_filename = MSI_FILENAME_PYTHON2_X64.format(version=version)
520 python3_x86_msi_filename = MSI_FILENAME_PYTHON3_X86.format(version=version)
412 python3_x86_msi_filename = MSI_FILENAME_PYTHON3_X86.format(version=version)
521 python3_x64_msi_filename = MSI_FILENAME_PYTHON3_X64.format(version=version)
413 python3_x64_msi_filename = MSI_FILENAME_PYTHON3_X64.format(version=version)
522
414
@@ -536,20 +428,6 def generate_latest_dat(version: str):
536 EXE_PYTHON3_X64_DESCRIPTION.format(version=version),
428 EXE_PYTHON3_X64_DESCRIPTION.format(version=version),
537 ),
429 ),
538 (
430 (
539 '9',
540 version,
541 X86_USER_AGENT_PATTERN,
542 '%s/%s' % (MERCURIAL_SCM_BASE_URL, python2_x86_exe_filename),
543 EXE_PYTHON2_X86_DESCRIPTION.format(version=version),
544 ),
545 (
546 '9',
547 version,
548 X64_USER_AGENT_PATTERN,
549 '%s/%s' % (MERCURIAL_SCM_BASE_URL, python2_x64_exe_filename),
550 EXE_PYTHON2_X64_DESCRIPTION.format(version=version),
551 ),
552 (
553 '10',
431 '10',
554 version,
432 version,
555 X86_USER_AGENT_PATTERN,
433 X86_USER_AGENT_PATTERN,
@@ -563,20 +441,6 def generate_latest_dat(version: str):
563 '%s/%s' % (MERCURIAL_SCM_BASE_URL, python3_x64_msi_filename),
441 '%s/%s' % (MERCURIAL_SCM_BASE_URL, python3_x64_msi_filename),
564 MSI_PYTHON3_X64_DESCRIPTION.format(version=version),
442 MSI_PYTHON3_X64_DESCRIPTION.format(version=version),
565 ),
443 ),
566 (
567 '9',
568 version,
569 X86_USER_AGENT_PATTERN,
570 '%s/%s' % (MERCURIAL_SCM_BASE_URL, python2_x86_msi_filename),
571 MSI_PYTHON2_X86_DESCRIPTION.format(version=version),
572 ),
573 (
574 '9',
575 version,
576 X64_USER_AGENT_PATTERN,
577 '%s/%s' % (MERCURIAL_SCM_BASE_URL, python2_x64_msi_filename),
578 MSI_PYTHON2_X64_DESCRIPTION.format(version=version),
579 ),
580 )
444 )
581
445
582 lines = ['\t'.join(e) for e in entries]
446 lines = ['\t'.join(e) for e in entries]
General Comments 0
You need to be logged in to leave comments. Login now