blob: 7bf6809fe08915a25ce2972e97fcd25638b189d2 [file] [log] [blame]
Daniel Dunbar44abe742009-07-19 01:59:03 +00001import os
2
Daniel Dunbar235aa412009-07-18 07:16:15 +00003import buildbot
4import buildbot.process.factory
5from buildbot.steps.source import SVN
Daniel Dunbar44abe742009-07-19 01:59:03 +00006from buildbot.steps.shell import Configure, ShellCommand
7from buildbot.steps.shell import WarningCountingShellCommand
8from buildbot.steps.transfer import FileDownload
Daniel Dunbar235aa412009-07-18 07:16:15 +00009from buildbot.process.properties import WithProperties
10
Daniel Dunbar235aa412009-07-18 07:16:15 +000011from zorg.buildbot.commands.ClangTestCommand import ClangTestCommand
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +000012from zorg.buildbot.commands.BatchFileDownload import BatchFileDownload
Daniel Dunbar22d594a2010-07-31 05:29:16 +000013from zorg.buildbot.commands import DejaGNUCommand
Daniel Dunbar235aa412009-07-18 07:16:15 +000014
Daniel Dunbar2b67e8f2011-02-11 21:03:41 +000015from zorg.buildbot.builders.Util import getConfigArgs
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +000016
Galina Kistanovaf4d79352011-10-20 20:46:52 +000017def getClangBuildFactory(
18 triple=None,
19 clean=True,
20 test=True,
21 package_dst=None,
22 run_cxx_tests=False,
23 examples=False,
24 valgrind=False,
25 valgrindLeakCheck=False,
26 outOfDir=False,
27 useTwoStage=False,
28 completely_clean=False,
Galina Kistanovaf4d79352011-10-20 20:46:52 +000029 make='make',
30 jobs="%(jobs)s",
31 stage1_config='Debug+Asserts',
32 stage2_config='Release+Asserts',
33 env={}, # Environmental variables for all steps.
34 extra_configure_args=[],
35 use_pty_in_tests=False,
Peter Collingbourned49ac282011-10-25 14:38:45 +000036 trunk_revision=None,
37 force_checkout=False,
Peter Collingbourne7a95b0c2011-10-26 16:40:17 +000038 extra_clean_step=None,
David Blaikiea76da842012-08-13 22:24:46 +000039 checkout_compiler_rt=False,
40 run_gdb=False,
David Blaikiedad03d52012-11-16 22:37:12 +000041 run_modern_gdb=False,
David Blaikiea76da842012-08-13 22:24:46 +000042 run_gcc=False):
Galina Kistanovaf4d79352011-10-20 20:46:52 +000043 # Prepare environmental variables. Set here all env we want everywhere.
44 merged_env = {
45 'TERM' : 'dumb' # Make sure Clang doesn't use color escape sequences.
46 }
47 if env is not None:
48 # Overwrite pre-set items with the given ones, so user can set anything.
49 merged_env.update(env)
David Blaikie2f7eb282012-08-24 18:37:00 +000050
David Blaikiedad03d52012-11-16 22:37:12 +000051 if run_gdb or run_gcc or run_modern_gdb:
David Blaikie88511c72012-08-24 23:14:06 +000052 outOfDir = True
Galina Kistanovaf4d79352011-10-20 20:46:52 +000053
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +000054 # Don't use in-dir builds with a two stage build process.
Daniel Dunbar3efb7822010-02-26 19:20:00 +000055 inDir = not outOfDir and not useTwoStage
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +000056 if inDir:
57 llvm_srcdir = "llvm"
58 llvm_1_objdir = "llvm"
David Blaikie88511c72012-08-24 23:14:06 +000059 llvm_1_installdir = None
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +000060 else:
61 llvm_srcdir = "llvm.src"
62 llvm_1_objdir = "llvm.obj"
63 llvm_1_installdir = "llvm.install.1"
64 llvm_2_objdir = "llvm.obj.2"
Daniel Dunbar22d594a2010-07-31 05:29:16 +000065 llvm_2_installdir = "llvm.install"
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +000066
Daniel Dunbar235aa412009-07-18 07:16:15 +000067 f = buildbot.process.factory.BuildFactory()
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +000068
69 # Determine the build directory.
70 f.addStep(buildbot.steps.shell.SetProperty(name="get_builddir",
71 command=["pwd"],
72 property="builddir",
73 description="set build dir",
Galina Kistanovaf4d79352011-10-20 20:46:52 +000074 workdir=".",
75 env=merged_env))
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +000076
Daniel Dunbar06b20f12010-04-08 18:29:38 +000077 # Blow away completely, if requested.
78 if completely_clean:
79 f.addStep(ShellCommand(name="rm-llvm.src",
80 command=["rm", "-rf", llvm_srcdir],
81 haltOnFailure=True,
82 description=["rm src dir", "llvm"],
Galina Kistanovaf4d79352011-10-20 20:46:52 +000083 workdir=".",
84 env=merged_env))
Daniel Dunbar06b20f12010-04-08 18:29:38 +000085
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +000086 # Checkout sources.
Peter Collingbourned49ac282011-10-25 14:38:45 +000087 if trunk_revision:
88 # The SVN build step provides no mechanism to check out a specific revision
89 # based on a property, so just run the commands directly here.
90 svn_co = ['svn', 'checkout']
91 if force_checkout:
92 svn_co += ['--force']
93 svn_co += ['--revision', WithProperties(trunk_revision)]
94
95 svn_co_llvm = svn_co + \
96 [WithProperties('http://llvm.org/svn/llvm-project/llvm/trunk@%s' %
97 trunk_revision),
98 llvm_srcdir]
99 svn_co_clang = svn_co + \
100 [WithProperties('http://llvm.org/svn/llvm-project/cfe/trunk@%s' %
101 trunk_revision),
102 '%s/tools/clang' % llvm_srcdir]
David Blaikie845ae0d2012-08-10 00:51:38 +0000103 svn_co_clang_tools_extra = svn_co + \
104 [WithProperties('http://llvm.org/svn/llvm-project/clang-tools-extra/trunk@%s' %
105 trunk_revision),
106 '%s/tools/clang/tools/extra' % llvm_srcdir]
Peter Collingbourned49ac282011-10-25 14:38:45 +0000107
108 f.addStep(ShellCommand(name='svn-llvm',
109 command=svn_co_llvm,
110 haltOnFailure=True,
111 workdir='.'))
112 f.addStep(ShellCommand(name='svn-clang',
113 command=svn_co_clang,
114 haltOnFailure=True,
115 workdir='.'))
David Blaikie845ae0d2012-08-10 00:51:38 +0000116 f.addStep(ShellCommand(name='svn-clang-tools-extra',
117 command=svn_co_clang_tools_extra,
118 haltOnFailure=True,
119 workdir='.'))
Peter Collingbourned49ac282011-10-25 14:38:45 +0000120 else:
121 f.addStep(SVN(name='svn-llvm',
Daniel Dunbarf4e23eb2010-09-20 21:13:02 +0000122 mode='update',
Peter Collingbourned49ac282011-10-25 14:38:45 +0000123 baseURL='http://llvm.org/svn/llvm-project/llvm/',
Daniel Dunbarf4e23eb2010-09-20 21:13:02 +0000124 defaultBranch='trunk',
Peter Collingbourned49ac282011-10-25 14:38:45 +0000125 workdir=llvm_srcdir))
126 f.addStep(SVN(name='svn-clang',
127 mode='update',
128 baseURL='http://llvm.org/svn/llvm-project/cfe/',
129 defaultBranch='trunk',
130 workdir='%s/tools/clang' % llvm_srcdir))
David Blaikie845ae0d2012-08-10 00:51:38 +0000131 f.addStep(SVN(name='svn-clang-tools-extra',
132 mode='update',
133 baseURL='http://llvm.org/svn/llvm-project/clang-tools-extra/',
134 defaultBranch='trunk',
135 workdir='%s/tools/clang/tools/extra' % llvm_srcdir))
Peter Collingbourned49ac282011-10-25 14:38:45 +0000136 if checkout_compiler_rt:
137 f.addStep(SVN(name='svn-compiler-rt',
138 mode='update',
139 baseURL='http://llvm.org/svn/llvm-project/compiler-rt/',
140 defaultBranch='trunk',
141 workdir='%s/projects/compiler-rt' % llvm_srcdir))
Daniel Dunbarfa0e0222009-11-09 06:08:28 +0000142
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000143 # Clean up llvm (stage 1); unless in-dir.
144 if clean and llvm_srcdir != llvm_1_objdir:
145 f.addStep(ShellCommand(name="rm-llvm.obj.stage1",
146 command=["rm", "-rf", llvm_1_objdir],
147 haltOnFailure=True,
148 description=["rm build dir", "llvm"],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000149 workdir=".",
150 env=merged_env))
Andrew Trick70fa9d22011-08-25 23:38:51 +0000151
Daniel Dunbarfa0e0222009-11-09 06:08:28 +0000152 # Force without llvm-gcc so we don't run afoul of Frontend test failures.
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000153 base_configure_args = [WithProperties("%%(builddir)s/%s/configure" % llvm_srcdir),
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000154 '--disable-bindings']
155 base_configure_args += extra_configure_args
Daniel Dunbarfa0e0222009-11-09 06:08:28 +0000156 if triple:
Andrew Trick70fa9d22011-08-25 23:38:51 +0000157 base_configure_args += ['--build=%s' % triple,
David Dean7da22862012-10-01 19:57:30 +0000158 '--host=%s' % triple]
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000159 args = base_configure_args + ["--without-llvmgcc", "--without-llvmgxx"]
Daniel Dunbar3efb7822010-02-26 19:20:00 +0000160 args.append(WithProperties("--prefix=%%(builddir)s/%s" % llvm_1_installdir))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000161 args += getConfigArgs(stage1_config)
162 f.addStep(Configure(command=args,
163 workdir=llvm_1_objdir,
164 description=['configuring',stage1_config],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000165 descriptionDone=['configure',stage1_config],
166 env=merged_env))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000167
168 # Make clean if using in-dir builds.
169 if clean and llvm_srcdir == llvm_1_objdir:
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000170 f.addStep(WarningCountingShellCommand(name="clean-llvm",
Daniel Dunbard20468a2009-11-24 18:27:23 +0000171 command=[make, "clean"],
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000172 haltOnFailure=True,
173 description="cleaning llvm",
174 descriptionDone="clean llvm",
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000175 workdir=llvm_1_objdir,
Peter Collingbourne7a95b0c2011-10-26 16:40:17 +0000176 doStepIf=clean,
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000177 env=merged_env))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000178
Peter Collingbourne7a95b0c2011-10-26 16:40:17 +0000179 if extra_clean_step:
180 f.addStep(extra_clean_step)
181
Daniel Dunbar7e959c82009-09-28 04:01:19 +0000182 f.addStep(WarningCountingShellCommand(name="compile",
Daniel Dunbard20468a2009-11-24 18:27:23 +0000183 command=['nice', '-n', '10',
184 make, WithProperties("-j%s" % jobs)],
Daniel Dunbar7e959c82009-09-28 04:01:19 +0000185 haltOnFailure=True,
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000186 description=["compiling", stage1_config],
187 descriptionDone=["compile", stage1_config],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000188 workdir=llvm_1_objdir,
189 env=merged_env))
Daniel Dunbar256fed42009-11-25 21:11:08 +0000190
191 if examples:
192 f.addStep(WarningCountingShellCommand(name="compile.examples",
193 command=['nice', '-n', '10',
194 make, WithProperties("-j%s" % jobs),
195 "BUILD_EXAMPLES=1"],
196 haltOnFailure=True,
197 description=["compilinge", stage1_config, "examples"],
198 descriptionDone=["compile", stage1_config, "examples"],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000199 workdir=llvm_1_objdir,
200 env=merged_env))
Daniel Dunbar256fed42009-11-25 21:11:08 +0000201
Daniel Dunbar93f828a2010-06-23 17:42:14 +0000202 clangTestArgs = llvmTestArgs = '-v -j %s' % jobs
Daniel Dunbarfa0e0222009-11-09 06:08:28 +0000203 if valgrind:
Daniel Dunbar89184b92010-04-18 19:09:32 +0000204 clangTestArgs += ' --vg'
Daniel Dunbara1bebce2010-03-21 01:24:00 +0000205 if valgrindLeakCheck:
206 clangTestArgs += ' --vg-leak'
Nick Lewycky8d26e472011-08-27 21:18:56 +0000207 clangTestArgs += ' --vg-arg --suppressions=%(builddir)s/llvm/tools/clang/utils/valgrind/x86_64-pc-linux-gnu_gcc-4.3.3.supp --vg-arg --suppressions=%(builddir)s/llvm/utils/valgrind/x86_64-pc-linux-gnu.supp'
Daniel Dunbarfa0e0222009-11-09 06:08:28 +0000208 extraTestDirs = ''
209 if run_cxx_tests:
210 extraTestDirs += '%(builddir)s/llvm/tools/clang/utils/C++Tests'
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000211 if test:
David Blaikie7e6f8a12012-08-31 20:46:27 +0000212 f.addStep(ClangTestCommand(name='check-all',
213 command=[make, "check-all", "VERBOSE=1",
Daniel Dunbar93f828a2010-06-23 17:42:14 +0000214 WithProperties("LIT_ARGS=%s" % llvmTestArgs)],
David Blaikie7e6f8a12012-08-31 20:46:27 +0000215 description=["checking"],
216 descriptionDone=["checked"],
Daniel Dunbar469e8ca2010-05-19 21:26:48 +0000217 workdir=llvm_1_objdir,
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000218 usePTY=use_pty_in_tests,
219 env=merged_env))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000220
221 # Install llvm and clang.
222 if llvm_1_installdir:
Daniel Dunbar9870de32010-03-28 22:25:31 +0000223 f.addStep(ShellCommand(name="rm-install.clang.stage1",
224 command=["rm", "-rf", llvm_1_installdir],
225 haltOnFailure=True,
226 description=["rm install dir", "clang"],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000227 workdir=".",
228 env=merged_env))
Daniel Dunbar9870de32010-03-28 22:25:31 +0000229 f.addStep(WarningCountingShellCommand(name="install.clang.stage1",
230 command = ['nice', '-n', '10',
231 make, 'install-clang'],
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000232 haltOnFailure=True,
Daniel Dunbar9870de32010-03-28 22:25:31 +0000233 description=["install", "clang",
234 stage1_config],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000235 workdir=llvm_1_objdir,
236 env=merged_env))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000237
David Blaikiedad03d52012-11-16 22:37:12 +0000238 if run_gdb or run_gcc or run_modern_gdb:
David Blaikiea76da842012-08-13 22:24:46 +0000239 ignores = getClangTestsIgnoresFromPath(os.path.expanduser('~/public/clang-tests'), 'clang-x86_64-darwin10')
240 install_prefix = "%%(builddir)s/%s" % llvm_1_installdir
241 if run_gdb:
242 addClangGDBTests(f, ignores, install_prefix)
David Blaikiedad03d52012-11-16 22:37:12 +0000243 if run_modern_gdb:
244 addModernClangGDBTests(f, jobs, install_prefix)
David Blaikiea76da842012-08-13 22:24:46 +0000245 if run_gcc:
246 addClangGCCTests(f, ignores, install_prefix)
247
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000248 if not useTwoStage:
Daniel Dunbardedf6572010-11-13 00:23:34 +0000249 if package_dst:
250 name = WithProperties(
251 "%(builddir)s/" + llvm_1_objdir +
252 "/clang-r%(got_revision)s-b%(buildnumber)s.tgz")
253 f.addStep(ShellCommand(name='pkg.tar',
254 description="tar root",
255 command=["tar", "zcvf", name, "./"],
256 workdir=llvm_1_installdir,
257 warnOnFailure=True,
258 flunkOnFailure=False,
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000259 haltOnFailure=False,
260 env=merged_env))
Daniel Dunbardedf6572010-11-13 00:23:34 +0000261 f.addStep(ShellCommand(name='pkg.upload',
Andrew Trick70fa9d22011-08-25 23:38:51 +0000262 description="upload root",
Daniel Dunbardedf6572010-11-13 00:23:34 +0000263 command=["scp", name,
264 WithProperties(
265 package_dst + "/%(buildername)s")],
266 workdir=".",
267 warnOnFailure=True,
268 flunkOnFailure=False,
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000269 haltOnFailure=False,
270 env=merged_env))
Daniel Dunbardedf6572010-11-13 00:23:34 +0000271
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000272 return f
273
274 # Clean up llvm (stage 2).
275 if clean:
276 f.addStep(ShellCommand(name="rm-llvm.obj.stage2",
277 command=["rm", "-rf", llvm_2_objdir],
278 haltOnFailure=True,
279 description=["rm build dir", "llvm", "(stage 2)"],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000280 workdir=".",
281 env=merged_env))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000282
283 # Configure llvm (stage 2).
284 args = base_configure_args + ["--without-llvmgcc", "--without-llvmgxx"]
Daniel Dunbar3efb7822010-02-26 19:20:00 +0000285 args.append(WithProperties("--prefix=%(builddir)s/" + llvm_2_installdir))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000286 args += getConfigArgs(stage2_config)
Benjamin Kramer9c6fed72012-07-20 10:18:32 +0000287 local_env = dict(merged_env)
288 local_env.update({
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000289 'CC' : WithProperties("%%(builddir)s/%s/bin/clang" % llvm_1_installdir),
290 'CXX' : WithProperties("%%(builddir)s/%s/bin/clang++" % llvm_1_installdir)})
291
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000292 f.addStep(Configure(name="configure.llvm.stage2",
293 command=args,
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000294 haltOnFailure=True,
295 workdir=llvm_2_objdir,
296 description=["configure", "llvm", "(stage 2)",
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000297 stage2_config],
298 env=local_env))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000299
300 # Build llvm (stage 2).
301 f.addStep(WarningCountingShellCommand(name="compile.llvm.stage2",
302 command=['nice', '-n', '10',
303 make, WithProperties("-j%s" % jobs)],
304 haltOnFailure=True,
305 description=["compiling", "(stage 2)",
306 stage2_config],
307 descriptionDone=["compile", "(stage 2)",
308 stage2_config],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000309 workdir=llvm_2_objdir,
310 env=merged_env))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000311
312 if test:
David Blaikie7e6f8a12012-08-31 20:46:27 +0000313 f.addStep(ClangTestCommand(name='check-all',
314 command=[make, "check-all", "VERBOSE=1",
Daniel Dunbar93f828a2010-06-23 17:42:14 +0000315 WithProperties("LIT_ARGS=%s" % llvmTestArgs)],
David Blaikie7e6f8a12012-08-31 20:46:27 +0000316 description=["checking"],
317 descriptionDone=["checked"],
Daniel Dunbar469e8ca2010-05-19 21:26:48 +0000318 workdir=llvm_2_objdir,
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000319 usePTY=use_pty_in_tests,
320 env=merged_env))
Daniel Dunbar8a89a6f2009-11-25 04:27:32 +0000321
Daniel Dunbar3efb7822010-02-26 19:20:00 +0000322 # Install clang (stage 2).
Daniel Dunbar9870de32010-03-28 22:25:31 +0000323 f.addStep(ShellCommand(name="rm-install.clang.stage2",
324 command=["rm", "-rf", llvm_2_installdir],
325 haltOnFailure=True,
326 description=["rm install dir", "clang"],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000327 workdir=".",
328 env=merged_env))
Daniel Dunbar3efb7822010-02-26 19:20:00 +0000329 f.addStep(WarningCountingShellCommand(name="install.clang.stage2",
330 command = ['nice', '-n', '10',
331 make, 'install-clang'],
332 haltOnFailure=True,
333 description=["install", "clang",
334 "(stage 2)"],
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000335 workdir=llvm_2_objdir,
336 env=merged_env))
Daniel Dunbar3efb7822010-02-26 19:20:00 +0000337
338 if package_dst:
339 name = WithProperties(
340 "%(builddir)s/" + llvm_2_objdir +
341 "/clang-r%(got_revision)s-b%(buildnumber)s.tgz")
342 f.addStep(ShellCommand(name='pkg.tar',
343 description="tar root",
344 command=["tar", "zcvf", name, "./"],
345 workdir=llvm_2_installdir,
346 warnOnFailure=True,
347 flunkOnFailure=False,
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000348 haltOnFailure=False,
349 env=merged_env))
Daniel Dunbar3efb7822010-02-26 19:20:00 +0000350 f.addStep(ShellCommand(name='pkg.upload',
Andrew Trick70fa9d22011-08-25 23:38:51 +0000351 description="upload root",
Daniel Dunbar3efb7822010-02-26 19:20:00 +0000352 command=["scp", name,
353 WithProperties(
354 package_dst + "/%(buildername)s")],
355 workdir=".",
356 warnOnFailure=True,
357 flunkOnFailure=False,
Galina Kistanovaf4d79352011-10-20 20:46:52 +0000358 haltOnFailure=False,
359 env=merged_env))
Daniel Dunbar3efb7822010-02-26 19:20:00 +0000360
Daniel Dunbar235aa412009-07-18 07:16:15 +0000361 return f
Daniel Dunbar44abe742009-07-19 01:59:03 +0000362
Daniel Dunbarc51a59e2010-09-23 14:57:45 +0000363def getClangMSVCBuildFactory(update=True, clean=True, vcDrive='c', jobs=1, cmake=r"cmake"):
Daniel Dunbar44abe742009-07-19 01:59:03 +0000364 f = buildbot.process.factory.BuildFactory()
365
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000366 if update:
Daniel Dunbar44abe742009-07-19 01:59:03 +0000367 f.addStep(SVN(name='svn-llvm',
368 mode='update', baseURL='http://llvm.org/svn/llvm-project/llvm/',
369 defaultBranch='trunk',
370 workdir='llvm'))
Daniel Dunbar44abe742009-07-19 01:59:03 +0000371 f.addStep(SVN(name='svn-clang',
Daniel Dunbar7e959c82009-09-28 04:01:19 +0000372 mode='update', baseURL='http://llvm.org/svn/llvm-project/cfe/',
Daniel Dunbar44abe742009-07-19 01:59:03 +0000373 defaultBranch='trunk',
374 workdir='llvm/tools/clang'))
David Blaikie845ae0d2012-08-10 00:51:38 +0000375 f.addStep(SVN(name='svn-clang-tools-extra',
376 mode='update', baseURL='http://llvm.org/svn/llvm-project/clang-tools-extra/',
377 defaultBranch='trunk',
378 workdir='llvm/tools/clang/tools/extra'))
Daniel Dunbar44abe742009-07-19 01:59:03 +0000379
380 # Full & fast clean.
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000381 if clean:
Daniel Dunbar44abe742009-07-19 01:59:03 +0000382 f.addStep(ShellCommand(name='clean-1',
383 command=['del','/s/q','build'],
Daniel Dunbar7e959c82009-09-28 04:01:19 +0000384 warnOnFailure=True,
Daniel Dunbar44abe742009-07-19 01:59:03 +0000385 description='cleaning',
386 descriptionDone='clean',
387 workdir='llvm'))
388 f.addStep(ShellCommand(name='clean-2',
389 command=['rmdir','/s/q','build'],
Daniel Dunbar7e959c82009-09-28 04:01:19 +0000390 warnOnFailure=True,
Daniel Dunbar44abe742009-07-19 01:59:03 +0000391 description='cleaning',
392 descriptionDone='clean',
393 workdir='llvm'))
394
395 # Create the project files.
Daniel Dunbar7e959c82009-09-28 04:01:19 +0000396
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000397 # Use batch files instead of ShellCommand directly, Windows quoting is
398 # borked. FIXME: See buildbot ticket #595 and buildbot ticket #377.
399 f.addStep(BatchFileDownload(name='cmakegen',
Daniel Dunbar06b20f12010-04-08 18:29:38 +0000400 command=[cmake,
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000401 "-DLLVM_TARGETS_TO_BUILD:=X86",
Daniel Dunbar1ddedce2010-09-24 19:57:34 +0000402 "-DLLVM_INCLUDE_EXAMPLES:=OFF",
403 "-DLLVM_INCLUDE_TESTS:=OFF",
404 "-DLLVM_TARGETS_TO_BUILD:=X86",
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000405 "-G",
406 "Visual Studio 9 2008",
407 ".."],
408 workdir="llvm\\build"))
Daniel Dunbar44abe742009-07-19 01:59:03 +0000409 f.addStep(ShellCommand(name='cmake',
410 command=['cmakegen.bat'],
Daniel Dunbar7e959c82009-09-28 04:01:19 +0000411 haltOnFailure=True,
Daniel Dunbar44abe742009-07-19 01:59:03 +0000412 description='cmake gen',
413 workdir='llvm\\build'))
414
415 # Build it.
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000416 f.addStep(BatchFileDownload(name='vcbuild',
417 command=[vcDrive + r""":\Program Files\Microsoft Visual Studio 9.0\VC\VCPackages\vcbuild.exe""",
418 "/M%d" % jobs,
419 "LLVM.sln",
420 "Debug|Win32"],
421 workdir="llvm\\build"))
Daniel Dunbar44abe742009-07-19 01:59:03 +0000422 f.addStep(WarningCountingShellCommand(name='vcbuild',
423 command=['vcbuild.bat'],
Daniel Dunbar7e959c82009-09-28 04:01:19 +0000424 haltOnFailure=True,
Daniel Dunbar44abe742009-07-19 01:59:03 +0000425 description='vcbuild',
426 workdir='llvm\\build',
427 warningPattern=" warning C.*:"))
Daniel Dunbarb51f6ab2009-11-09 03:09:23 +0000428
429 # Build clang-test project.
430 f.addStep(BatchFileDownload(name='vcbuild_test',
431 command=[vcDrive + r""":\Program Files\Microsoft Visual Studio 9.0\VC\VCPackages\vcbuild.exe""",
432 "clang-test.vcproj",
433 "Debug|Win32"],
434 workdir="llvm\\build\\tools\\clang\\test"))
435 f.addStep(ClangTestCommand(name='test-clang',
436 command=["vcbuild_test.bat"],
437 workdir="llvm\\build\\tools\\clang\\test"))
438
Daniel Dunbar44abe742009-07-19 01:59:03 +0000439 return f
Daniel Dunbar22d594a2010-07-31 05:29:16 +0000440
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000441# Builds on Windows using CMake, MinGW(32|64), and no Microsoft tools.
Galina Kistanova5e97edf2012-06-19 20:10:21 +0000442def getClangMinGWBuildFactory(update=True, clean=True, jobs=6, cmake=r"cmake"):
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000443 f = buildbot.process.factory.BuildFactory()
444
445 if update:
446 f.addStep(SVN(name='svn-llvm',
447 mode='update', baseURL='http://llvm.org/svn/llvm-project/llvm/',
448 defaultBranch='trunk',
449 workdir='llvm'))
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000450 f.addStep(SVN(name='svn-clang',
451 mode='update', baseURL='http://llvm.org/svn/llvm-project/cfe/',
452 defaultBranch='trunk',
453 workdir='llvm/tools/clang'))
David Blaikie845ae0d2012-08-10 00:51:38 +0000454 f.addStep(SVN(name='svn-clang-tools-extra',
455 mode='update', baseURL='http://llvm.org/svn/llvm-project/clang-tools-extra/',
456 defaultBranch='trunk',
457 workdir='llvm/tools/clang/tools/extra'))
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000458
459 # Full & fast clean.
460 if clean:
461 # note: This command is redundant as the next command removes everything
462 f.addStep(ShellCommand(name='clean-1',
463 command=['del','/s/q','build'],
464 warnOnFailure=True,
465 description='cleaning',
466 descriptionDone='clean',
467 workdir='llvm'))
468 f.addStep(ShellCommand(name='clean-2',
469 command=['rmdir','/s/q','build'],
470 warnOnFailure=True,
471 description='cleaning',
472 descriptionDone='clean',
473 workdir='llvm'))
474
475 # Create the Makefiles.
476
477 # Use batch files instead of ShellCommand directly, Windows quoting is
478 # borked. FIXME: See buildbot ticket #595 and buildbot ticket #377.
479 f.addStep(BatchFileDownload(name='cmakegen',
480 command=[cmake,
481 "-DLLVM_TARGETS_TO_BUILD:=X86",
482 "-DLLVM_INCLUDE_EXAMPLES:=OFF",
483 "-DLLVM_INCLUDE_TESTS:=OFF",
484 "-DLLVM_TARGETS_TO_BUILD:=X86",
485 "-G",
Galina Kistanova5e97edf2012-06-19 20:10:21 +0000486 "Ninja",
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000487 ".."],
488 workdir="llvm\\build"))
489 f.addStep(ShellCommand(name='cmake',
490 command=['cmakegen.bat'],
491 haltOnFailure=True,
492 description='cmake gen',
493 workdir='llvm\\build'))
494
495 # Build it.
496 f.addStep(BatchFileDownload(name='makeall',
Galina Kistanova5e97edf2012-06-19 20:10:21 +0000497 command=["ninja", "-j", "%d" % jobs],
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000498 haltOnFailure=True,
499 workdir='llvm\\build'))
500
501 f.addStep(WarningCountingShellCommand(name='makeall',
502 command=['makeall.bat'],
503 haltOnFailure=True,
504 description='makeall',
505 workdir='llvm\\build'))
506
Galina Kistanova5e97edf2012-06-19 20:10:21 +0000507 # Build global check project (make check) (sources not checked out...).
508 if 0:
509 f.addStep(BatchFileDownload(name='makecheck',
510 command=["ninja", "check"],
511 workdir='llvm\\build'))
512 f.addStep(WarningCountingShellCommand(name='check',
513 command=['makecheck.bat'],
514 description='make check',
515 workdir='llvm\\build'))
Galina Kistanova049d76c2012-06-09 00:56:05 +0000516
517 # Build clang-test project (make clang-test).
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000518 f.addStep(BatchFileDownload(name='maketest',
Galina Kistanova5e97edf2012-06-19 20:10:21 +0000519 command=["ninja", "clang-test"],
Galina Kistanova049d76c2012-06-09 00:56:05 +0000520 workdir="llvm\\build"))
521 f.addStep(ClangTestCommand(name='clang-test',
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000522 command=["maketest.bat"],
Galina Kistanova049d76c2012-06-09 00:56:05 +0000523 workdir="llvm\\build"))
Galina Kistanova2a97a3b2012-06-06 20:50:33 +0000524
525 return f
526
Daniel Dunbar7363d032011-02-27 03:22:35 +0000527def addClangGCCTests(f, ignores={}, install_prefix="%(builddir)s/llvm.install",
528 languages = ('gcc', 'g++', 'objc', 'obj-c++')):
Daniel Dunbar22d594a2010-07-31 05:29:16 +0000529 make_vars = [WithProperties(
Daniel Dunbar2b67e8f2011-02-11 21:03:41 +0000530 'CC_UNDER_TEST=%s/bin/clang' % install_prefix),
Daniel Dunbar22d594a2010-07-31 05:29:16 +0000531 WithProperties(
Daniel Dunbar2b67e8f2011-02-11 21:03:41 +0000532 'CXX_UNDER_TEST=%s/bin/clang++' % install_prefix)]
Daniel Dunbar22d594a2010-07-31 05:29:16 +0000533 f.addStep(SVN(name='svn-clang-tests', mode='update',
534 baseURL='http://llvm.org/svn/llvm-project/clang-tests/',
535 defaultBranch='trunk', workdir='clang-tests'))
536 gcc_dg_ignores = ignores.get('gcc-4_2-testsuite', {})
Daniel Dunbar2b67e8f2011-02-11 21:03:41 +0000537 for lang in languages:
Daniel Dunbar22d594a2010-07-31 05:29:16 +0000538 f.addStep(DejaGNUCommand.DejaGNUCommand(
539 name='test-gcc-4_2-testsuite-%s' % lang,
540 command=["make", "-k", "check-%s" % lang] + make_vars,
541 description="gcc-4_2-testsuite (%s)" % lang,
542 workdir='clang-tests/gcc-4_2-testsuite',
David Dean2bd0c3a2011-10-18 16:36:28 +0000543 logfiles={ 'dg.sum' : 'obj/%s/%s.sum' % (lang, lang),
544 '%s.log' % lang : 'obj/%s/%s.log' % (lang, lang)},
Daniel Dunbar22d594a2010-07-31 05:29:16 +0000545 ignore=gcc_dg_ignores.get(lang, [])))
Daniel Dunbar2b67e8f2011-02-11 21:03:41 +0000546
Daniel Dunbar7363d032011-02-27 03:22:35 +0000547def addClangGDBTests(f, ignores={}, install_prefix="%(builddir)s/llvm.install"):
548 make_vars = [WithProperties(
549 'CC_UNDER_TEST=%s/bin/clang' % install_prefix),
550 WithProperties(
551 'CXX_UNDER_TEST=%s/bin/clang++' % install_prefix)]
552 f.addStep(SVN(name='svn-clang-tests', mode='update',
553 baseURL='http://llvm.org/svn/llvm-project/clang-tests/',
554 defaultBranch='trunk', workdir='clang-tests'))
Daniel Dunbar7363d032011-02-27 03:22:35 +0000555 f.addStep(DejaGNUCommand.DejaGNUCommand(
556 name='test-gdb-1472-testsuite',
557 command=["make", "-k", "check"] + make_vars,
558 description="gdb-1472-testsuite",
559 workdir='clang-tests/gdb-1472-testsuite',
David Blaikie7ec695f2012-10-09 22:17:09 +0000560 logfiles={ 'dg.sum' : 'obj/filtered.gdb.sum',
David Blaikie624f4392012-11-05 22:34:35 +0000561 'gdb.log' : 'obj/gdb.log' }))
Daniel Dunbar7363d032011-02-27 03:22:35 +0000562
David Blaikiedad03d52012-11-16 22:37:12 +0000563def addModernClangGDBTests(f, jobs, install_prefix):
564 make_vars = [WithProperties('RUNTESTFLAGS="CC_FOR_TARGET=%s/bin/clang CXX_FOR_TARGET=%s/bin/clang++"' % install_prefix),
565 "FORCE_PARALLEL=1"]
566 f.addStep(SVN(name='svn-clang-tests', mode='update',
567 svnurl='http://llvm.org/svn/llvm-project/clang-tests-external/trunk/gdb/7.5/gdb/testsuite',
568 workdir='clang-tests/src'))
569 f.addStep(Configure(command='../src/configure',
570 workdir='clang-tests/build'))
571 f.addStep(DejaGNUCommand.DejaGNUCommand(
572 name='gdb-75-check',
573 command=["make", "-k", WithProperties("-j%s" % jobs), "check"] + make_vars,
574 env={'PATH': ['/home/buildslave/gdb-install/bin', '${PATH}']},
575 workdir='clang-tests/build',
576 logfiles={'dg.sum':'dg.sum',
577 'gdb.log':'gdb.log'}))
578
579
580
Daniel Dunbar7363d032011-02-27 03:22:35 +0000581# FIXME: Deprecated.
582addClangTests = addClangGCCTests
583
Daniel Dunbar2b67e8f2011-02-11 21:03:41 +0000584def getClangTestsIgnoresFromPath(path, key):
585 def readList(path):
586 if not os.path.exists(path):
587 return []
588
589 f = open(path)
590 lines = [ln.strip() for ln in f]
591 f.close()
592 return lines
593
594 ignores = {}
595
596 gcc_dg_ignores = {}
597 for lang in ('gcc', 'g++', 'objc', 'obj-c++'):
598 lang_path = os.path.join(path, 'gcc-4_2-testsuite', 'expected_results',
599 key, lang)
600 gcc_dg_ignores[lang] = (
601 readList(os.path.join(lang_path, 'FAIL.txt')) +
602 readList(os.path.join(lang_path, 'UNRESOLVED.txt')) +
603 readList(os.path.join(lang_path, 'XPASS.txt')))
604 ignores['gcc-4_2-testsuite' ] = gcc_dg_ignores
605
Daniel Dunbar7363d032011-02-27 03:22:35 +0000606 ignores_path = os.path.join(path, 'gdb-1472-testsuite', 'expected_results',
607 key)
608 gdb_dg_ignores = (
609 readList(os.path.join(ignores_path, 'FAIL.txt')) +
610 readList(os.path.join(ignores_path, 'UNRESOLVED.txt')) +
611 readList(os.path.join(ignores_path, 'XPASS.txt')))
612 ignores['gdb-1472-testsuite' ] = gdb_dg_ignores
613
Daniel Dunbar2b67e8f2011-02-11 21:03:41 +0000614 return ignores