summaryrefslogtreecommitdiff
path: root/exercism/emacs-lisp/hamming/hamming-test.el
diff options
context:
space:
mode:
Diffstat (limited to 'exercism/emacs-lisp/hamming/hamming-test.el')
-rw-r--r--exercism/emacs-lisp/hamming/hamming-test.el55
1 files changed, 55 insertions, 0 deletions
diff --git a/exercism/emacs-lisp/hamming/hamming-test.el b/exercism/emacs-lisp/hamming/hamming-test.el
new file mode 100644
index 0000000..fb9be46
--- /dev/null
+++ b/exercism/emacs-lisp/hamming/hamming-test.el
@@ -0,0 +1,55 @@
+;;; hamming-test.el --- Tests for hamming (exercism)
+
+;;; Commentary:
+;; Common test data version: 2.0.1 f79dfd7
+
+;;; Code:
+
+(load-file "hamming.el")
+
+(declare-function hamming-distance "hamming.el")
+
+(ert-deftest empty-strands ()
+ (should (= 0 (hamming-distance "" ""))))
+
+(ert-deftest identical-strands ()
+ (should (= 0 (hamming-distance "A" "A"))))
+
+(ert-deftest long-identical-strands ()
+ (should (= 0 (hamming-distance "GGACTGA" "GGACTGA"))))
+
+(ert-deftest complete-distance-in-single-nucleotide-strands ()
+ (should (= 1 (hamming-distance "A" "G"))))
+
+(ert-deftest complete-distance-in-small-strands ()
+ (should (= 2 (hamming-distance "AG" "CT"))))
+
+(ert-deftest small-distance-in-small-strands ()
+ (should (= 1 (hamming-distance "AT" "CT"))))
+
+(ert-deftest small-distance ()
+ (should (= 1 (hamming-distance "GGACG" "GGTCG"))))
+
+(ert-deftest small-distance-in-long-strands ()
+ (should (= 2 (hamming-distance "ACCAGGG" "ACTATGG"))))
+
+(ert-deftest non-unique-character-in-first-strand ()
+ (should (= 1 (hamming-distance "AAA" "AAG"))))
+
+(ert-deftest same-nucleotides-in-different-positions ()
+ (should (= 2 (hamming-distance "TAG" "GAT"))))
+
+(ert-deftest large-distance ()
+ (should (= 4 (hamming-distance "GATACA" "GCATAA"))))
+
+(ert-deftest large-distance-in-off-by-one-strand ()
+ (should (= 9 (hamming-distance "GGACGGATTCTG" "AGGACGGATTCT"))))
+
+(ert-deftest disallow-first-strand-longer ()
+ (should-error (hamming-distance "AATG" "AAA")))
+
+(ert-deftest disallow-second-strand-longer ()
+ (should-error (hamming-distance "ATA" "AGTG")))
+
+(provide 'hamming-test)
+;;; hamming-test.el ends here