1
0
mirror of https://github.com/php/web-php.git synced 2026-03-24 07:12:16 +01:00
Files
archived-web-php/include/release-qa.php
2026-01-02 18:43:54 +01:00

171 lines
7.7 KiB
PHP

<?php
/*
What this file does:
- Generates the download links found at qa.php.net
- Determines which test results are emailed to news.php.net/php.qa.reports
- Defines $QA_RELEASES for internal and external (api.php) use, contains all qa related information for future PHP releases
Documentation:
$QA_RELEASES documentation:
Configuration:
- Key is future PHP version number
- Example: If 5.3.6 is the latest stable release, then use 5.3.7 because 5.3.7-dev is our qa version
- Typically, this is the only part needing changed
- active (bool):
- It's active and being tested here
- Meaning, the version will be reported to the qa.reports list, and be linked at qa.php.net
- File extensions .tar.gz and .tar.bz2 are assumed to be available
- release (array):
- type: RC, alpha, and beta are examples (case should match filename case)
- version: 0 if no such release exists, otherwise an integer of the rc/alpha/beta number
- sha256_bz2: sha256 checksum of this downloadable .tar.bz2 file
- sha256_gz: sha256 checksum of this downloadable .tar.gz file
- sha256_xz: sha256 checksum of this downloadble .xz file
- date: date of release e.g., 21 May 2011
- baseurl: base url of where these downloads are located
- Multiple checksums can be available, see the $QA_CHECKSUM_TYPES array below
Other variables within $QA_RELEASES are later defined including:
- reported: versions that make it to the qa.reports mailing list
- release: all current qa releases, including paths to dl urls (w/ sha256 info)
- dev_version: dev version
- $QA_RELEASES is made available at qa.php.net/api.php
TODO:
- Save all reports (on qa server) for all tests, categorize by PHP version (see buildtest-process.php)
- Consider storing rc downloads at one location, independent of release master
- Determine best way to handle rc baseurl, currently assumes .tar.gz/tar.bz2 will exist
- Determine if $QA_RELEASES is compatible with all current, and most future configurations
- Determine if $QA_RELEASES can be simplified
- Determine if alpha/beta options are desired
- Unify then create defaults for most settings
- Add option to allow current releases (e.g., retrieve current release info via daily cron, cache, check, configure ~ALLOW_CURRENT_RELEASES)
*/
$QA_RELEASES = [
'8.2.27' => [
'active' => true,
'release' => [
'type' => 'RC',
'number' => 0,
'sha256_bz2' => '',
'sha256_gz' => '',
'sha256_xz' => '',
'date' => '05 Dec 2024',
'baseurl' => 'https://downloads.php.net/',
],
],
'8.3.30' => [
'active' => true,
'release' => [
'type' => 'RC',
'number' => 1,
'sha256_bz2' => '2e432f7aa06cc8bc966cd63ede1913cf7c9b9c356ba14f1beb3d5725c41acf9a',
'sha256_gz' => 'ef8c41dc1af1371e70dd1c9d8caaab5ee47ecf712206a5496e0510417b53fcd7',
'sha256_xz' => 'ad87853e60a5e92fad718b8c85387a22ba33a120acc288abbb73abcd48b8081a',
'date' => '01 Jan 2026',
'baseurl' => 'https://downloads.php.net/~jakub/',
],
],
'8.4.17' => [
'active' => true,
'release' => [
'type' => 'RC',
'number' => 1,
'sha256_bz2' => '02abfe473ff3aa12a06ac6fedfe896cb8c082c108d46e17a1d9174bb139d2d1b',
'sha256_gz' => 'a3062494dffd9be5be259eb20da6dc248954c5322b681b98b0a5cc93d125808d',
'sha256_xz' => '0d86b6a92d8af1b25671c3abe558d035f26aefb48218fada3757406e1cbf4dd8',
'date' => '01 Jan 2026',
'baseurl' => 'https://downloads.php.net/~calvinb/',
],
],
'8.5.2' => [
'active' => true,
'release' => [
'type' => 'RC',
'number' => 1,
'sha256_bz2' => '622b2d9471bd10d054a7d5938e66072512fad367b97e147165c0a864746b94ff',
'sha256_gz' => '12f39245d139c956af072b45c3adbf9bb8b35d23a03e401cd502a83ed00d4d39',
'sha256_xz' => '5ba316ea268c80bb50468baecf8e040971fad328239d526dcc0a986c1d72b13b',
'date' => '01 Jan 2026',
'baseurl' => 'https://downloads.php.net/~daniels/',
],
],
];
/*** End Configuration *******************************************************************/
// This is a list of the possible checksum values that can be supplied with a QA release. Any
// new algorithm is read from the $QA_RELEASES array under the 'release' index for each version
// in the form of "$algorithm_$filetype".
//
// For example, if SHA512 were to be supported, the following indices would have to be added:
//
// 'sha512_bz2' => 'xxx',
// 'sha512_gz' => 'xxx',
// 'sha512_xz' => 'xxx',
$QA_CHECKSUM_TYPES = ['sha256'];
// $QA_RELEASES eventually contains just about everything, also for external use
// release : These are encouraged for use (e.g., linked at qa.php.net)
// reported : These are allowed to report @ the php.qa.reports mailing list
(function(&$QA_RELEASES) use ($QA_CHECKSUM_TYPES) {
foreach ($QA_RELEASES as $pversion => $info) {
if (isset($info['active']) && $info['active']) {
// Allow -dev versions of all active types
// Example: 5.3.6-dev
$QA_RELEASES['reported'][] = "{$pversion}-dev";
$QA_RELEASES[$pversion]['dev_version'] = "{$pversion}-dev";
// Allow -dev version of upcoming qa releases (rc/alpha/beta)
// @todo confirm this php version format for all dev versions
if ((int)$info['release']['number'] > 0) {
$QA_RELEASES['reported'][] = "{$pversion}{$info['release']['type']}{$info['release']['number']}";
if (!empty($info['release']['baseurl'])) {
// php.net filename format for qa releases
// example: php-5.3.0RC2
$fn_base = 'php-' . $pversion . $info['release']['type'] . $info['release']['number'];
$QA_RELEASES[$pversion]['release']['version'] = $pversion . $info['release']['type'] . $info['release']['number'];
foreach ([ 'bz2', 'gz', 'xz' ] as $file_type) {
foreach ($QA_CHECKSUM_TYPES as $algo) {
if (isset($info['release'][$algo . '_' . $file_type])) {
$QA_RELEASES[$pversion]['release']['files'][$file_type][$algo] = $info['release'][$algo . '_' . $file_type];
}
}
if (!empty($QA_RELEASES[$pversion]['release']['files'][$file_type])) {
$QA_RELEASES[$pversion]['release']['files'][$file_type]['path']= $info['release']['baseurl'] . $fn_base . '.tar.' . $file_type;
}
}
if (empty($QA_RELEASES[$pversion]['release']['files'])) {
$QA_RELEASES[$pversion]['release']['enabled'] = false;
}
}
} else {
$QA_RELEASES[$pversion]['release']['enabled'] = false;
}
}
}
// Sorted information for later use
// @todo need these?
// $QA_RELEASES['releases'] : All current versions with active qa releases
foreach ($QA_RELEASES as $pversion => $info) {
if (isset($info['active']) && $info['active'] && !empty($info['release']['number'])) {
$QA_RELEASES['releases'][$pversion] = $info['release'];
}
}
})($QA_RELEASES);