summaryrefslogtreecommitdiffstats
path: root/t/015-subpermutations.t
blob: 36e57d8f865c2a5644a454d03942afee9a3f4155 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#!/usr/bin/env perl
use strict;
use warnings;
use Test::More;
use Test::Deep;
use List::Util qw/sum/;
use Games::Word qw/is_subpermutation all_subpermutations/;

my %is_subpermutation_tests = (
    ""      => [""],
    "abc",  => ["", "abc", "ab", "ac", "cb", "bac", "ca"],
    "aaba"  => ["a", "aa", "aaa", "aab", "aba"],
    "abcba" => ["aa", "bb", "c", "abc", "cba", "abba", "bbaac", "caa"],
);
my %all_subpermutations_tests = (
    ""    => [""],
    "a"   => ["", "a"],
    "ab"  => ["", "a", "b", "ab", "ba"],
    "aab" => ["", "a", "a", "b", "aa", "ab", "ab", "ba", "ba", "aa",
              "aab", "aab", "aba", "aba", "baa", "baa"],
    "abc" => ["", "a", "b", "c", "ab", "ac", "bc", "ba", "ca", "cb",
              "abc", "acb", "bac", "bca", "cab", "cba"],
);
plan tests => (sum map { scalar @$_ } values %is_subpermutation_tests) +
              keys %all_subpermutations_tests;

while (my ($word, $subpermutations) = each %is_subpermutation_tests) {
    ok(is_subpermutation($_, $word), "is '$_' a subpermutation of '$word'?")
        for @$subpermutations;
}
while (my ($word, $subpermutations) = each %all_subpermutations_tests) {
    cmp_deeply([all_subpermutations($word)], bag(@$subpermutations),
               "do we get all of the subpermutations of '$word'?");
}