Add import-time-skip support to OptDeps, switch most tests over to that
[dbsrgits/DBIx-Class.git] / xt / optional_deps.t
CommitLineData
c052f3dd 1my ($inc_before, $inc_after);
be68095d 2BEGIN {
c052f3dd 3 $inc_before = [ keys %INC ];
4 require DBIx::Class::Optional::Dependencies;
5 $inc_after = [ keys %INC ];
be68095d 6}
7
cb551b07 8use strict;
9use warnings;
10no warnings qw/once/;
11
c052f3dd 12use Test::More;
13use Test::Exception;
e3a7746c 14
15# load before we break require()
16use Scalar::Util();
17use MRO::Compat();
cb551b07 18use Carp 'confess';
05c0614b 19
c052f3dd 20ok ( (! grep { $_ =~ m|DBIx/Class| } @$inc_before ), 'Nothing DBIC related was loaded before inc-test')
21 unless $ENV{PERL5OPT}; # a defined PERL5OPT may inject extra deps crashing this test
3c3e76bd 22
23is_deeply (
24 [ sort @$inc_after],
cb551b07 25 [ sort (@$inc_before, qw( DBIx/Class/Optional/Dependencies.pm if.pm )) ],
3c3e76bd 26 'Nothing loaded other than DBIx::Class::OptDeps',
cb551b07 27) unless $ENV{RELEASE_TESTING};
3c3e76bd 28
31c31b8d 29
30# check the project-local groups for sanity
31lives_ok {
32 DBIx::Class::Optional::Dependencies->req_group_list
33} "The entire optdep list is well formed";
34
05c0614b 35is_deeply (
31c31b8d 36 [ keys %{ DBIx::Class::Optional::Dependencies->req_list_for ('deploy') } ],
05c0614b 37 [ 'SQL::Translator' ],
38 'Correct deploy() dependency list',
39);
40
31c31b8d 41# scope to break require()
d8799bab 42{
31c31b8d 43
44# make module loading impossible, regardless of actual libpath contents
cb551b07 45 local @INC = (sub { confess('Optional Dep Test') } );
d8799bab 46
31c31b8d 47# basic test using the deploy target
48 for ('deploy', ['deploy']) {
49
50 # explicitly blow up cache
51 %DBIx::Class::Optional::Dependencies::req_unavailability_cache = ();
52
53 ok (
54 ! DBIx::Class::Optional::Dependencies->req_ok_for ($_),
55 'deploy() deps missing',
56 );
57
58 like (
e3a7746c 59 DBIx::Class::Optional::Dependencies->modreq_missing_for ($_),
60 qr/
61 \A
62 " SQL::Translator \~ \>\= [\d\.]+ "
63 \z
64 /x,
65 'expected modreq missing string contents',
66 );
67
68 like (
31c31b8d 69 DBIx::Class::Optional::Dependencies->req_missing_for ($_),
70 qr/
e3a7746c 71 \A
31c31b8d 72 " SQL::Translator \~ \>\= [\d\.]+ "
e3a7746c 73 \Q (see DBIx::Class::Optional::Dependencies documentation for details)\E
31c31b8d 74 \z
75 /x,
76 'expected missing string contents',
77 );
78
79 like (
5ffa39c7 80 DBIx::Class::Optional::Dependencies->modreq_errorlist_for ($_)->{'SQL::Translator'},
31c31b8d 81 qr/Optional Dep Test/,
82 'custom exception found in errorlist',
83 );
84
85 #make it so module appears loaded
86 local $INC{'SQL/Translator.pm'} = 1;
87 local $SQL::Translator::VERSION = 999;
88
89 ok (
90 ! DBIx::Class::Optional::Dependencies->req_ok_for ($_),
91 'deploy() deps missing cached properly from previous run',
92 );
93
94 # blow cache again
95 %DBIx::Class::Optional::Dependencies::req_unavailability_cache = ();
96
97 ok (
98 DBIx::Class::Optional::Dependencies->req_ok_for ($_),
99 'deploy() deps present',
100 );
101
102 is (
103 DBIx::Class::Optional::Dependencies->req_missing_for ($_),
104 '',
105 'expected null missing string',
106 );
107
108 is_deeply (
5ffa39c7 109 # use the deprecated method name
31c31b8d 110 DBIx::Class::Optional::Dependencies->req_errorlist_for ($_),
111 undef,
112 'expected empty errorlist',
113 );
114 }
115
e3a7746c 116# test single-db text
117 local $ENV{DBICTEST_MYSQL_DSN};
118 is_deeply(
119 DBIx::Class::Optional::Dependencies->req_list_for('test_rdbms_mysql'),
120 undef,
121 'unknown optional dependencies list for testing MySQL without ENV var',
122 );
31c31b8d 123 is_deeply(
e3a7746c 124 DBIx::Class::Optional::Dependencies->modreq_list_for('test_rdbms_mysql'),
125 { 'DBD::mysql' => 0 },
126 'correct optional module dependencies list for testing MySQL without ENV var',
127 );
128
129 local $ENV{DBICTEST_MYSQL_DSN};
130 local $ENV{DBICTEST_PG_DSN};
131
132 is_deeply(
133 DBIx::Class::Optional::Dependencies->modreq_list_for('test_rdbms_pg'),
134 { 'DBD::Pg' => '2.009002' },
135 'optional dependencies list for testing Postgres without envvar',
136 );
137
138 is_deeply(
139 DBIx::Class::Optional::Dependencies->req_list_for('test_rdbms_pg'),
140 undef,
141 'optional dependencies list for testing Postgres without envvar',
d8799bab 142 );
143
31c31b8d 144 is_deeply(
145 DBIx::Class::Optional::Dependencies->req_list_for('rdbms_pg'),
146 { 'DBD::Pg' => '0', },
147 'optional dependencies list for using Postgres matches',
d8799bab 148 );
149
e3a7746c 150# test combination of different requirements on same module (pg's are relatively stable)
31c31b8d 151 is_deeply (
152 DBIx::Class::Optional::Dependencies->req_list_for([qw( rdbms_pg test_rdbms_pg )]),
e3a7746c 153 { 'DBD::Pg' => '0' },
154 'optional module dependencies list for testing Postgres matches without envvar',
155 );
156
157 is(
158 DBIx::Class::Optional::Dependencies->req_missing_for([qw( rdbms_pg test_rdbms_pg )]),
159 '"DBD::Pg~>=2.009002" as well as the following group(s) of environment variables: DBICTEST_PG_DSN/..._USER/..._PASS',
160 'optional dependencies for testing Postgres without envvar'
161 );
162
163 is(
164 DBIx::Class::Optional::Dependencies->req_missing_for([qw( test_rdbms_mysql test_rdbms_pg )]),
165 'DBD::mysql "DBD::Pg~>=2.009002" as well as the following group(s) of environment variables: DBICTEST_MYSQL_DSN/..._USER/..._PASS and DBICTEST_PG_DSN/..._USER/..._PASS',
166 'optional dependencies for testing Postgres+MySQL without envvars'
167 );
168
169 $ENV{DBICTEST_PG_DSN} = 'boo';
170 is_deeply (
171 DBIx::Class::Optional::Dependencies->modreq_list_for([qw( rdbms_pg test_rdbms_pg )]),
31c31b8d 172 { 'DBD::Pg' => '2.009002' },
e3a7746c 173 'optional module dependencies list for testing Postgres matches with envvar',
d8799bab 174 );
05c0614b 175
31c31b8d 176 is(
177 DBIx::Class::Optional::Dependencies->req_missing_for([qw( rdbms_pg test_rdbms_pg )]),
178 '"DBD::Pg~>=2.009002"',
e3a7746c 179 'optional dependencies error text for testing Postgres matches with evvar',
31c31b8d 180 );
05c0614b 181
31c31b8d 182}
05c0614b 183
be68095d 184# test multiple times to find autovivification bugs
e3a7746c 185for my $meth (qw(req_list_for modreq_list_for)) {
be68095d 186 throws_ok {
e3a7746c 187 DBIx::Class::Optional::Dependencies->$meth();
be68095d 188 } qr/\Qreq_list_for() expects a requirement group name/,
e3a7746c 189 "$meth without groupname throws exception";
be68095d 190
191 throws_ok {
e3a7746c 192 DBIx::Class::Optional::Dependencies->$meth('');
193 } qr/\Q$meth() expects a requirement group name/,
194 "$meth with empty groupname throws exception";
be68095d 195
196 throws_ok {
e3a7746c 197 DBIx::Class::Optional::Dependencies->$meth('invalid_groupname');
31c31b8d 198 } qr/Requirement group 'invalid_groupname' is not defined/,
e3a7746c 199 "$meth with invalid groupname throws exception";
be68095d 200}
201
05c0614b 202done_testing;