summaryrefslogtreecommitdiffstats
path: root/t/subpermutations.t
diff options
context:
space:
mode:
Diffstat (limited to 't/subpermutations.t')
-rw-r--r--t/subpermutations.t36
1 files changed, 36 insertions, 0 deletions
diff --git a/t/subpermutations.t b/t/subpermutations.t
new file mode 100644
index 0000000..bf16ec3
--- /dev/null
+++ b/t/subpermutations.t
@@ -0,0 +1,36 @@
+#!/usr/bin/env perl
+use strict;
+use warnings;
+use Test::More;
+
+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"],
+);
+
+for my $word (keys %is_subpermutation_tests) {
+ ok(is_subpermutation($_, $word), "is '$_' a subpermutation of '$word'?")
+ for @{ $is_subpermutation_tests{$word} };
+}
+for my $word (keys %all_subpermutations_tests) {
+ is_deeply(
+ [sort(all_subpermutations($word))],
+ [sort(@{ $all_subpermutations_tests{$word} })],
+ "do we get all of the subpermutations of '$word'?"
+ );
+}
+
+done_testing;