]>
Commit | Line | Data |
---|---|---|
1 | #!/usr/bin/python -u | |
2 | #---------------------------------------------------------------------- | |
3 | # Name: build-all.py | |
4 | # Purpose: Master build script for building all the wxPython | |
5 | # installers and such on all the build machines in | |
6 | # my lab, and then distributing the results as needed. | |
7 | # | |
8 | # This will replace the build-all bash script and is | |
9 | # needed because the needs of the build have outgrown | |
10 | # what I can do with bash. | |
11 | # | |
12 | # Author: Robin Dunn | |
13 | # | |
14 | # Created: 05-Nov-2004 | |
15 | # RCS-ID: $Id$ | |
16 | # Copyright: (c) 2004 by Total Control Software | |
17 | # Licence: wxWindows license | |
18 | #---------------------------------------------------------------------- | |
19 | ||
20 | import sys | |
21 | import os | |
22 | import time | |
23 | from taskrunner import Job, Task, TaskRunner, Config | |
24 | ||
25 | #---------------------------------------------------------------------- | |
26 | # Configuration items | |
27 | ||
28 | CFGFILE = "./distrib/all/build-environ.cfg" | |
29 | config = Config() | |
30 | config.read(CFGFILE) | |
31 | ||
32 | #---------------------------------------------------------------------- | |
33 | # Define all the build tasks | |
34 | ||
35 | class Job(Job): | |
36 | LOGBASE = "./tmp" | |
37 | ||
38 | #---------------------------------------------------------------------- | |
39 | ||
40 | def getTasks(config_env): | |
41 | # Things that need to be done before any of the builds | |
42 | initialTask = Task([ | |
43 | Job("", "distrib/all/build-setup", env=config_env), | |
44 | Job("", "distrib/all/build-docs", env=config_env), | |
45 | Job("", "distrib/all/build-sources", env=config_env), | |
46 | ]) | |
47 | ||
48 | # Build tasks. Anything that can be done in parallel (depends greatly | |
49 | # on the nature of the build machines configurations...) is a separate | |
50 | # task. | |
51 | ||
52 | ## jaguarTask = Task( Job("whopper.23", "distrib/all/build-osx", | |
53 | ## [config.OSX_HOST_jaguar, "2.3", "ansi"], env=config_env) ) | |
54 | ||
55 | pantherTask = Task( [ Job("bigmac.23", | |
56 | "distrib/all/build-osx", | |
57 | [config.OSX_HOST_panther, "2.3", "both"], env=config_env), | |
58 | Job("bigmac.24", | |
59 | "distrib/all/build-osx", | |
60 | [config.OSX_HOST_panther, "2.4", "both"], env=config_env) | |
61 | ]) | |
62 | ||
63 | tigerTask = Task([ #Job("smallfry.23", | |
64 | # "distrib/all/build-osx", | |
65 | # [config.OSX_HOST_tiger, "2.3", "both"], env=config_env), | |
66 | Job("smallfry.24", | |
67 | "distrib/all/build-osx", | |
68 | [config.OSX_HOST_tiger, "2.4", "both", "universal"], env=config_env), | |
69 | Job("smallfry.25", | |
70 | "distrib/all/build-osx", | |
71 | [config.OSX_HOST_tiger, "2.5", "both", "universal"], env=config_env) | |
72 | ]) | |
73 | ||
74 | ||
75 | beastTask1 = Task( | |
76 | [ #Job("beast.23", "distrib/all/build-windows", ["2.3"], env=config_env), | |
77 | # Job("co-rh9.23", "distrib/all/build-rpm", ["beast", "co-rh9", "rh9", "2.3"], env=config_env), | |
78 | Job("beast.24", "distrib/all/build-windows", ["2.4"], env=config_env), | |
79 | # Job("co-rh9.24", "distrib/all/build-rpm", ["beast", "co-rh9", "rh9", "2.4"], env=config_env), | |
80 | Job("beast.25", "distrib/all/build-windows", ["2.5"], env=config_env), | |
81 | Job("co-mdk2006.24","distrib/all/build-rpm", ["beast", "co-mdk2006", "mdk2006", "2.4"], env=config_env), | |
82 | ]) | |
83 | ||
84 | beastTask2 = Task( | |
85 | [ #Job("co-fc2.23", "distrib/all/build-rpm", ["beast", "co-fc2", "fc2", "2.3"], env=config_env), | |
86 | Job("co-fc4.24", "distrib/all/build-rpm", ["beast", "co-fc4", "fc4", "2.4"], env=config_env), | |
87 | Job("co-mdk102.24", "distrib/all/build-rpm", ["beast", "co-mdk102", "mdk102", "2.4"], env=config_env), | |
88 | # Job("co-mdk2006.24","distrib/all/build-rpm", ["beast", "co-mdk2006", "mdk2006", "2.4"], env=config_env), | |
89 | ]) | |
90 | ||
91 | xavierTask = Task([ | |
92 | Job("xavier", "distrib/all/build-deb", ["xavier", "/work/chroot/dapper", "dapper"], env=config_env), | |
93 | ]) | |
94 | ||
95 | buildTasks = [ #jaguarTask, | |
96 | pantherTask, | |
97 | tigerTask, | |
98 | beastTask1, | |
99 | beastTask2, | |
100 | xavierTask, | |
101 | ] | |
102 | ||
103 | # Finalization. This is for things that must wait until all the | |
104 | # builds are done, such as copying the installers someplace, sending | |
105 | # emails, etc. | |
106 | finalizationTask = Task( Job("", "distrib/all/build-finalize", env=config_env) ) | |
107 | ||
108 | return initialTask, buildTasks, finalizationTask | |
109 | ||
110 | ||
111 | #---------------------------------------------------------------------- | |
112 | ||
113 | def usage(): | |
114 | print "" | |
115 | print "Usage: build-all [command flags...]" | |
116 | print "" | |
117 | print "build types:" | |
118 | print " dryrun Do the build, but don't copy anywhere (default)" | |
119 | print " daily Do a daily build, copy to starship" | |
120 | print " release Do a normal release (cantidate) build, copy to starship" | |
121 | print "" | |
122 | print "optional command flags:" | |
123 | print " skipsource Don't build the source archives, use the ones" | |
124 | print " already in the staging dir." | |
125 | print " onlysource Exit after building the source and docs archives" | |
126 | print " skipdocs Don't rebuild the docs" | |
127 | print " skipwin Don't do the remote Windows build" | |
128 | print " skiposx Don't do the remote OSX build" | |
129 | print " skiprpm Don't do the remote Linux (RPM) build" | |
130 | print " skipdeb Don't do the remote Linux (DEB) build" | |
131 | print " skipclean Don't do the cleanup step on the remote builds" | |
132 | print " skipupload Don't upload the builds to starship" | |
133 | print " ansi Also do the ansi builds" | |
134 | print "" | |
135 | print " nocohost Don't start the coLinux sessions if they are" | |
136 | print " not already online" | |
137 | print "" | |
138 | ||
139 | ||
140 | #---------------------------------------------------------------------- | |
141 | ||
142 | def main(args): | |
143 | # Make sure we are running in the right directory. TODO: make | |
144 | # this test more robust. Currenly we just test for the presence | |
145 | # of 'wxPython' and 'wx' subdirs. | |
146 | if not os.path.isdir("wxPython") or not os.path.isdir("wx"): | |
147 | print "Please run this script from the root wxPython directory." | |
148 | sys.exit(1) | |
149 | ||
150 | ||
151 | ||
152 | # Check command line flags | |
153 | for flag in args: | |
154 | if flag in ["dryrun", "daily", "release"]: | |
155 | config.KIND = flag | |
156 | ||
157 | elif flag == "skipsource": | |
158 | config.skipsource = "yes" | |
159 | ||
160 | elif flag == "onlysource": | |
161 | config.onlysource = "yes" | |
162 | ||
163 | elif flag == "skipdocs": | |
164 | config.skipdocs = "yes" | |
165 | ||
166 | elif flag == "skipnewdocs": | |
167 | config.skipnewdocs = "yes" | |
168 | ||
169 | elif flag == "skipwin": | |
170 | config.skipwin = "yes" | |
171 | ||
172 | elif flag == "skiposx": | |
173 | config.skiposx = "yes" | |
174 | ||
175 | elif flag == "skipdeb": | |
176 | config.skipdeb = "yes" | |
177 | ||
178 | elif flag == "skiprpm": | |
179 | config.skiprpm = "yes" | |
180 | ||
181 | elif flag == "skipclean": | |
182 | config.skipclean = "yes" | |
183 | ||
184 | elif flag == "skipupload": | |
185 | config.skipupload = "yes" | |
186 | ||
187 | elif flag == "ansi": | |
188 | config.buildansi = "yes" | |
189 | ||
190 | elif flag == "nocohost": | |
191 | config.startcohost = "no" | |
192 | ||
193 | else: | |
194 | print 'Unknown flag: "%s"' % flag | |
195 | usage() | |
196 | sys.exit(2) | |
197 | ||
198 | ||
199 | # ensure the staging area exists | |
200 | if not os.path.exists(config.STAGING_DIR): | |
201 | os.makedirs(config.STAGING_DIR) | |
202 | ||
203 | # Figure out the wxPython version number, possibly adjusted for being a daily build | |
204 | if config.KIND == "daily": | |
205 | t = time.localtime() | |
206 | config.DAILY = time.strftime("%Y%m%d") # should it include the hour too? 2-digit year? | |
207 | file("DAILY_BUILD", "w").write(config.DAILY) | |
208 | sys.path.append('.') | |
209 | import setup | |
210 | v = config.VERSION = setup.VERSION | |
211 | config.VER2 = '.'.join(v.split('.')[:2]) | |
212 | ||
213 | config_env = config.asDict() | |
214 | config_env.update(os.environ) | |
215 | ||
216 | initialTask, buildTasks, finalizationTask = getTasks(config_env) | |
217 | ||
218 | print "Build getting started at: ", time.ctime() | |
219 | ||
220 | # Run the first task, which will create the docs and sources tarballs | |
221 | tr = TaskRunner(initialTask) | |
222 | rc = tr.run() | |
223 | ||
224 | # cleanup the DAILY_BUILD file | |
225 | if config.KIND == "daily": | |
226 | os.unlink("DAILY_BUILD") | |
227 | ||
228 | # Quit now? | |
229 | if rc != 0 or config.onlysource == "yes": | |
230 | sys.exit(rc) | |
231 | ||
232 | ||
233 | # Run the main build tasks | |
234 | tr = TaskRunner(buildTasks) | |
235 | rc = tr.run() | |
236 | if rc != 0: | |
237 | sys.exit(rc) | |
238 | ||
239 | ||
240 | # when all the builds are done, run the finalization task | |
241 | tr = TaskRunner(finalizationTask) | |
242 | rc = tr.run() | |
243 | if rc != 0: | |
244 | sys.exit(rc) | |
245 | ||
246 | ||
247 | print "Build finished at: ", time.ctime() | |
248 | sys.exit(0) | |
249 | ||
250 | ||
251 | ||
252 | ||
253 | if __name__ == "__main__": | |
254 | main(sys.argv[1:]) |