Fix test failure on 5.8.x with DBIC_TRACE=1 (introduced by 68b8ba54)
[dbsrgits/DBIx-Class.git] / .travis.yml
1 # Some overall notes on how this works
2 #
3 # * We smoke using the system provided latest, and custom built "oddball perls"
4 # The reason for not having a blanket matrix is to conserve travis resources
5 # as a full DBIC depchain isn't cheap
6 #
7 # * Minimum perl officially supported by DBIC is 5.8.3. This *includes* the
8 # basic depchain. On failure either attempt to fix it or bring it to the
9 # attention of ribasushi. *DO NOT* disable 5.8 testing - it is here for a
10 # reason
11 #
12 # * The matrix is built from two main modes - CLEANTEST = [true|false].
13 # - In the first case we test with minimal deps available, and skip everything
14 #   listed in DBIC::OptDesps. The modules are installed with classic CPAN
15 #   invocations and are *fully tested*. In other words we simulate what would
16 #   happen if a user tried to install on a just-compiled virgin perl
17 # - Without CLEANTEST we bring the armada of RDBMS and install the maximum
18 #   possible set of deps *without testing them*. This ensures we stay within
19 #   a reasonable build-time and still run as many of our tests as possible
20 #
21 # * The perl builds and the DBIC tests run under VCPU_USE number of threads.
22 # The testing of dependencies under CLEANTEST runs single-threaded, at least
23 # until we fix our entire dep-chain to safely pass under -j
24 #
25 # * The way .travis.yml is fed to the command controller is idiotic - it
26 # makes using multiline `bash -c` statements impossible. Therefore to
27 # aid readability (our travis logic is rather complex), the bulk of
28 # functionality is moved to scripts. More about the problem (and the
29 # WONTFIX "explanation") here: https://github.com/travis-ci/travis-ci/issues/497
30 #
31 # the entire run times out after 50 minutes, or after 5 minutes without
32 # console output
33
34 #
35 # Smoke all branches except for blocked* and wip/*
36 #
37 # Additionally master does not smoke with bleadperl
38 # ( implemented in maint/travis-ci_scripts/10_before_install.bash )
39 #
40 branches:
41   except:
42     - /^wip\//
43     - /^blocked/
44
45 notifications:
46   irc:
47     channels:
48       - "irc.perl.org#dbic-smoke"
49     template:
50       - "%{branch}#%{build_number} by %{author}: %{message} (%{build_url})"
51     on_success: change
52     on_failure: always
53     use_notice: true
54
55   email:
56     recipients:
57       - ribasushi@cpan.org
58       # Temporary - if it proves to be too noisy, we'll shut it off
59       #- dbix-class-devel@lists.scsys.co.uk
60     on_success: change
61     on_failure: always
62
63 # FIXME - This stuff is not yet available for free OSS accounts, sadpanda
64 # First paragrah on http://about.travis-ci.org/docs/user/caching/
65 #cache:
66 #  apt: true
67 #  directories:
68 #    - /var/cache/apt/archives
69
70 language: perl
71
72 perl:
73   - "5.8"
74   - "5.20-extras"
75
76 env:
77   - CLEANTEST=false
78   - CLEANTEST=true VCPU_USE=1
79
80 sudo: true
81
82 matrix:
83   fast_finish: true
84   include:
85     # CLEANTEST of minimum supported with non-tracing poisoning
86     - perl: 5.8.3_nt_mb
87       env:
88         - CLEANTEST=true
89         - POISON_ENV=true
90         - DBIC_TRACE_PROFILE=console_monochrome
91         - BREWVER=5.8.3
92         - BREWOPTS="-Dusemorebits"
93
94     # Full Test of minimum supported without threads with plain poisoned trace
95     - perl: 5.8.3_nt
96       env:
97         - CLEANTEST=false
98         - POISON_ENV=true
99         - DBIC_TRACE=1
100         - BREWVER=5.8.3
101
102     # Full Test of minimum supported with threads with non-tracing poisoning
103     - perl: 5.8.5_thr
104       env:
105         - CLEANTEST=false
106         - POISON_ENV=true
107         - DBIC_TRACE_PROFILE=console
108         - BREWVER=5.8.5
109         - BREWOPTS="-Duseithreads"
110
111     # CLEANTEST of solaris-like perl with non-tracing poisoning
112     - perl: 5.8.4_nt
113       env:
114         - CLEANTEST=true
115         - POISON_ENV=true
116         - DBIC_TRACE_PROFILE=console
117         - BREWVER=5.8.4
118
119     # CLEANTEST: this particular perl is quite widespread
120     - perl: 5.8.8_thr
121       env:
122         - CLEANTEST=true
123         - BREWVER=5.8.8
124         - BREWOPTS="-Duseithreads"
125
126     # CLEANTEST: this is the perl suse ships, with env poisoning
127     - perl: 5.10.0_thr_dbg
128       env:
129         - CLEANTEST=true
130         - POISON_ENV=true
131         - BREWVER=5.10.0
132         - BREWOPTS="-DDEBUGGING -Duseithreads"
133
134     # CLEANTEST: this one is in a number of debian-based LTS (test a sane CPAN.pm)
135     - perl: 5.14.2_thr_mb
136       env:
137         - CLEANTEST=true
138         - BREWVER=5.14.2
139         - BREWOPTS="-Duseithreads -Dusemorebits"
140
141     ###
142     # some permutations of tracing and envvar poisoning
143
144     - perl: 5.12.3_thr
145       env:
146         - CLEANTEST=true
147         - POISON_ENV=true
148         - DBIC_TRACE=1
149         - DBIC_MULTICREATE_DEBUG=1
150         - DBIC_STORAGE_RETRY_DEBUG=1
151         - DBIC_TRACE_PROFILE=console
152         - BREWVER=5.12.3
153         - BREWOPTS="-Duseithreads"
154
155     - perl: 5.16.3_thr_mb
156       env:
157         - CLEANTEST=false
158         - POISON_ENV=true
159         - DBIC_TRACE=1
160         - BREWVER=5.16.3
161         - BREWOPTS="-Duseithreads -Dusemorebits"
162
163     - perl: 5.18-extras
164       env:
165         - CLEANTEST=false
166         - POISON_ENV=true
167         - DBIC_TRACE=1
168         - DBIC_TRACE_PROFILE=console_monochrome
169         - DBICTEST_VIA_REPLICATED=0
170
171     ###
172     # Start of the allow_failures block
173
174     # threaded oldest possible with blead CPAN
175     - perl: devcpan_5.8.1_thr_mb
176       env:
177         - CLEANTEST=true
178         - DEVREL_DEPS=true
179         - BREWVER=5.8.1
180         - BREWOPTS="-Duseithreads -Dusemorebits"
181
182     # oldest possible with blead CPAN with poisoning and plain trace
183     - perl: devcpan_5.8.1
184       env:
185         - CLEANTEST=true
186         - DEVREL_DEPS=true
187         - POISON_ENV=true
188         - DBIC_TRACE=1
189         - BREWVER=5.8.1
190
191     # 5.8.3 with blead CPAN
192     - perl: devcpan_5.8.3_mb
193       env:
194         - CLEANTEST=false
195         - DEVREL_DEPS=true
196         - BREWVER=5.8.3
197         - BREWOPTS="-Dusemorebits"
198
199     # 5.8.7 threaded with blead CPAN with non-tracing poisoning
200     - perl: devcpan_5.8.7_thr
201       env:
202         - CLEANTEST=true
203         - DEVREL_DEPS=true
204         - POISON_ENV=true
205         - BREWVER=5.8.7
206         - BREWOPTS="-Duseithreads"
207
208     # 5.8.8 threaded MB (exercises P5#72210)
209     - perl: devcpan_5.8.8_thr_mb
210       env:
211         - CLEANTEST=true
212         - DEVREL_DEPS=true
213         - BREWVER=5.8.8
214         - BREWOPTS="-Duseithreads -Dusemorebits"
215
216     # 5.10.0 threaded with blead CPAN
217     - perl: devcpan_5.10.0_thr_mb
218       env:
219         - CLEANTEST=true
220         - DEVREL_DEPS=true
221         - BREWVER=5.10.0
222         - BREWOPTS="-Duseithreads -Dusemorebits"
223
224     # 5.12.1 with blead CPAN
225     - perl: devcpan_5.12.1_thr
226       env:
227         - CLEANTEST=true
228         - DEVREL_DEPS=true
229         - BREWVER=5.12.1
230         - BREWOPTS="-Duseithreads"
231
232     # bleadperl with stock CPAN, full depchain test with non-tracing poisoning
233     - perl: bleadperl
234       env:
235         - CLEANTEST=true
236         - POISON_ENV=true
237         - BREWVER=blead
238
239     # bleadperl with blead CPAN
240     - perl: devcpan_bleadperl_thr_mb
241       env:
242         - CLEANTEST=false
243         - DEVREL_DEPS=true
244         - BREWVER=blead
245         - BREWOPTS="-Duseithreads -Dusemorebits"
246
247     # CLEANTEST of http://schplog.schmorp.de/2015-06-06-a-stable-perl.html with non-tracing poisoning
248     - perl: schmorp_stableperl_thr_mb
249       env:
250         - CLEANTEST=true
251         - POISON_ENV=true
252         - BREWVER=schmorp_stableperl
253         - BREWOPTS="-Duseithreads -Dusemorebits"
254
255   # which ones of the above can fail
256   allow_failures:
257
258     # these run with various dev snapshots - allowed to fail
259     - perl: devcpan_5.8.1_thr_mb
260     - perl: devcpan_5.8.1
261     - perl: devcpan_5.8.3_mb
262     - perl: devcpan_5.8.7_thr
263     - perl: devcpan_5.8.8_thr_mb
264     - perl: devcpan_5.10.0_thr_mb
265     - perl: devcpan_5.12.1_thr
266     - perl: bleadperl
267     - perl: devcpan_bleadperl_thr_mb
268     - perl: schmorp_stableperl_thr_mb
269
270
271 ###
272 ### For the following two phases -e is *set*
273 ###
274
275 before_install:
276   # common functions for all run phases below
277   #
278   # this is an exporter - sourcing it is crucial
279   # among other things it also sets -e
280   #
281   - source maint/travis-ci_scripts/common.bash
282
283   # Sets global envvars, downloads/configures debs based on CLEANTEST
284   # Sets extra DBICTEST_* envvars
285   #
286   # this is an exporter - sourcing it is crucial
287   #
288   - source maint/travis-ci_scripts/10_before_install.bash
289
290 install:
291   # Build and switch to a custom perl if requested
292   # Configure the perl env, preinstall some generic toolchain parts
293   # Possibly poison the environment
294   #
295   # this is an exporter - sourcing it is crucial
296   #
297   - source maint/travis-ci_scripts/20_install.bash
298
299 ###
300 ### From this point on -e is *unset*, rely on travis' error handling
301 ###
302   - set +e
303
304 before_script:
305   # Preinstall/install deps based on envvars/CLEANTEST
306   #
307   # need to invoke the after_failure script manually
308   # because 'after_failure' runs only after 'script' fails
309   #
310   - maint/getstatus maint/travis-ci_scripts/30_before_script.bash || ( maint/travis-ci_scripts/50_after_failure.bash && /bin/false )
311
312 script:
313   # Run actual tests
314   #
315   - maint/getstatus maint/travis-ci_scripts/40_script.bash
316
317 ###
318 ### Set -e back, work around https://github.com/travis-ci/travis-ci/issues/3533
319 ###
320   - set -e
321
322 after_success:
323   # Check if we can assemble a dist properly if not in CLEANTEST
324   #
325   - maint/getstatus maint/travis-ci_scripts/50_after_success.bash
326
327 after_failure:
328   # Final sysinfo printout on fail
329   #
330   - maint/getstatus maint/travis-ci_scripts/50_after_failure.bash
331
332 after_script:
333   # No tasks yet
334   #
335   #- maint/getstatus maint/travis-ci_scripts/60_after_script.bash