X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Model-DBIC-Schema.git;a=blobdiff_plain;f=t%2F05testapp.t;h=bc67a15b682da9f6d019f685e3eb93c9178706fb;hp=552ef4561fd348e0ae503fcab05bdcb74c598143;hb=b34b0affac7741bbb0427d429eb63f96ce9679b3;hpb=d618699fb37ec2e519fa03d8237d9544dc6fff7c diff --git a/t/05testapp.t b/t/05testapp.t index 552ef45..bc67a15 100644 --- a/t/05testapp.t +++ b/t/05testapp.t @@ -1,8 +1,9 @@ use strict; use Test::More; use FindBin; -use File::Spec; +use File::Spec::Functions qw/catfile catdir/; use File::Find; +use Config; plan skip_all => 'Enable this optional test with $ENV{C_M_DBIC_SCHEMA_TESTAPP}' unless $ENV{C_M_DBIC_SCHEMA_TESTAPP}; @@ -12,27 +13,39 @@ plan skip_all => 'Enable this optional test with $ENV{C_M_DBIC_SCHEMA_TESTAPP}' my $test_params = [ [ 'TestSchema', 'DBIC::Schema', '' ], [ 'TestSchemaDSN', 'DBIC::Schema', qw/fakedsn fakeuser fakepass/, '{ AutoCommit => 1 }' ], - [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', 'moniker_map={ roles => "ROLE" }', 'constraint=^users\z', 'dbi:SQLite:testdb.db' ], - [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', 'moniker_map={ roles => "ROLE" }', 'constraint=^users\z', 'dbi:SQLite:testdb.db', '', '', 'on_connect_do=["select 1", "select 2"]', 'quote_char="' ], - [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', 'moniker_map={ roles => "ROLE" }', 'dbi:SQLite:testdb.db', 'on_connect_do=["select 1", "select 2"]', 'quote_char="' ], + [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', q|moniker_map={ roles => 'ROLE' }|, 'constraint=^users\z', 'dbi:SQLite:testdb.db' ], + [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', q|moniker_map={ roles => 'ROLE' }|, 'constraint=^users\z', 'dbi:SQLite:testdb.db', '', '', q|on_connect_do=['select 1', 'select 2']| ], + [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', q|moniker_map={ roles => 'ROLE' }|, 'dbi:SQLite:testdb.db', q|on_connect_do=['select 1', 'select 2']| ], [ 'TestSchemaDSN', 'DBIC::Schema', 'create=static', 'traits=Caching', 'inflect_singular=sub { $_[0] =~ /\A(.+?)(_id)?\z/; $1 }', q{moniker_map=sub { return join('', map ucfirst, split(/[\W_]+/, lc $_[0])); }}, 'dbi:SQLite:testdb.db' ], ]; my $test_dir = $FindBin::Bin; -my $blib_dir = File::Spec->catdir ($test_dir, '..', 'blib', 'lib'); -my $cat_dir = File::Spec->catdir ($test_dir, 'TestApp'); -my $catlib_dir = File::Spec->catdir ($cat_dir, 'lib'); -my $schema_dir = File::Spec->catdir ($catlib_dir, 'TestSchemaDSN'); -my $creator = File::Spec->catfile($cat_dir, 'script', 'testapp_create.pl'); -my $model_dir = File::Spec->catdir ($catlib_dir, 'TestApp', 'Model'); -my $db = File::Spec->catdir ($cat_dir, 'testdb.db'); +my $blib_dir = catdir ($test_dir, '..', 'blib', 'lib'); +my $cat_dir = catdir ($test_dir, 'TestApp'); +my $catlib_dir = catdir ($cat_dir, 'lib'); +my $schema_dir = catdir ($catlib_dir, 'TestSchemaDSN'); +my $creator = catfile($cat_dir, 'script', 'testapp_create.pl'); +my $model_dir = catdir ($catlib_dir, 'TestApp', 'Model'); +my $db = catdir ($cat_dir, 'testdb.db'); + +my $catalyst_pl; + +foreach my $bin (split /[$Config{path_sep}:]/, $ENV{PATH}) { + my $file = catfile($bin, 'catalyst.pl'); + if (-f $file) { + $catalyst_pl = $file; + last; + } +} + +plan skip_all => 'catalyst.pl not found' unless $catalyst_pl; chdir($test_dir); -system("catalyst.pl TestApp"); +system("$^X $catalyst_pl TestApp"); chdir($cat_dir); # create test db -open my $sql, '|-', 'sqlite3', $db or die $!; +open my $sql, '|-', "sqlite3 $db" or die $!; print $sql <<'EOF'; CREATE TABLE users ( id INTEGER PRIMARY KEY, @@ -57,7 +70,7 @@ foreach my $tparam (@$test_params) { system($^X, "-I$blib_dir", $creator, 'model', $model, $helper, $model, @args); - my $model_path = File::Spec->catfile($model_dir, $model . '.pm'); + my $model_path = catfile($model_dir, $model . '.pm'); ok( -f $model_path, "$model_path is a file" ); my $compile_rv = system("$^X -I$blib_dir -I$catlib_dir -c $model_path"); ok($compile_rv == 0, "perl -c $model_path"); @@ -154,7 +167,7 @@ done_testing; sub rm_rf { my $name = $File::Find::name; - if(-d $name) { rmdir $name or die "Cannot rmdir $name: $!" } + if(-d $name) { rmdir $name or warn "Cannot rmdir $name: $!" } else { unlink $name or die "Cannot unlink $name: $!" } } @@ -175,9 +188,22 @@ sub code_for { } sub result_files { - my $glob = File::Spec->catfile($schema_dir, 'Result', '*'); + my $result_dir = catfile($schema_dir, 'Result'); + + my @results; + + opendir my $dir, $result_dir + or die "Could not open $result_dir: $!"; + + while (my $file = readdir $dir) { + next unless $file =~ /\.pm\z/; + + push @results, catfile($result_dir, $file); + } + + closedir $dir; - return glob($glob); + return @results; } END {