Here is a new file for the purpose of testing config::inter::make. Due to the fact that anyone who is running Parrot tests is highly likely to have some version of 'make' on his/her box and is almost as likely to have a version of 'gmake' there, it will be very hard to achieve coverage of very branch and condition in config/inter/make.pm.
Please review. I'll commit to trunk in about 3 days if there is no objection. Thank you very much. kid51
Index: MANIFEST =================================================================== --- MANIFEST (revision 21118) +++ MANIFEST (working copy) @@ -1,7 +1,7 @@ # ex: set ro: # $Id$ # -# generated by tools/dev/mk_manifest_and_skip.pl Thu Sep 6 19:17:40 2007 UT +# generated by tools/dev/mk_manifest_and_skip.pl Fri Sep 7 01:07:33 2007 UT # # See tools/dev/install_files.pl for documentation on the # format of this file. @@ -2928,6 +2928,7 @@ t/configure/106-init_headers.t [] t/configure/107-inter_progs.01.t [] t/configure/107-inter_progs.02.t [] +t/configure/108-inter_make.t [] t/configure/testlib/Make_VERSION_File.pm [] t/configure/testlib/Tie/Filehandle/Preempt/Stdin.pm [] t/configure/testlib/init/alpha.pm [] Index: t/configure/108-inter_make.t =================================================================== --- t/configure/108-inter_make.t (revision 0) +++ t/configure/108-inter_make.t (revision 0) @@ -0,0 +1,94 @@ +#! perl +# Copyright (C) 2007, The Perl Foundation. +# $Id$ +# 108-inter_make.t + +use strict; +use warnings; +use Test::More tests => 13; +use Carp; +use lib qw( lib t/configure/testlib ); +use_ok('config::init::defaults'); +use_ok('config::inter::make'); +use Parrot::Configure; +use Parrot::Configure::Options qw( process_options ); +use Parrot::IO::Capture::Mini; +use Parrot::Configure::Test qw( test_step_thru_runstep); +use Tie::Filehandle::Preempt::Stdin; + +my $args = process_options( { + argv => [ q{--ask} ], + mode => q{configure}, +} ); + +my $conf = Parrot::Configure->new(); + +test_step_thru_runstep($conf, q{init::defaults}, $args); + +my ($task, $step_name, @step_params, $step, $ret); +my $pkg = q{inter::make}; + +$conf->add_steps($pkg); +$conf->options->set(%{$args}); + +$task = $conf->steps->[0]; +$step_name = $task->step; [EMAIL PROTECTED] = @{ $task->params }; + +$step = $step_name->new(); +ok(defined $step, "$step_name constructor returned defined value"); +isa_ok($step, $step_name); +ok($step->description(), "$step_name has description"); + +my (@prompts, $object); [EMAIL PROTECTED] = ( q{make} ); +$object = tie *STDIN, 'Tie::Filehandle::Preempt::Stdin', @prompts; +can_ok('Tie::Filehandle::Preempt::Stdin', ('READLINE')); +isa_ok($object, 'Tie::Filehandle::Preempt::Stdin'); + +$ret = $step->runstep($conf); +ok(defined $ret, "$step_name runstep() returned defined value"); + +$object = undef; +untie *STDIN; + +pass("Completed all tests in $0"); + +################### DOCUMENTATION ################### + +=head1 NAME + +108-inter_make.t - test config::inter::make + +=head1 SYNOPSIS + + % prove t/configure/108-inter_make.t + +=head1 DESCRIPTION + +The files in this directory test functionality used by F<Configure.pl>. + +The tests in this file test subroutines exported by config::inter::make. + +B<Note:> Since F<inter::make> probes for the F<make> program +found on a particular OS, it will probably be difficult to achieve high +branch or condition coverage. The module is likely to discover a +F<make> program long before it reaches the point where it must prompt +the user for a response. + +=head1 AUTHOR + +James E Keenan + +=head1 SEE ALSO + +config::inter::make, F<Configure.pl>. + +=cut + +# Local Variables: +# mode: cperl +# cperl-indent-level: 4 +# fill-column: 100 +# End: +# vim: expandtab shiftwidth=4: Property changes on: t/configure/108-inter_make.t ___________________________________________________________________ Name: svn:mime-type + text/plain Name: svn:keywords + Author Date Id Revision Name: svn:eol-style + native