Sha256: afff835605d238e0aef30a62bdf19e83312103e47da588831f066ff7ecb906d6

Contents?: true

Size: 1.29 KB

Versions: 293

Compression:

Stored size: 1.29 KB

Contents

#!/usr/bin/env perl
use strict;
use warnings;

use Test::More;
use FindBin;
my $dir;
BEGIN { $dir = $FindBin::Bin . '/' };
use lib $dir;

my $module = $ENV{EXERCISM} ? 'Example' : 'Hamming';

plan tests => 12;

ok -e "${dir}${module}.pm", "Missing $module.pm" or BAIL_OUT "You need to create file: $module.pm";
eval "use $module";
ok !$@, "Cannot load $module" or BAIL_OUT "Cannot load $module. Does it compile? Does it end with 1;?";
can_ok $module, 'compute' or BAIL_OUT "Missing package $module; or missing sub compute()?";

sub dies_like(&$$) {
    my( $code, $expected, $message ) = @_;
    eval { $code->() };
    like $@ => $expected, $message;
}

my $sub = \&{"$module" . "::compute"}; 
is $sub->('A', 'A'), 0, "identical strands";
is $sub->('A', 'G'), 1, "different strands";
is $sub->('AG', 'CT'), 2, "completely different strands";
is $sub->('AT', 'CT'), 1, "one hamming distance";
is $sub->('GGACG', 'GGTCG'), 1, "one hamming distance, longer strands";
is $sub->('GATACA', 'GCATAA'), 4, "4 hamming distance";
is $sub->('GGACGGATTCTG', 'AGGACGGATTCT'), 9, "9 hamming distance";

dies_like { $sub->('AAAG', 'AAA') } 
    qr/DNA strands must be of equal length/, 
    "extra length on 1st strand";

dies_like { $sub->('AAA', 'AAAG') } 
    qr/DNA strands must be of equal length/, 
    "extra length on 2nd strand";

Version data entries

293 entries across 293 versions & 1 rubygems

Version Path
trackler-2.2.1.105 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.104 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.103 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.102 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.101 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.100 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.99 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.98 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.97 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.96 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.95 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.94 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.93 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.92 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.91 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.90 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.89 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.88 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.87 tracks/perl5/exercises/hamming/hamming.t
trackler-2.2.1.86 tracks/perl5/exercises/hamming/hamming.t