mirror of
https://github.com/duncs/clusterssh.git
synced 2025-04-21 17:09:06 +00:00
349 lines
10 KiB
Perl
349 lines
10 KiB
Perl
use strict;
|
|
use warnings;
|
|
|
|
use FindBin qw($Bin);
|
|
use lib "$Bin/../lib";
|
|
|
|
use Test::More;
|
|
use Test::Trap;
|
|
|
|
BEGIN { use_ok('App::ClusterSSH::Base') }
|
|
|
|
# force default language for tests
|
|
App::ClusterSSH::Base->set_lang('en');
|
|
|
|
my $base;
|
|
|
|
$base = App::ClusterSSH::Base->new();
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
|
|
diag('testing output') if ( $ENV{TEST_VERBOSE} );
|
|
trap {
|
|
$base->stdout_output('testing');
|
|
};
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout =~ tr/\n//, 1, 'got correct number of print lines' );
|
|
like( $trap->stdout, qr/\Atesting\n\Z/xsm,
|
|
'checking for expected print output' );
|
|
|
|
diag('Testing debug output') if ( $ENV{TEST_VERBOSE} );
|
|
|
|
for my $level ( 0 .. 9 ) {
|
|
$base->set_debug_level($level);
|
|
is( $base->debug_level(), $level, 'debug level is correct' );
|
|
|
|
trap {
|
|
for my $log_level ( 0 .. 9 ) {
|
|
$base->debug( $log_level, 'test' );
|
|
}
|
|
};
|
|
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout =~ tr/\n//,
|
|
$level + 1, 'got correct number of debug lines' );
|
|
like( $trap->stdout, qr/(?:test\n){$level}/xsm,
|
|
'checking for expected debug output' );
|
|
}
|
|
|
|
my $level;
|
|
trap {
|
|
$level = $base->set_debug_level();
|
|
};
|
|
isa_ok( $trap->die, 'App::ClusterSSH::Exception',
|
|
'Caught exception object OK' );
|
|
is( $trap->leaveby, 'die', 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting no STDOUT' );
|
|
like( $trap->die, qr/^Debug level not provided/, 'Got correct croak text' );
|
|
|
|
$base->set_debug_level(10);
|
|
is( $base->debug_level(), 9, 'checking debug_level reset to 9' );
|
|
|
|
$base = undef;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new( debug => 6, );
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout =~ tr/\n//, 1, 'got new() debug output lines' );
|
|
like(
|
|
$trap->stdout,
|
|
qr/^Setting\slanguage\sto\s"en"/xsm,
|
|
'got expected new() output'
|
|
);
|
|
|
|
$base = undef;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new( debug => 6, lang => 'en' );
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout =~ tr/\n//, 1, 'got new() debug output lines' );
|
|
like(
|
|
$trap->stdout,
|
|
qr/^Setting\slanguage\sto\s"en"/xsm,
|
|
'got expected new() output'
|
|
);
|
|
|
|
$base = undef;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new( debug => 6, lang => 'rubbish' );
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout =~ tr/\n//, 1, 'got new() debug output lines' );
|
|
like(
|
|
$trap->stdout,
|
|
qr/^Setting\slanguage\sto\s"rubbish"/xsm,
|
|
'got expected new() output'
|
|
);
|
|
|
|
$base = undef;
|
|
my $get_config;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new( debug => 7, );
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout =~ tr/\n//, 3, 'got new() debug output lines' );
|
|
like(
|
|
$trap->stdout,
|
|
qr/^Setting\slanguage\sto\s"en".Arguments\sto\sApp::ClusterSSH::Base->new.*debug\s=>\s7,$/xsm,
|
|
'got expected new() output'
|
|
);
|
|
|
|
trap {
|
|
$get_config = $base->config();
|
|
};
|
|
$trap->quiet("No issus with config call");
|
|
is( $get_config, undef, "config set undef as expected" );
|
|
|
|
# config tests
|
|
$base = undef;
|
|
my $object;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new( debug => 3, );
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting no STDOUT' );
|
|
|
|
$base = undef;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new( debug => 3, parent => 'guardian' );
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting no STDOUT' );
|
|
is( $base->parent, 'guardian', 'Expecting no STDOUT' );
|
|
|
|
trap {
|
|
$get_config = $base->config();
|
|
};
|
|
isa_ok( $trap->die, 'App::ClusterSSH::Exception',
|
|
'Caught exception object OK' );
|
|
is( $trap->leaveby, 'die', 'died ok' );
|
|
like( $trap->die, qr/^config has not yet been set/,
|
|
'Got correct croak text' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting not STDOUT' );
|
|
is( $get_config, undef, 'config left empty' );
|
|
|
|
trap {
|
|
$object = $base->set_config();
|
|
};
|
|
isa_ok( $trap->die, 'App::ClusterSSH::Exception',
|
|
'Caught exception object OK' );
|
|
is( $trap->leaveby, 'die', 'died ok' );
|
|
like( $trap->die, qr/^passed config is empty/, 'Got correct croak text' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting no STDOUT' );
|
|
|
|
trap {
|
|
$object = $base->set_config('set to scalar');
|
|
};
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'config set ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
like(
|
|
$trap->stdout,
|
|
qr/^Setting\sapp\sconfiguration/xsm,
|
|
'Got expected STDOUT'
|
|
);
|
|
isa_ok( $object, 'App::ClusterSSH::Base' );
|
|
|
|
trap {
|
|
$get_config = $base->config();
|
|
};
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting not STDOUT' );
|
|
is( $get_config, 'set to scalar', 'config set as expected' );
|
|
|
|
trap {
|
|
$object = $base->set_config('set to another scalar');
|
|
};
|
|
is( $trap->leaveby, 'die', 'died ok' );
|
|
isa_ok( $trap->die, 'App::ClusterSSH::Exception',
|
|
'Caught exception object OK' );
|
|
like(
|
|
$trap->die,
|
|
qr/^config\shas\salready\sbeen\sset/,
|
|
'config cannot be reset'
|
|
);
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Got expected STDOUT' );
|
|
|
|
trap {
|
|
$object = $base->set_config();
|
|
};
|
|
is( $trap->leaveby, 'die', 'died ok' );
|
|
isa_ok( $trap->die, 'App::ClusterSSH::Exception',
|
|
'Caught exception object OK' );
|
|
like(
|
|
$trap->die,
|
|
qr/^config\shas\salready\sbeen\sset/,
|
|
'config cannot be reset'
|
|
);
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Got expected STDOUT' );
|
|
|
|
# basic checks - validity of config is tested elsewhere
|
|
my %config;
|
|
trap {
|
|
%config = $object->load_file;
|
|
};
|
|
is( $trap->leaveby, 'die', 'died ok' );
|
|
isa_ok( $trap->die, 'App::ClusterSSH::Exception',
|
|
'Caught exception object OK' );
|
|
is( $trap->die,
|
|
q{"filename" arg not passed},
|
|
'missing filename arg die message'
|
|
);
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Got expected STDOUT' );
|
|
|
|
trap {
|
|
%config = $object->load_file( filename => $Bin . '/15config.t.file1' );
|
|
};
|
|
is( $trap->leaveby, 'die', 'died ok' );
|
|
isa_ok( $trap->die, 'App::ClusterSSH::Exception',
|
|
'Caught exception object OK' );
|
|
is( $trap->die, q{"type" arg not passed}, 'missing type arg die message' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
|
|
my $get_options;
|
|
|
|
$base = undef;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new( debug => 3 );
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting no STDOUT' );
|
|
is( $base->parent, undef, 'Expecting no parent set' );
|
|
|
|
trap {
|
|
$get_options = $base->options();
|
|
};
|
|
$trap->quiet("No extra output");
|
|
is( $get_options, undef, "options call correctly unset" );
|
|
|
|
$base = undef;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new( debug => 3, parent => 'guardian' );
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting no STDOUT' );
|
|
is( $base->parent, 'guardian', 'Expecting no STDOUT' );
|
|
|
|
trap {
|
|
$get_options = $base->options();
|
|
};
|
|
$trap->quiet("No extra output");
|
|
is( $get_options, undef, "options call correctly unset" );
|
|
|
|
$base = undef;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new(
|
|
debug => 3,
|
|
parent => { config => 'set', options => 'set' }
|
|
);
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting no STDOUT' );
|
|
is( ref( $base->parent ), 'HASH', 'Expecting no STDOUT' );
|
|
is( $base->parent->{config}, 'set', 'Expecting no STDOUT' );
|
|
|
|
trap {
|
|
$get_options = $base->options();
|
|
};
|
|
is( ref($get_options), '', "options call correctly set" );
|
|
is( $get_options, 'set', "options call hash value correctly set" );
|
|
$trap->quiet("No extra output");
|
|
|
|
my $sort;
|
|
trap {
|
|
$sort = $base->sort;
|
|
};
|
|
$trap->quiet("No errors getting 'sort'");
|
|
|
|
# NOTE: trap doesnt like passing code refs, so recreate here
|
|
$sort = $base->sort;
|
|
is( ref($sort), 'CODE', "got results from sort" );
|
|
my @sorted = $sort->( 4, 8, 1, 5, 3 );
|
|
my @expected = ( 1, 3, 4, 5, 8 );
|
|
is_deeply( \@sorted, \@expected, "simple sort results okay" );
|
|
|
|
$base = undef;
|
|
trap {
|
|
$base = App::ClusterSSH::Base->new(
|
|
debug => 3,
|
|
parent => { config => { use_natural_sort => 1 }, options => 'set' }
|
|
);
|
|
};
|
|
isa_ok( $base, 'App::ClusterSSH::Base' );
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( $trap->stderr, '', 'Expecting no STDERR' );
|
|
is( $trap->stdout, '', 'Expecting no STDOUT' );
|
|
|
|
trap {
|
|
$sort = $base->sort;
|
|
};
|
|
|
|
# May get an error here if Sort::Naturally is not installed
|
|
# $trap->quiet("No errors getting 'sort'");
|
|
is( $trap->leaveby, 'return', 'returned ok' );
|
|
is( $trap->die, undef, 'returned ok' );
|
|
is( ref($sort), 'CODE', "got results from sort" );
|
|
@sorted = $sort->( 4, 8, 1, 5, 3 );
|
|
@expected = ( 1, 3, 4, 5, 8 );
|
|
is_deeply( \@sorted, \@expected, "simple sort results okay" );
|
|
|
|
done_testing();
|