X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=.travis.yml;h=2f7a767ea94a4da8e7e8dafa576b02f9b633e747;hb=wip%2Finsert_select_take2;hp=db8fdfa23e7b44580955d5414dee95835084947f;hpb=c87d30a7fa385200b9129a92b446f45c4028def0;p=dbsrgits%2FDBIx-Class.git diff --git a/.travis.yml b/.travis.yml index db8fdfa..2f7a767 100644 --- a/.travis.yml +++ b/.travis.yml @@ -25,24 +25,20 @@ # * The way .travis.yml is fed to the command controller is idiotic - it # makes using multiline `bash -c` statements impossible. Therefore to # aid readability (our travis logic is rather complex), the bulk of -# functionality is moved to a script. More about the problem (and the +# functionality is moved to scripts. More about the problem (and the # WONTFIX "explanation") here: https://github.com/travis-ci/travis-ci/issues/497 # # -# Smoke only specific branches to a) not overload the queue and b) not -# overspam the notification channels +# Smoke all branches except for blocked* and wip/* # -# Furthermore if the branch is ^topic/ - the custom compiled smokes will -# not run at all, again in order to conserve queue resources -# -# Additionally bleadperl tests do not run on master (but do run on smoke/*) +# Additionally master does not smoke with bleadperl +# ( implemented in maint/travis-ci_scripts/10_before_install.bash ) # branches: - only: - - master - - /^smoke\// - - /^topic\// + except: + - /^wip\// + - /^blocked/ notifications: irc: @@ -60,12 +56,12 @@ notifications: # Temporary - if it proves to be too noisy, we'll shut it off #- dbix-class-devel@lists.scsys.co.uk on_success: change - on_failure: change + on_failure: always language: perl perl: - - "5.16" + - "5.18" env: - CLEANTEST=false @@ -73,72 +69,161 @@ env: matrix: include: - # minimum supported with threads + # this particular perl is quite widespread + - perl: 5.8.8_thr_mb + env: + - CLEANTEST=true + - BREWOPTS="-Duseithreads -Dusemorebits" + - BREWVER=5.8.8 + + # so is this one (test a sane CPAN.pm) + - perl: 5.12.4_thr_mb + env: + - CLEANTEST=true + - BREWOPTS="-Duseithreads -Dusemorebits" + - BREWVER=5.12.4 + + # this is the perl suse ships + - perl: 5.10.0_thr_dbg + env: + - CLEANTEST=true + - BREWOPTS="-DDEBUGGING -Duseithreads" + - BREWVER=5.10.0 + + # CLEANTEST of minimum supported + - perl: 5.8.3_nt_mb + env: + - CLEANTEST=true + - BREWOPTS="-Dusemorebits" + - BREWVER=5.8.3 + + # Full Test of minimum supported with threads - perl: 5.8.5_thr env: - CLEANTEST=false - BREWOPTS="-Duseithreads" - BREWVER=5.8.5 + - DBIC_TRACE_PROFILE=console - # minimum supported without threads + # Full Test of minimum supported without threads - perl: 5.8.3_nt env: - CLEANTEST=false - BREWOPTS="" - BREWVER=5.8.3 + - DBIC_TRACE_PROFILE=console_monochrome - # bleadperl - - perl: bleadperl_thr_mb + ### + # some permutations of tracing and envvar poisoning + + - perl: 5.18.1_thr_mb env: - CLEANTEST=false + - POISON_ENV=true + - DBIC_TRACE=1 + - DBIC_MULTICREATE_DEBUG=0 - BREWOPTS="-Duseithreads -Dusemorebits" - - BREWVER=blead + - BREWVER=5.18.1 - # check CLEANTEST of minimum supported - - perl: 5.8.3_nt_mb + - perl: 5.18 env: - - CLEANTEST=true - - BREWOPTS="-Dusemorebits" - - BREWVER=5.8.3 + - CLEANTEST=false + - POISON_ENV=true + - DBIC_TRACE_PROFILE=console - # this is the perl suse ships - - perl: 5.10.0_thr_dbg + - perl: 5.18 env: - CLEANTEST=true - - BREWOPTS="-DDEBUGGING -Duseithreads" - - BREWVER=5.10.0 + - POISON_ENV=true + - DBIC_TRACE=1 + - DBIC_TRACE_PROFILE=console - # this particular perl is quite widespread - - perl: 5.8.8_thr_mb + - perl: 5.18 env: - - CLEANTEST=true + - CLEANTEST=false + - POISON_ENV=true + - DBIC_TRACE=1 + - DBIC_TRACE_PROFILE=console_monochrome + - DBIC_MULTICREATE_DEBUG=0 + + ### + # Start of the allow_failures block + + # recentish stable with blead CPAN + - perl: devcpan_5.18.1_thr_mb + env: + - CLEANTEST=false - BREWOPTS="-Duseithreads -Dusemorebits" - - BREWVER=5.8.8 + - BREWVER=5.18.1 + - DEVREL_DEPS=true + + # bleadperl with stock CPAN + - perl: bleadperl_thr_mb + env: + - CLEANTEST=false + - BREWOPTS="-Duseithreads -Dusemorebits" + - BREWVER=blead + + # bleadperl with blead CPAN + - perl: devcpan_bleadperl_thr_mb + env: + - CLEANTEST=false + - BREWOPTS="-Duseithreads -Dusemorebits" + - BREWVER=blead + - DEVREL_DEPS=true + + + # which ones of the above can fail + allow_failures: + # these run with various dev snapshots - allowed to fail + - perl: devcpan_5.18.1_thr_mb + - perl: bleadperl_thr_mb + - perl: devcpan_bleadperl_thr_mb + + +# sourcing the files is *EXTREMELY* important - otherwise +# no envvars will survive + +# the entire run times out after 50 minutes, or after 5 minutes without +# console output before_install: - # Do not make this part of the env-matrix - # different boxes we run on have different amount of hw threads - # hence why we need to query - # result is 1.5 times the physical threads - - export NUMTHREADS=$(( ( $(cut -f 2 -d '-' /sys/devices/system/cpu/online) + 1 ) * 15 / 10 )) + # Sets global envvars, downloads/configures debs based on CLEANTEST + # Sets extra DBICTEST_* envvars + # + - source maint/travis-ci_scripts/10_before_install.bash install: # Build and switch to a custom perl if requested - # Set the environment based on CLEANTEST - # Preinstall/install deps + # Configure the perl env, preinstall some generic toolchain parts # - # sourcing the file is *EXTREMELY* important - otherwise - # no envvars will survive - - source maint/travis-ci_prepare_env + - source maint/travis-ci_scripts/20_install.bash -script: - - export HARNESS_TIMER=1 HARNESS_OPTIONS=c:j$NUMTHREADS +before_script: + # Preinstall/install deps based on envvars/CLEANTEST + # + - source maint/travis-ci_scripts/30_before_script.bash - # either a plain 'make test' OR a shuffled prove torture - # use the random order test plan unless CLEANTEST - # prepare_env may have short-circuited the test entirely - - test -n "$SHORT_CIRCUIT_SMOKE" || (test "$CLEANTEST" = "true" && make test || prove -lrswj$NUMTHREADS t xt) +script: + # Run actual tests + # + - source maint/travis-ci_scripts/40_script.bash after_success: - # check if we can assemble a dist properly given we have all deps - - test -n "$SHORT_CIRCUIT_SMOKE" || test "$CLEANTEST" = "true" || make dist + # Check if we can assemble a dist properly if not in CLEANTEST + # + - source maint/travis-ci_scripts/50_after_success.bash + +after_failure: + # No tasks yet + # + #- source maint/travis-ci_scripts/50_after_failure.bash + +after_script: + # No tasks yet + # + #- source maint/travis-ci_scripts/60_after_script.bash + + # if we do not unset this before we terminate the travis teardown will + # mark the entire job as failed + - set +e