You've already forked setup-python
							
							
				mirror of
				https://github.com/actions/setup-python.git
				synced 2025-10-26 04:55:13 +07:00 
			
		
		
		
	Handle download HTTP error (#511)
This commit is contained in:
		
							
								
								
									
										92
									
								
								dist/setup/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										92
									
								
								dist/setup/index.js
									
									
									
									
										vendored
									
									
								
							| @ -66511,27 +66511,45 @@ function installPyPy(pypyVersion, pythonVersion, architecture, releases) { | |||||||
|         const { foundAsset, resolvedPythonVersion, resolvedPyPyVersion } = releaseData; |         const { foundAsset, resolvedPythonVersion, resolvedPyPyVersion } = releaseData; | ||||||
|         let downloadUrl = `${foundAsset.download_url}`; |         let downloadUrl = `${foundAsset.download_url}`; | ||||||
|         core.info(`Downloading PyPy from "${downloadUrl}" ...`); |         core.info(`Downloading PyPy from "${downloadUrl}" ...`); | ||||||
|         const pypyPath = yield tc.downloadTool(downloadUrl); |         try { | ||||||
|         core.info('Extracting downloaded archive...'); |             const pypyPath = yield tc.downloadTool(downloadUrl); | ||||||
|         if (utils_1.IS_WINDOWS) { |             core.info('Extracting downloaded archive...'); | ||||||
|             downloadDir = yield tc.extractZip(pypyPath); |             if (utils_1.IS_WINDOWS) { | ||||||
|  |                 downloadDir = yield tc.extractZip(pypyPath); | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                 downloadDir = yield tc.extractTar(pypyPath, undefined, 'x'); | ||||||
|  |             } | ||||||
|  |             // root folder in archive can have unpredictable name so just take the first folder
 | ||||||
|  |             // downloadDir is unique folder under TEMP and can't contain any other folders
 | ||||||
|  |             const archiveName = fs_1.default.readdirSync(downloadDir)[0]; | ||||||
|  |             const toolDir = path.join(downloadDir, archiveName); | ||||||
|  |             let installDir = toolDir; | ||||||
|  |             if (!utils_1.isNightlyKeyword(resolvedPyPyVersion)) { | ||||||
|  |                 installDir = yield tc.cacheDir(toolDir, 'PyPy', resolvedPythonVersion, architecture); | ||||||
|  |             } | ||||||
|  |             utils_1.writeExactPyPyVersionFile(installDir, resolvedPyPyVersion); | ||||||
|  |             const binaryPath = getPyPyBinaryPath(installDir); | ||||||
|  |             yield createPyPySymlink(binaryPath, resolvedPythonVersion); | ||||||
|  |             yield installPip(binaryPath); | ||||||
|  |             return { installDir, resolvedPythonVersion, resolvedPyPyVersion }; | ||||||
|         } |         } | ||||||
|         else { |         catch (err) { | ||||||
|             downloadDir = yield tc.extractTar(pypyPath, undefined, 'x'); |             if (err instanceof Error) { | ||||||
|  |                 // Rate limit?
 | ||||||
|  |                 if (err instanceof tc.HTTPError && | ||||||
|  |                     (err.httpStatusCode === 403 || err.httpStatusCode === 429)) { | ||||||
|  |                     core.info(`Received HTTP status code ${err.httpStatusCode}.  This usually indicates the rate limit has been exceeded`); | ||||||
|  |                 } | ||||||
|  |                 else { | ||||||
|  |                     core.info(err.message); | ||||||
|  |                 } | ||||||
|  |                 if (err.stack !== undefined) { | ||||||
|  |                     core.debug(err.stack); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             throw err; | ||||||
|         } |         } | ||||||
|         // root folder in archive can have unpredictable name so just take the first folder
 |  | ||||||
|         // downloadDir is unique folder under TEMP and can't contain any other folders
 |  | ||||||
|         const archiveName = fs_1.default.readdirSync(downloadDir)[0]; |  | ||||||
|         const toolDir = path.join(downloadDir, archiveName); |  | ||||||
|         let installDir = toolDir; |  | ||||||
|         if (!utils_1.isNightlyKeyword(resolvedPyPyVersion)) { |  | ||||||
|             installDir = yield tc.cacheDir(toolDir, 'PyPy', resolvedPythonVersion, architecture); |  | ||||||
|         } |  | ||||||
|         utils_1.writeExactPyPyVersionFile(installDir, resolvedPyPyVersion); |  | ||||||
|         const binaryPath = getPyPyBinaryPath(installDir); |  | ||||||
|         yield createPyPySymlink(binaryPath, resolvedPythonVersion); |  | ||||||
|         yield installPip(binaryPath); |  | ||||||
|         return { installDir, resolvedPythonVersion, resolvedPyPyVersion }; |  | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.installPyPy = installPyPy; | exports.installPyPy = installPyPy; | ||||||
| @ -66730,17 +66748,35 @@ function installCpythonFromRelease(release) { | |||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const downloadUrl = release.files[0].download_url; |         const downloadUrl = release.files[0].download_url; | ||||||
|         core.info(`Download from "${downloadUrl}"`); |         core.info(`Download from "${downloadUrl}"`); | ||||||
|         const pythonPath = yield tc.downloadTool(downloadUrl, undefined, AUTH); |         let pythonPath = ''; | ||||||
|         core.info('Extract downloaded archive'); |         try { | ||||||
|         let pythonExtractedFolder; |             pythonPath = yield tc.downloadTool(downloadUrl, undefined, AUTH); | ||||||
|         if (utils_1.IS_WINDOWS) { |             core.info('Extract downloaded archive'); | ||||||
|             pythonExtractedFolder = yield tc.extractZip(pythonPath); |             let pythonExtractedFolder; | ||||||
|  |             if (utils_1.IS_WINDOWS) { | ||||||
|  |                 pythonExtractedFolder = yield tc.extractZip(pythonPath); | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                 pythonExtractedFolder = yield tc.extractTar(pythonPath); | ||||||
|  |             } | ||||||
|  |             core.info('Execute installation script'); | ||||||
|  |             yield installPython(pythonExtractedFolder); | ||||||
|         } |         } | ||||||
|         else { |         catch (err) { | ||||||
|             pythonExtractedFolder = yield tc.extractTar(pythonPath); |             if (err instanceof tc.HTTPError) { | ||||||
|  |                 // Rate limit?
 | ||||||
|  |                 if (err.httpStatusCode === 403 || err.httpStatusCode === 429) { | ||||||
|  |                     core.info(`Received HTTP status code ${err.httpStatusCode}.  This usually indicates the rate limit has been exceeded`); | ||||||
|  |                 } | ||||||
|  |                 else { | ||||||
|  |                     core.info(err.message); | ||||||
|  |                 } | ||||||
|  |                 if (err.stack) { | ||||||
|  |                     core.debug(err.stack); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             throw err; | ||||||
|         } |         } | ||||||
|         core.info('Execute installation script'); |  | ||||||
|         yield installPython(pythonExtractedFolder); |  | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.installCpythonFromRelease = installCpythonFromRelease; | exports.installCpythonFromRelease = installCpythonFromRelease; | ||||||
|  | |||||||
| @ -46,37 +46,58 @@ export async function installPyPy( | |||||||
|   let downloadUrl = `${foundAsset.download_url}`; |   let downloadUrl = `${foundAsset.download_url}`; | ||||||
|  |  | ||||||
|   core.info(`Downloading PyPy from "${downloadUrl}" ...`); |   core.info(`Downloading PyPy from "${downloadUrl}" ...`); | ||||||
|   const pypyPath = await tc.downloadTool(downloadUrl); |  | ||||||
|  |  | ||||||
|   core.info('Extracting downloaded archive...'); |   try { | ||||||
|   if (IS_WINDOWS) { |     const pypyPath = await tc.downloadTool(downloadUrl); | ||||||
|     downloadDir = await tc.extractZip(pypyPath); |  | ||||||
|   } else { |     core.info('Extracting downloaded archive...'); | ||||||
|     downloadDir = await tc.extractTar(pypyPath, undefined, 'x'); |     if (IS_WINDOWS) { | ||||||
|  |       downloadDir = await tc.extractZip(pypyPath); | ||||||
|  |     } else { | ||||||
|  |       downloadDir = await tc.extractTar(pypyPath, undefined, 'x'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // root folder in archive can have unpredictable name so just take the first folder | ||||||
|  |     // downloadDir is unique folder under TEMP and can't contain any other folders | ||||||
|  |     const archiveName = fs.readdirSync(downloadDir)[0]; | ||||||
|  |  | ||||||
|  |     const toolDir = path.join(downloadDir, archiveName); | ||||||
|  |     let installDir = toolDir; | ||||||
|  |     if (!isNightlyKeyword(resolvedPyPyVersion)) { | ||||||
|  |       installDir = await tc.cacheDir( | ||||||
|  |         toolDir, | ||||||
|  |         'PyPy', | ||||||
|  |         resolvedPythonVersion, | ||||||
|  |         architecture | ||||||
|  |       ); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     writeExactPyPyVersionFile(installDir, resolvedPyPyVersion); | ||||||
|  |  | ||||||
|  |     const binaryPath = getPyPyBinaryPath(installDir); | ||||||
|  |     await createPyPySymlink(binaryPath, resolvedPythonVersion); | ||||||
|  |     await installPip(binaryPath); | ||||||
|  |  | ||||||
|  |     return {installDir, resolvedPythonVersion, resolvedPyPyVersion}; | ||||||
|  |   } catch (err) { | ||||||
|  |     if (err instanceof Error) { | ||||||
|  |       // Rate limit? | ||||||
|  |       if ( | ||||||
|  |         err instanceof tc.HTTPError && | ||||||
|  |         (err.httpStatusCode === 403 || err.httpStatusCode === 429) | ||||||
|  |       ) { | ||||||
|  |         core.info( | ||||||
|  |           `Received HTTP status code ${err.httpStatusCode}.  This usually indicates the rate limit has been exceeded` | ||||||
|  |         ); | ||||||
|  |       } else { | ||||||
|  |         core.info(err.message); | ||||||
|  |       } | ||||||
|  |       if (err.stack !== undefined) { | ||||||
|  |         core.debug(err.stack); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     throw err; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // root folder in archive can have unpredictable name so just take the first folder |  | ||||||
|   // downloadDir is unique folder under TEMP and can't contain any other folders |  | ||||||
|   const archiveName = fs.readdirSync(downloadDir)[0]; |  | ||||||
|  |  | ||||||
|   const toolDir = path.join(downloadDir, archiveName); |  | ||||||
|   let installDir = toolDir; |  | ||||||
|   if (!isNightlyKeyword(resolvedPyPyVersion)) { |  | ||||||
|     installDir = await tc.cacheDir( |  | ||||||
|       toolDir, |  | ||||||
|       'PyPy', |  | ||||||
|       resolvedPythonVersion, |  | ||||||
|       architecture |  | ||||||
|     ); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   writeExactPyPyVersionFile(installDir, resolvedPyPyVersion); |  | ||||||
|  |  | ||||||
|   const binaryPath = getPyPyBinaryPath(installDir); |  | ||||||
|   await createPyPySymlink(binaryPath, resolvedPythonVersion); |  | ||||||
|   await installPip(binaryPath); |  | ||||||
|  |  | ||||||
|   return {installDir, resolvedPythonVersion, resolvedPyPyVersion}; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| export async function getAvailablePyPyVersions() { | export async function getAvailablePyPyVersions() { | ||||||
|  | |||||||
| @ -72,15 +72,33 @@ export async function installCpythonFromRelease(release: tc.IToolRelease) { | |||||||
|   const downloadUrl = release.files[0].download_url; |   const downloadUrl = release.files[0].download_url; | ||||||
|  |  | ||||||
|   core.info(`Download from "${downloadUrl}"`); |   core.info(`Download from "${downloadUrl}"`); | ||||||
|   const pythonPath = await tc.downloadTool(downloadUrl, undefined, AUTH); |   let pythonPath = ''; | ||||||
|   core.info('Extract downloaded archive'); |   try { | ||||||
|   let pythonExtractedFolder; |     pythonPath = await tc.downloadTool(downloadUrl, undefined, AUTH); | ||||||
|   if (IS_WINDOWS) { |     core.info('Extract downloaded archive'); | ||||||
|     pythonExtractedFolder = await tc.extractZip(pythonPath); |     let pythonExtractedFolder; | ||||||
|   } else { |     if (IS_WINDOWS) { | ||||||
|     pythonExtractedFolder = await tc.extractTar(pythonPath); |       pythonExtractedFolder = await tc.extractZip(pythonPath); | ||||||
|   } |     } else { | ||||||
|  |       pythonExtractedFolder = await tc.extractTar(pythonPath); | ||||||
|  |     } | ||||||
|  |  | ||||||
|   core.info('Execute installation script'); |     core.info('Execute installation script'); | ||||||
|   await installPython(pythonExtractedFolder); |     await installPython(pythonExtractedFolder); | ||||||
|  |   } catch (err) { | ||||||
|  |     if (err instanceof tc.HTTPError) { | ||||||
|  |       // Rate limit? | ||||||
|  |       if (err.httpStatusCode === 403 || err.httpStatusCode === 429) { | ||||||
|  |         core.info( | ||||||
|  |           `Received HTTP status code ${err.httpStatusCode}.  This usually indicates the rate limit has been exceeded` | ||||||
|  |         ); | ||||||
|  |       } else { | ||||||
|  |         core.info(err.message); | ||||||
|  |       } | ||||||
|  |       if (err.stack) { | ||||||
|  |         core.debug(err.stack); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     throw err; | ||||||
|  |   } | ||||||
| } | } | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 Sergey Dolin
					Sergey Dolin