App-Sandy
view release on metacpan or search on metacpan
t/lib/TestsFor/App/Sandy/Quality.pm view on Meta::CPAN
package TestsFor::App::Sandy::Quality;
# ABSTRACT: Tests for 'App::Sandy::Quality' class
use App::Sandy::Base 'test';
use App::Sandy::RNG;
use autodie;
use base 'TestsFor';
use constant {
SEQ_SYS => "poisson",
QUALITY_SIZE => 10,
SEED => 17
};
sub startup : Tests(startup) {
my $test = shift;
$test->SUPER::startup;
my $class = ref $test;
$class->mk_classdata('default_quality');
$class->mk_classdata('default_attr');
$class->mk_classdata('rng');
}
sub setup : Tests(setup) {
my $test = shift;
my %child_arg = @_;
$test->SUPER::setup;
my %default_attr = (
quality_profile => SEQ_SYS,
%child_arg
);
$test->default_attr(\%default_attr);
$test->default_quality($test->class_to_test->new(%default_attr));
$test->rng(App::Sandy::RNG->new(SEED));
}
sub constructor : Tests(2) {
my $test = shift;
my $class = $test->class_to_test;
my $quality = $test->default_quality;
my %default_attr = %{ $test->default_attr };
while (my ($attr, $value) = each %default_attr) {
can_ok $quality, $attr;
is lc $quality->$attr, lc $value, "The value for $attr shold be correct";
}
}
sub gen_quality : Test(10) {
my $test = shift;
my $size = QUALITY_SIZE;
my $class = $test->class_to_test;
my $quality = $test->default_quality;
my $rng = $test->rng;
for my $i (1..10) {
my $q = $quality->gen_quality($size, $rng);
is length $$q, $size,
"quality length should be equal read_size. Try $i";
}
}
( run in 1.221 second using v1.01-cache-2.11-cpan-ceb78f64989 )