forked from php/web-qa
/
release-qa.php
202 lines (168 loc) · 7.42 KB
/
release-qa.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
<?php /* $Id$ */
/*
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
- snap (array):
- Define the array to link at qa.php.net, otherwise array() to not list it
- prefix: prefix of the filename, minus the .tar.gz/bz2 extensions
- baseurl: base url of snaps server
- We define a prefix because our snapshot filenames are not consistent with version (e.g., php-trunk)
- 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
- md5_bz2: md5 checksum of this downloadable .tar.bz2 file
- md5_gz: md5 checksum of this downloadable .tar.gz file
- date: date of release e.g., 21 May 2011
- baseurl: base url of where these downloads are located
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/ md5 info)
- snaps: all current snaps, including paths to dl urls
- 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
- Consider not linking to snaps if rcs exist
- Determine best way to handle snap/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 = array(
'5.3.12' => array(
'active' => true,
'snaps' => array(
'prefix' => 'php5.3-latest',
'baseurl' => 'http://snaps.php.net/',
),
'release' => array(
'type' => 'RC',
'number' => 0,
'md5_bz2' => '',
'md5_gz' => '',
'date' => '12 April 2011',
'baseurl' => 'http://downloads.php.net/johannes/',
),
),
'5.4.2' => array(
'active' => true,
'snaps' => array(
'prefix' => 'php5.4-latest',
'baseurl' => 'http://snaps.php.net/',
),
'release' => array(
'type' => 'RC',
'number' => 0,
'md5_bz2' => '',
'md5_gz' => '',
'date' => '12 April 2012',
'baseurl' => 'http://downloads.php.net/stas/',
),
),
'trunk' => array(
'active' => false,
'snaps' => array(
'prefix' => 'php-trunk-latest',
'baseurl' => 'http://snaps.php.net/',
),
),
);
/*** End Configuration *******************************************************************/
// $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
// snap : Snapshots that are being monitored by the QA team
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";
// Allowed snaps, unless 'snaps' => array() (empty)
if (!empty($info['snaps'])) {
$QA_RELEASES[$pversion]['snaps']['files']['bz2']['path'] = $info['snaps']['baseurl'] . $info['snaps']['prefix'] . '.tar.bz2';
$QA_RELEASES[$pversion]['snaps']['files']['gz']['path'] = $info['snaps']['baseurl'] . $info['snaps']['prefix'] . '.tar.gz';
}
// 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'];
$QA_RELEASES[$pversion]['release']['files']['bz2']['path']= $info['release']['baseurl'] . $fn_base . '.tar.bz2';
$QA_RELEASES[$pversion]['release']['files']['bz2']['md5'] = $info['release']['md5_bz2'];
$QA_RELEASES[$pversion]['release']['files']['gz']['path'] = $info['release']['baseurl'] . $fn_base . '.tar.gz';
$QA_RELEASES[$pversion]['release']['files']['gz']['md5'] = $info['release']['md5_gz'];
}
} 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
// $QA_RELEASES['snaps'] : All current versions with active snaps
foreach ($QA_RELEASES as $pversion => $info) {
if (isset($info['active']) && $info['active']) {
if (!empty($info['release']['number'])) {
$QA_RELEASES['releases'][$pversion] = $info['release'];
}
if (!empty($info['snaps'])) {
$QA_RELEASES['snaps'][$pversion] = $info['snaps'];
}
}
}
/* Content */
function show_release_qa($QA_RELEASES) {
echo "<!-- RELEASE QA -->\n";
if (!empty($QA_RELEASES['releases'])) {
$plural = count($QA_RELEASES['releases']) > 1 ? 's' : '';
// QA Releases
echo "<span class='lihack'>\n";
echo "Providing QA for the following <a href='http://qa.php.net/rc.php'>test release{$plural}</a>:\n";
echo "<ul>\n";
// @todo check for vars, like if md5_* are set
foreach ($QA_RELEASES['releases'] as $pversion => $info) {
// pure madness
echo "<li>{$info['version']}: [<a href='{$info['files']['bz2']['path']}'>tar.bz2</a>] (md5 checksum: {$info['files']['bz2']['md5']})</li>\n";
echo "<li>{$info['version']}: [<a href='{$info['files']['gz']['path']}'>tar.gz</a>] (md5 checksum: {$info['files']['gz']['md5']})</li>\n";
}
echo "</ul>\n</span>\n";
}
if (!empty($QA_RELEASES['snaps'])) {
$plural = count($QA_RELEASES['snaps']) > 1 ? 's' : '';
// Snap for dev releases
echo "Providing QA for the following snapshot{$plural} of future PHP versions:\n";
echo "<span class='lihack'>\n";
echo "<ul>\n";
// @todo check for vars, like if md5_* are set
foreach ($QA_RELEASES['snaps'] as $pversion => $info) {
// more madness
echo "<li>$pversion: ";
echo "[<a href='{$info['files']['bz2']['path']}'>tar.bz2</a>] or ";
echo "[<a href='{$info['files']['gz']['path']}'>tar.gz</a>]</li>\n";
}
echo "</ul>\n</span>\n";
}
echo "<!-- END -->\n";
}