Commit | Line | Data |
b58ecb01 |
1 | #!/bin/bash |
2 | |
afeb40d2 |
3 | # this file is executed in a subshell - set up the common stuff |
4 | source maint/travis-ci_scripts/common.bash |
b58ecb01 |
5 | |
afeb40d2 |
6 | if [[ -n "$SHORT_CIRCUIT_SMOKE" ]] ; then exit 0 ; fi |
6d74b82c |
7 | |
27cb13e3 |
8 | # The prereq-install stage will not work with both POISON and DEVREL |
9 | # DEVREL wins |
10 | if [[ "$DEVREL_DEPS" = "true" ]] ; then |
11 | export POISON_ENV="" |
12 | fi |
13 | |
afeb40d2 |
14 | # FIXME - this is a kludge in place of proper MDV testing. For the time |
15 | # being simply use the minimum versions of our DBI/DBDstack, to avoid |
16 | # fuckups like 0.08260 (went unnoticed for 5 months) |
27cb13e3 |
17 | if [[ "$POISON_ENV" = "true" ]] ; then |
4f6eb3d8 |
18 | |
4f6eb3d8 |
19 | # use url-spec for DBI due to https://github.com/miyagawa/cpanminus/issues/328 |
e52712a8 |
20 | if [[ "$CLEANTEST" != "true" ]] || perl -M5.013003 -e1 &>/dev/null ; then |
21 | # the fulltest may re-upgrade DBI, be conservative only on cleantests |
4f6eb3d8 |
22 | # earlier DBI will not compile without PERL_POLLUTE which was gone in 5.14 |
23 | parallel_installdeps_notest T/TI/TIMB/DBI-1.614.tar.gz |
24 | else |
25 | parallel_installdeps_notest T/TI/TIMB/DBI-1.57.tar.gz |
26 | fi |
27 | |
28 | # Test both minimum DBD::SQLite and minimum BigInt SQLite |
e52712a8 |
29 | # reverse the logic from above for this (low on full, higher on clean) |
4f6eb3d8 |
30 | if [[ "$CLEANTEST" = "true" ]]; then |
31 | parallel_installdeps_notest DBD::SQLite@1.37 |
32 | else |
33 | parallel_installdeps_notest DBD::SQLite@1.29 |
34 | fi |
35 | |
e9d552de |
36 | # also try minimal tested installs *without* a compiler |
37 | if [[ "$CLEANTEST" = "true" ]]; then |
38 | |
39 | # Clone and P::S::XS are both bugs |
40 | # File::Spec can go away as soon as I dump Path::Class |
41 | # List::Util can be excised after that as well (need to make my own max() routine for older perls) |
42 | |
43 | installdeps Sub::Name Clone Package::Stash::XS \ |
44 | $( perl -MFile::Spec\ 3.26 -e1 &>/dev/null || echo "File::Spec" ) \ |
45 | $( perl -MList::Util\ 1.16 -e1 &>/dev/null || echo "List::Util" ) |
46 | |
47 | mkdir -p "$HOME/bin" # this is already in $PATH, just doesn't exist |
48 | run_or_err "Linking ~/bin/cc to /bin/false - thus essentially BREAKING the C compiler" \ |
49 | "ln -s /bin/false $HOME/bin/cc" |
50 | fi |
992a24f6 |
51 | fi |
52 | |
b58ecb01 |
53 | if [[ "$CLEANTEST" = "true" ]]; then |
54 | # get the last inc/ off cpan - we will get rid of MI |
55 | # soon enough, but till then this will do |
56 | # the point is to have a *really* clean perl (the ones |
57 | # we build are guaranteed to be clean, without side |
58 | # effects from travis preinstalls) |
59 | |
60 | # trick cpanm into executing true as shell - we just need the find+unpack |
6d74b82c |
61 | [[ -d ~/.cpanm/latest-build/DBIx-Class-*/inc ]] || run_or_err "Downloading latest stable DBIC inc/ from CPAN" \ |
b58ecb01 |
62 | "SHELL=/bin/true cpanm --look DBIx::Class" |
63 | |
64 | mv ~/.cpanm/latest-build/DBIx-Class-*/inc . |
65 | |
b58ecb01 |
66 | # The first CPAN which is somewhat sane is around 1.94_56 (perl 5.12) |
67 | # The problem is that the first sane version also brings a *lot* of |
68 | # deps with it, notably things like YAML and HTTP::Tiny |
69 | # The goal of CLEANTEST is to have as little extra stuff installed as |
70 | # possible, mainly to catch "but X is perl core" mistakes |
71 | # So instead we still use our stock (possibly old) CPAN, and add some |
72 | # handholding |
b58ecb01 |
73 | |
cb4b23e9 |
74 | if [[ "$DEVREL_DEPS" != "true" ]] && ! CPAN_is_sane ; then |
75 | # no configure_requires - we will need the usual suspects anyway |
a872a9d7 |
76 | # without pre-installing these in one pass things won't yet work |
90e09088 |
77 | installdeps Module::Build |
e6b373aa |
78 | fi |
79 | |
b58ecb01 |
80 | else |
81 | # we will be running all dbic tests - preinstall lots of stuff, run basic tests |
b58ecb01 |
82 | |
83 | # do the preinstall in several passes to minimize amount of cross-deps installing |
84 | # multiple times, and to avoid module re-architecture breaking another install |
91d48c58 |
85 | # (e.g. once Carp is upgraded there's no more Carp::Heavy, |
86 | # while a File::Path upgrade may cause a parallel EUMM run to fail) |
b58ecb01 |
87 | # |
91d48c58 |
88 | parallel_installdeps_notest File::Path |
b58ecb01 |
89 | parallel_installdeps_notest Carp |
e58d384f |
90 | parallel_installdeps_notest Module::Build |
90e09088 |
91 | parallel_installdeps_notest File::Spec Module::Runtime |
3fdb3624 |
92 | parallel_installdeps_notest Test::Exception Encode::Locale Test::Fatal |
e1ab2f7a |
93 | parallel_installdeps_notest Test::Warn B::Hooks::EndOfScope Test::Differences HTTP::Status |
f5616614 |
94 | parallel_installdeps_notest Test::Pod::Coverage Test::EOL Devel::GlobalDestruction Sub::Name MRO::Compat Class::XSAccessor URI::Escape HTML::Entities |
4841171c |
95 | parallel_installdeps_notest YAML LWP Class::Trigger DateTime::Format::Builder Class::Accessor::Grouped Package::Variant |
90e09088 |
96 | parallel_installdeps_notest SQL::Abstract Moose Module::Install@1.15 JSON SQL::Translator File::Which Class::DBI::Plugin |
b58ecb01 |
97 | |
e52712a8 |
98 | # the official version is very much outdated and does not compile on 5.14+ |
99 | # use this rather updated source tree (needs to go to PAUSE): |
100 | # https://github.com/pilcrow/perl-dbd-interbase |
2b580420 |
101 | if [[ -n "$DBICTEST_FIREBIRD_INTERBASE_DSN" ]] ; then |
8be58dca |
102 | parallel_installdeps_notest git://github.com/dbsrgits/perl-dbd-interbase.git |
b58ecb01 |
103 | fi |
104 | |
105 | fi |
106 | |
107 | # generate the makefile which will have different deps depending on |
108 | # the runmode and envvars set above |
109 | run_or_err "Configure on current branch" "perl Makefile.PL" |
110 | |
111 | # install (remaining) dependencies, sometimes with a gentle push |
112 | if [[ "$CLEANTEST" = "true" ]]; then |
5af54265 |
113 | |
b33e214d |
114 | # we are doing a devrel pass - try to upgrade *everything* (we will be using cpanm so safe-ish) |
115 | if [[ "$DEVREL_DEPS" == "true" ]] ; then |
116 | |
117 | HARD_DEPS="$(echo $(make listalldeps))" |
118 | |
119 | else |
120 | |
fe92f179 |
121 | HARD_DEPS="$(echo $(make listdeps | sort -R))" |
b33e214d |
122 | |
123 | ##### TEMPORARY WORKAROUNDS needed in case we will be using a fucked CPAN.pm |
124 | if ! CPAN_is_sane ; then |
125 | |
126 | # DBD::SQLite reasonably wants DBI at config time |
127 | perl -MDBI -e1 &>/dev/null || HARD_DEPS="DBI $HARD_DEPS" |
128 | |
f207111d |
129 | fi |
b33e214d |
130 | |
f207111d |
131 | ##### END TEMPORARY WORKAROUNDS |
b33e214d |
132 | fi |
4e338f1b |
133 | |
579472df |
134 | installdeps $HARD_DEPS |
b58ecb01 |
135 | |
f207111d |
136 | else |
5af54265 |
137 | |
bd15e62e |
138 | parallel_installdeps_notest "$(make listdeps)" |
5af54265 |
139 | |
b58ecb01 |
140 | fi |
141 | |
f207111d |
142 | echo_err "$(tstamp) Dependency installation finished" |
55c6fb91 |
143 | |
144 | run_or_err "Re-configure" "perl Makefile.PL" |
b58ecb01 |
145 | |
146 | # make sure we got everything we need |
147 | if [[ -n "$(make listdeps)" ]] ; then |
148 | echo_err "$(tstamp) Not all deps installed - something went wrong :(" |
149 | sleep 1 # without this the echo below confuses the console listener >.< |
579472df |
150 | CPAN_is_sane || echo_err -e "Outdated CPAN.pm used - full installdep log follows\n$INSTALLDEPS_OUT\n\nSearch for 'NOT OK' in the text above\n\nDeps still missing:" |
b58ecb01 |
151 | sleep 3 # without this the above echo confuses the console listener >.< |
152 | make listdeps |
153 | exit 1 |
154 | fi |
155 | |
4f6eb3d8 |
156 | # check that our MDV somewhat works |
157 | if [[ "$POISON_ENV" = "true" ]] && ( perl -MDBD::SQLite\ 1.38 -e1 || perl -MDBI\ 1.615 -e1 ) &>/dev/null ; then |
158 | echo_err "Something went wrong - higher versions of DBI and/or DBD::SQLite than we expected" |
159 | exit 1 |
160 | fi |
161 | |
162 | |
b58ecb01 |
163 | # announce what are we running |
164 | echo_err " |
165 | ===================== DEPENDENCY CONFIGURATION COMPLETE ===================== |
166 | $(tstamp) Configuration phase seems to have taken $(date -ud "@$SECONDS" '+%H:%M:%S') (@$SECONDS) |
167 | |
5c0b7a18 |
168 | $(ci_vm_state_text)" |