[Catalyst-commits] r12194 - in
Catalyst-Devel/1.00/branches/generated_app-fix: lib/Catalyst t
autarch at dev.catalyst.perl.org
autarch at dev.catalyst.perl.org
Sat Dec 5 22:32:20 GMT 2009
Author: autarch
Date: 2009-12-05 22:32:19 +0000 (Sat, 05 Dec 2009)
New Revision: 12194
Modified:
Catalyst-Devel/1.00/branches/generated_app-fix/lib/Catalyst/Helper.pm
Catalyst-Devel/1.00/branches/generated_app-fix/t/generated_app.t
Log:
Fixes for generated_app.t so it doesn't rely on finding catalyst.pl in the current path, and so that it always uses the right share dir
Modified: Catalyst-Devel/1.00/branches/generated_app-fix/lib/Catalyst/Helper.pm
===================================================================
--- Catalyst-Devel/1.00/branches/generated_app-fix/lib/Catalyst/Helper.pm 2009-12-05 22:30:42 UTC (rev 12193)
+++ Catalyst-Devel/1.00/branches/generated_app-fix/lib/Catalyst/Helper.pm 2009-12-05 22:32:19 UTC (rev 12194)
@@ -32,7 +32,10 @@
sub get_sharedir_file {
my ($self, @filename) = @_;
my $dist_dir;
- if (-d "inc/.author" && -f "lib/Catalyst/Helper.pm"
+ if (exists $ENV{CATALYST_DEVEL_SHAREDIR}) {
+ $dist_dir = $ENV{CATALYST_DEVEL_SHAREDIR};
+ }
+ elsif (-d "inc/.author" && -f "lib/Catalyst/Helper.pm"
) { # Can't use sharedir if we're in a checkout
# this feels horrible, better ideas?
$dist_dir = 'share';
Modified: Catalyst-Devel/1.00/branches/generated_app-fix/t/generated_app.t
===================================================================
--- Catalyst-Devel/1.00/branches/generated_app-fix/t/generated_app.t 2009-12-05 22:30:42 UTC (rev 12193)
+++ Catalyst-Devel/1.00/branches/generated_app-fix/t/generated_app.t 2009-12-05 22:32:19 UTC (rev 12194)
@@ -1,30 +1,46 @@
use strict;
use warnings;
use lib ();
-use File::Temp qw/ tempdir tmpnam /;
+use Cwd qw( abs_path );
+use File::Temp qw/ tempdir /;
use File::Spec;
use FindBin qw/$Bin/;
use Catalyst::Devel;
+use Catalyst::Helper;
+use Test::More;
+eval "use IPC::Run3";
+plan skip_all => 'These tests require IPC::Run3' if $@;
+
+my $share_dir = abs_path('share');
+plan skip_all => "No share dir at $share_dir!"
+ unless -d $share_dir;
+
+$ENV{CATALYST_DEVEL_SHAREDIR} = $share_dir;
+
my $dir = tempdir(CLEANUP => 1);
my $devnull = File::Spec->devnull;
-use Test::More;
-
diag "Generated app is in $dir";
+chdir $dir or die "Cannot chdir to $dir: $!";
+
{
- my $exit;
- if ($^O eq 'MSWin32') {
- $exit = system("cd $dir & catalyst TestApp > $devnull 2>&1");
- }
- else {
- $exit = system("cd $dir; catalyst.pl TestApp > $devnull 2>&1");
- }
- is $exit, 0, 'Exit status ok';
+ open my $fh, '>', $devnull or die "Cannot write to $devnull: $!";
+
+ local *STDOUT = $fh;
+
+ my $helper = Catalyst::Helper->new(
+ {
+ name => 'TestApp',
+ }
+ );
+
+ $helper->mk_app('TestApp');
}
-chdir(File::Spec->catdir($dir, 'TestApp'));
+my $app_dir = File::Spec->catdir($dir, 'TestApp');
+chdir($app_dir) or die "Cannot chdir to $app_dir: $!";
lib->import(File::Spec->catdir($dir, 'TestApp', 'lib'));
my @files = qw|
@@ -60,9 +76,9 @@
}
create_ok($_, 'My' . $_) for qw/Model View Controller/;
-is system($^X, 'Makefile.PL'), 0, 'Ran Makefile.PL';
+command_ok( [ $^X, 'Makefile.PL' ] );
ok -e "Makefile", "Makefile generated";
-is system("make"), 0, 'Run make';
+command_ok( [ 'make' ] );
run_generated_component_tests();
@@ -80,9 +96,24 @@
chdir('/');
done_testing;
+sub command_ok {
+ my $cmd = shift;
+ my $desc = shift;
+
+ my $stdout;
+ my $stderr;
+ run3( $cmd, \undef, \$stdout, \$stderr );
+
+ $desc ||= "Exit status ok for '@{$cmd}'";
+ unless ( is $? >> 8, 0, $desc ) {
+ diag "STDOUT:\n$stdout" if defined $stdout;
+ diag "STDERR:\n$stderr" if defined $stderr;
+ }
+}
+
sub runperl {
my $comment = pop @_;
- is system($^X, '-I', File::Spec->catdir($Bin, '..', 'lib'), @_), 0, $comment;
+ command_ok( [ $^X, '-I', File::Spec->catdir($Bin, '..', 'lib'), @_ ], $comment );
}
my @generated_component_tests;
@@ -115,5 +146,5 @@
my ($type, $name) = @_;
runperl( File::Spec->catdir('script', 'testapp_create.pl'), $type, $name,
"'script/testapp_create.pl $type $name' ok");
- test_fn(File::Spec->catdir('t', sprintf("%s_%s.t", $type, $name)));
+ test_fn(File::Spec->catdir('t', sprintf("%s_%s.t", lc $type, $name)));
}
More information about the Catalyst-commits
mailing list