allow constraint/exclude options together
[dbsrgits/DBIx-Class-Schema-Loader.git] / lib / DBIx / Class / Schema / Loader / Utils.pm
CommitLineData
cc4f11a2 1package # hide from PAUSE
2 DBIx::Class::Schema::Loader::Utils;
3
4use strict;
5use warnings;
61cd4bfc 6use Data::Dumper ();
1ad8e8c3 7use Test::More;
fcf328c7 8use File::Slurp 'read_file';
1ad8e8c3 9use namespace::clean;
cc4f11a2 10use Exporter 'import';
11
fcf328c7 12our @EXPORT_OK = qw/split_name dumper dumper_squashed eval_package_without_redefine_warnings class_path no_warnings warnings_exist warnings_exist_silent slurp_file/;
cc4f11a2 13
14use constant BY_CASE_TRANSITION =>
15 qr/(?<=[[:lower:]\d])[\W_]*(?=[[:upper:]])|[\W_]+/;
16
17use constant BY_NON_ALPHANUM =>
18 qr/[\W_]+/;
19
fcf328c7 20my $LF = "\x0a";
21my $CRLF = "\x0d\x0a";
22
cc4f11a2 23sub split_name($) {
24 my $name = shift;
25
26 split $name =~ /[[:upper:]]/ && $name =~ /[[:lower:]]/ ? BY_CASE_TRANSITION : BY_NON_ALPHANUM, $name;
27}
28
15efd63a 29sub dumper($) {
30 my $val = shift;
31
32 my $dd = Data::Dumper->new([]);
33 $dd->Terse(1)->Indent(1)->Useqq(1)->Deparse(1)->Quotekeys(0)->Sortkeys(1);
34 return $dd->Values([ $val ])->Dump;
35}
36
37sub dumper_squashed($) {
38 my $val = shift;
39
40 my $dd = Data::Dumper->new([]);
41 $dd->Terse(1)->Indent(1)->Useqq(1)->Deparse(1)->Quotekeys(0)->Sortkeys(1)->Indent(0);
42 return $dd->Values([ $val ])->Dump;
43}
44
0f21885a 45sub eval_package_without_redefine_warnings {
46 my ($pkg, $code) = @_;
c38ec663 47
48 my $warn_handler = $SIG{__WARN__} || sub { warn @_ };
0f21885a 49
c38ec663 50 local $SIG{__WARN__} = sub {
51 $warn_handler->(@_)
52 unless $_[0] =~ /^Subroutine \S+ redefined/;
53 };
0f21885a 54
55 # This hairiness is to handle people using "use warnings FATAL => 'all';"
56 # in their custom or external content.
57 my @delete_syms;
58 my $try_again = 1;
59
60 while ($try_again) {
61 eval $code;
62
63 if (my ($sym) = $@ =~ /^Subroutine (\S+) redefined/) {
64 delete $INC{ +class_path($pkg) };
65 push @delete_syms, $sym;
66
67 foreach my $sym (@delete_syms) {
68 no strict 'refs';
69 undef *{"${pkg}::${sym}"};
70 }
71 }
72 elsif ($@) {
73 die $@ if $@;
74 }
75 else {
76 $try_again = 0;
77 }
78 }
79}
80
81sub class_path {
82 my $class = shift;
83
84 my $class_path = $class;
85 $class_path =~ s{::}{/}g;
86 $class_path .= '.pm';
87
88 return $class_path;
c38ec663 89}
90
12b86f07 91sub no_warnings(&;$) {
92 my ($code, $test_name) = @_;
93
94 my $failed = 0;
95
96 my $warn_handler = $SIG{__WARN__} || sub { warn @_ };
97 local $SIG{__WARN__} = sub {
98 $failed = 1;
99 $warn_handler->(@_);
100 };
101
102 $code->();
103
104 ok ((not $failed), $test_name);
105}
106
1ad8e8c3 107sub warnings_exist(&$$) {
108 my ($code, $re, $test_name) = @_;
109
110 my $matched = 0;
111
112 my $warn_handler = $SIG{__WARN__} || sub { warn @_ };
113 local $SIG{__WARN__} = sub {
114 if ($_[0] =~ $re) {
115 $matched = 1;
116 }
117 else {
118 $warn_handler->(@_)
119 }
120 };
121
122 $code->();
123
124 ok $matched, $test_name;
125}
126
127sub warnings_exist_silent(&$$) {
128 my ($code, $re, $test_name) = @_;
129
130 my $matched = 0;
131
132 local $SIG{__WARN__} = sub { $matched = 1 if $_[0] =~ $re; };
133
134 $code->();
135
136 ok $matched, $test_name;
137}
138
fcf328c7 139sub slurp_file($) {
140 my $data = read_file(shift, binmode => ':encoding(UTF-8)');
141
142 $data =~ s/$CRLF|$LF/\n/g;
143
144 return $data;
145}
1ad8e8c3 146
cc4f11a2 1471;
148# vim:et sts=4 sw=4 tw=0: