fix codetest failure - ASSERT_ARGS does not have a ; after and
[parrot.git] / t / configure / 012-verbose.t
blob2d2d9f73a9494ede46114d081f152287061ece3b
1 #! perl
2 # Copyright (C) 2007, Parrot Foundation.
3 # $Id$
4 # 012-verbose.t
6 use strict;
7 use warnings;
9 use Test::More tests => 12;
10 use Carp;
11 use lib qw( lib t/configure/testlib );
12 use Parrot::Configure;
13 use Parrot::Configure::Options qw( process_options );
14 use IO::CaptureOutput qw | capture |;
16 $| = 1;
17 is( $|, 1, "output autoflush is set" );
19 my ($args, $step_list_ref) = process_options(
20     {
21         argv => [q{--verbose}],
22         mode => q{configure},
23     }
25 ok( defined $args, "process_options returned successfully" );
26 my %args = %$args;
28 my $conf = Parrot::Configure->new;
29 ok( defined $conf, "Parrot::Configure->new() returned okay" );
31 my $step        = q{init::beta};
32 my $description = 'Determining if your computer does beta';
34 $conf->add_steps($step);
35 my @confsteps = @{ $conf->steps };
36 isnt( scalar @confsteps, 0,
37     "Parrot::Configure object 'steps' key holds non-empty array reference" );
38 is( scalar @confsteps, 1, "Parrot::Configure object 'steps' key holds ref to 1-element array" );
39 my $nontaskcount = 0;
40 foreach my $k (@confsteps) {
41     $nontaskcount++ unless $k->isa("Parrot::Configure::Task");
43 is( $nontaskcount, 0, "Each step is a Parrot::Configure::Task object" );
44 is( $confsteps[0]->step, $step, "'step' element of Parrot::Configure::Task struct identified" );
45 ok( !ref( $confsteps[0]->object ),
46     "'object' element of Parrot::Configure::Task struct is not yet a ref" );
48 $conf->options->set(%args);
49 is( $conf->options->{c}->{debugging},
50     1, "command-line option '--debugging' has been stored in object" );
53     my $rv;
54     my $stdout;
55     capture ( sub {$rv    = $conf->runsteps}, \$stdout );
56     ok( $rv, "runsteps successfully ran $step" );
57     like(
58     $stdout,
59     qr/$description\.\.\..*beta is verbose.*You've got beta.*done\./s,    #'
60         "Got message expected upon running $step"
61     );
64 pass("Completed all tests in $0");
66 ################### DOCUMENTATION ###################
68 =head1 NAME
70 012-verbose.t - test the C<--verbose> command-line argument
72 =head1 SYNOPSIS
74     % prove t/configure/012-verbose.t
76 =head1 DESCRIPTION
78 The files in this directory test functionality used by F<Configure.pl>.
80 The tests in this file examine what happens when you configure with
81 C<--verbose>.
83 =head1 AUTHOR
85 James E Keenan
87 =head1 SEE ALSO
89 Parrot::Configure, F<Configure.pl>.
91 =cut
93 # Local Variables:
94 #   mode: cperl
95 #   cperl-indent-level: 4
96 #   fill-column: 100
97 # End:
98 # vim: expandtab shiftwidth=4: