X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=rt%2Fsbin%2Frt-test-dependencies.in;h=35d1db38fa7623261fe825465a2927c70dddf315;hp=ce1f441501f9efa1ec122117491ac5115c388b53;hb=ef20b2b6b1feb47ad02b5ff7525f1a0fd11d0fa4;hpb=a513c0bef534d05f03c1242831b6f3be19b97dae diff --git a/rt/sbin/rt-test-dependencies.in b/rt/sbin/rt-test-dependencies.in index ce1f44150..35d1db38f 100644 --- a/rt/sbin/rt-test-dependencies.in +++ b/rt/sbin/rt-test-dependencies.in @@ -3,7 +3,7 @@ # # COPYRIGHT: # -# This software is Copyright (c) 1996-2005 Best Practical Solutions, LLC +# This software is Copyright (c) 1996-2007 Best Practical Solutions, LLC # # # (Except where explicitly superseded by other copyright notices) @@ -23,7 +23,9 @@ # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software -# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA +# 02110-1301 or visit their web page on the internet at +# http://www.gnu.org/copyleft/gpl.html. # # # CONTRIBUTION SUBMISSION POLICY: @@ -61,6 +63,7 @@ GetOptions( 'with-ORACLE', 'with-FASTCGI', 'with-SPEEDYCGI', 'with-MODPERL1', 'with-MODPERL2', 'with-DEV', + 'with-STANDALONE', 'download=s', 'repository=s' ); @@ -69,13 +72,20 @@ unless (keys %args) { help(); exit(0); } - # Set up defaults -$args{'with-MASON'} = 1; -$args{'with-CORE'} = 1; -$args{'with-DEV'} =1; -$args{'with-CLI'} =1; -$args{'with-MAILGATE'} =1; +my %default = ( + 'with-MASON' => 1, + 'with-CORE' => 1, + 'with-CLI' => 1, + 'with-MAILGATE' => 1, + 'with-DEV' => @RT_DEVEL_MODE@, + 'with-STANDALONE' => @RT_STANDALONE@, +); +$args{$_} = $default{$_} foreach grep !exists $args{$_}, keys %default; + +use Data::Dumper; +print Dumper( \%args ); + { my $section; my %always_show_sections = ( @@ -130,6 +140,7 @@ The following switches will tell the tool to check for specific dependencies --with-sqlite Database interface and driver for SQLite (unsupported) --with-oracle Database interface for oracle (unsupported) + --with-standalone Libraries needed to support the standalone simple pure perl server --with-fastcgi Libraries needed to support the fastcgi handler --with-speedycgi Libraries needed to support the speedycgi handler --with-modperl1 Libraries needed to support the modperl 1 handler @@ -139,26 +150,38 @@ The following switches will tell the tool to check for specific dependencies You can also specify -v or --verbose to list the status of all dependencies, rather than just the missing ones. + +The "RT_FIX_DEPS_CMD" environment variable, if set, will be used +instead of the standard CPAN shell by --install to install any +required modules. It will be called with the module name, or, if +"RT_FIX_DEPS_CMD" contains a "%s", will replace the "%s" with the +module name before calling the program. . } -sub _ { - map { /(\S+)\s*(\S*)/; $1 => ($2 ? $2 :'') } split ( /\n/, $_[0] ); +sub text_to_hash { + my %hash; + for my $line ( split /\n/, $_[0] ) { + my($key, $value) = $line =~ /(\S+)\s*(\S*)/; + $value ||= ''; + $hash{$key} = $value; + } + + return %hash; } -$deps{'CORE'} = [ _( << '.') ]; +$deps{'CORE'} = [ text_to_hash( << '.') ]; Digest::base Digest::MD5 2.27 DBI 1.37 -Test::Inline Class::ReturnValue 0.40 -DBIx::SearchBuilder 1.35 +Date::Format +DBIx::SearchBuilder 1.48 Text::Template File::Spec 0.8 HTML::Entities HTML::Scrubber 0.08 -Net::Domain Log::Dispatch 2.0 Locale::Maketext 1.06 Locale::Maketext::Lexicon 0.32 @@ -170,92 +193,102 @@ Text::Wrapper Time::ParseDate Time::HiRes File::Temp -Term::ReadKey Text::Autoformat -Text::Quoted 1.3 +Text::Quoted 2.02 Tree::Simple 1.04 +Regexp::Common Scalar::Util -Module::Versions::Report +Module::Versions::Report 1.03 Cache::Simple::TimedExpiry -XML::Simple +UNIVERSAL::require +Calendar::Simple . -$deps{'MASON'} = [ _( << '.') ]; -Params::Validate 0.02 -Cache::Cache -Exception::Class 1.14 +$deps{'MASON'} = [ text_to_hash( << '.') ]; HTML::Mason 1.23 -MLDBM Errno -FreezeThaw Digest::MD5 2.27 CGI::Cookie 1.20 Storable 2.08 Apache::Session 1.53 XML::RSS 1.05 +GD +GD::Graph +GD::Text +Text::WikiFormat 0.76 +. + +$deps{'STANDALONE'} = [ text_to_hash( << '.') ]; HTTP::Server::Simple 0.07 HTTP::Server::Simple::Mason 0.09 -Text::WikiFormat . -$deps{'MAILGATE'} = [ _( << '.') ]; +$deps{'MAILGATE'} = [ text_to_hash( << '.') ]; HTML::TreeBuilder HTML::FormatText Getopt::Long LWP::UserAgent +Pod::Usage . -$deps{'CLI'} = [ _( << '.') ]; +$deps{'CLI'} = [ text_to_hash( << '.') ]; Getopt::Long 2.24 +LWP +HTTP::Request::Common +Text::ParseWords +Term::ReadLine +Term::ReadKey . -$deps{'DEV'} = [ _( << '.') ]; -Regexp::Common +$deps{'DEV'} = [ text_to_hash( << '.') ]; Test::Inline Apache::Test HTML::Form HTML::TokeParser WWW::Mechanize -Test::WWW::Mechanize +Test::WWW::Mechanize 1.04 Module::Refresh 0.03 +Test::Expect 0.30 +XML::Simple +File::Find . -$deps{'FASTCGI'} = [ _( << '.') ]; +$deps{'FASTCGI'} = [ text_to_hash( << '.') ]; CGI 2.92 FCGI CGI::Fast . -$deps{'SPEEDYCGI'} = [ _( << '.') ]; +$deps{'SPEEDYCGI'} = [ text_to_hash( << '.') ]; CGI 2.92 CGI::SpeedyCGI . -$deps{'MODPERL1'} = [ _( << '.') ]; +$deps{'MODPERL1'} = [ text_to_hash( << '.') ]; CGI 2.92 Apache::Request Apache::DBI 0.92 . -$deps{'MODPERL2'} = [ _( << '.') ]; +$deps{'MODPERL2'} = [ text_to_hash( << '.') ]; CGI 2.92 Apache::DBI HTML::Mason 1.31 . -$deps{'MYSQL'} = [ _( << '.') ]; +$deps{'MYSQL'} = [ text_to_hash( << '.') ]; DBD::mysql 2.1018 . -$deps{'ORACLE'} = [ _( << '.') ]; +$deps{'ORACLE'} = [ text_to_hash( << '.') ]; DBD::Oracle . -$deps{'POSTGRESQL'} = [ _( << '.') ]; -DBD::Pg 1.41 +$deps{'POSTGRESQL'} = [ text_to_hash( << '.') ]; +DBD::Pg 1.43 . -$deps{'SQLITE'} = [ _( << '.') ]; -DBD::SQLite +$deps{'SQLITE'} = [ text_to_hash( << '.') ]; +DBD::SQLite 1.00 . if ($args{'download'}) { @@ -269,18 +302,24 @@ check_perl_version(); check_users(); -foreach my $type (keys %args) { +foreach my $type (sort grep $args{$_}, keys %args) { next unless ($type =~ /^with-(.*?)$/); - my $type = $1; + + $type = $1; section("$type dependencies"); - my @deps = (@{$deps{$type}}); + + my @missing; + my @deps = @{ $deps{$type} }; while (@deps) { my $module = shift @deps; my $version = shift @deps; - my $ret = test_dep($module, $version); + my $ret = test_dep($module, $version); - if ($args{'install'} && !$ret) { - resolve_dep($module); + push @missing, $module, $version unless $ret; + } + if ( $args{'install'} ) { + while( @missing ) { + resolve_dep(shift @missing, shift @missing); } } } @@ -300,14 +339,77 @@ sub test_dep { return undef; } else { - found("$module $version", 1); + my $msg = "$module"; + $msg .= " >=$version" if $version; + found($msg, 1); return 1; } } sub resolve_dep { my $module = shift; - system( qq[@PERL@ -MCPAN -e'install("$module")'] ); + my $version = shift; + + print "\nInstall module $module\n"; + + my $ext = $ENV{'RT_FIX_DEPS_CMD'}; + unless( $ext ) { + my $configured = 1; + { + local @INC = @INC; + if ( $ENV{'HOME'} ) { + unshift @INC, "$ENV{'HOME'}/.cpan"; + } + $configured = eval { require CPAN::MyConfig } || eval { require CPAN::Config }; + } + unless ( $configured ) { + print <install($module) }; + return $rv unless $@; + + print <&2`; } sub download_mods { @@ -355,10 +457,10 @@ sub check_perl_version { section("perl"); eval {require 5.008003}; if ($@) { - found("5.8.3", 0, "RT is known to be non-functional on versions of perl older than 5.8.3. Please upgrade to 5.8.3 or newer."); - die; + found("5.8.3", 0,"RT is known to be non-functional on versions of perl older than 5.8.3. Please upgrade to 5.8.3 or newer."); + exit(1); } else { - found("5.8.3", 1); + found( ">=5.8.3($])", 1); } }