]> git.donarmstrong.com Git - biopieces.git/blobdiff - code_ruby/test/maasha/seq/test_backtrack.rb
refactored backtrack methods to use options hash in method invocations
[biopieces.git] / code_ruby / test / maasha / seq / test_backtrack.rb
index 08fba496d323875a1490a157b165f006bbc0eaf5..79d530045cfb03bbbafff686d5aca210d9d023dd 100644 (file)
@@ -1,5 +1,5 @@
 #!/usr/bin/env ruby
-$:.unshift File.join(File.dirname(__FILE__),'..','lib')
+$:.unshift File.join(File.dirname(__FILE__), '..', '..', '..')
 
 # Copyright (C) 2007-2011 Martin A. Hansen.
 
@@ -26,121 +26,140 @@ $:.unshift File.join(File.dirname(__FILE__),'..','lib')
 # >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>><<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
 
 require 'test/unit'
+require 'test/helper'
 require 'maasha/seq'
-require 'maasha/seq/backtrack'
-
-include BackTrack
 
 class BackTrackTest < Test::Unit::TestCase
   def setup
-    #                       0         1
-    #                       01234567890123456789
-    @seq = Seq.new("test", "tacgatgctagcatgcacgg")
+    #                    0         1
+    #                    01234567890123456789
+    @seq = Seq.new(seq: "tacgatgctagcatgcacgg")
+    @seq.extend(BackTrack)
   end
 
-  def test_BackTrack_patscan_with_bad_pattern_raises
+  test "#patscan with bad pattern raises" do
     ["", "X", "1"].each { |pattern|
       assert_raise(BackTrackError) { @seq.patscan(pattern) }
     }
   end
 
-  def test_BackTrack_patscan_with_OK_pattern_dont_raise
+  test "#patscan with OK pattern dont raise" do
     ["N", "atcg"].each { |pattern|
       assert_nothing_raised { @seq.patscan(pattern) }
     }
   end
 
-  def test_BackTrack_patscan_with_bad_pos_raises
-    [-1, 20].each { |pos
-      assert_raise(BackTrackError) { @seq.patscan("N", pos) }
+  test "#patscan with bad start raises" do
+    [-1, 20].each { |start
+      assert_raise(BackTrackError) { @seq.patscan("N", start: start) }
     }
   end
 
-  def test_BackTrack_patscan_with_OK_pos_dont_raise
-    [0, 19].each { |pos
-      assert_nothing_raised { @seq.patscan("N", pos) }
+  test "#patscan with OK start dont raise" do
+    [0, 19].each { |start
+      assert_nothing_raised { @seq.patscan("N", start: start) }
     }
   end
 
-  def test_BackTrack_patscan_with_bad_mis_raises
+  test "#patscan with bad stop raises" do
+    [-1, 20].each { |stop|
+      assert_raise(BackTrackError) { @seq.patscan("N", stop: stop) }
+    }
+  end
+
+  test "#patscan with OK stop dont raise" do
+    [0, 19].each { |stop|
+      assert_nothing_raised { @seq.patscan("N", stop: stop) }
+    }
+  end
+
+  test "#patscan with stop returns correctly" do
+    assert_nil(@seq.patmatch("G", start: 0, stop: 2))
+    assert_equal("3:1:g", @seq.patmatch("G", start: 0, stop: 3).to_s)
+  end
+
+  test "#patscan with bad mis raises" do
     [-1, 6].each { |mis| 
-      assert_raise(BackTrackError) { @seq.patscan("N", 0, mis) }
+      assert_raise(BackTrackError) { @seq.patscan("N", max_mismatches: mis) }
     }
   end
 
-  def test_BackTrack_patscan_with_OK_mis_dont_raise
+  test "#patscan with OK mis dont raise" do
     [0, 5].each { |mis| 
-      assert_nothing_raised { @seq.patscan("N", 0, mis) }
+      assert_nothing_raised { @seq.patscan("N", max_mismatches: mis) }
     }
   end
 
-  def test_BackTrack_patscan_with_bad_ins_raises
+  test "#patscan with bad ins raises" do
     [-1, 6].each { |ins| 
-      assert_raise(BackTrackError) { @seq.patscan("N", 0, 0, ins) }
+      assert_raise(BackTrackError) { @seq.patscan("N", max_insertions: ins) }
     }
   end
 
-  def test_BackTrack_patscan_with_OK_ins_dont_raise
+  test "#patscan with OK ins dont raise" do
     [0, 5].each { |ins| 
-      assert_nothing_raised { @seq.patscan("N", 0, 0, ins) }
+      assert_nothing_raised { @seq.patscan("N", max_insertions: ins) }
     }
   end
 
-  def test_BackTrack_patscan_with_bad_del_raises
+  test "#patscan with bad del raises" do
     [-1, 6].each { |del| 
-      assert_raise(BackTrackError) { @seq.patscan("N", 0, 0, 0, del) }
+      assert_raise(BackTrackError) { @seq.patscan("N", max_deletions: del) }
     }
   end
 
-  def test_BackTrack_patscan_with_OK_del_dont_raise
+  test "#patscan with OK del dont raise" do
     [0, 5].each { |del| 
-      assert_nothing_raised { @seq.patscan("N", 0, 0, 0, del) }
+      assert_nothing_raised { @seq.patscan("N", max_deletions: del) }
     }
   end
 
-  def test_BackTrack_patscan_perfect_left_is_ok
+  test "#patscan perfect left is ok" do
     assert_equal("0:7:tacgatg", @seq.patscan("TACGATG").first.to_s)
   end
 
-  def test_BackTrack_patscan_perfect_right_is_ok
+  test "#patscan perfect right is ok" do
     assert_equal("13:7:tgcacgg", @seq.patscan("TGCACGG").first.to_s)
   end
 
-  def test_BackTrack_patscan_ambiguity_is_ok
+  test "#patscan ambiguity is ok" do
     assert_equal("13:7:tgcacgg", @seq.patscan("TGCACNN").first.to_s)
   end
 
-  def test_BackTrack_patscan_pos_is_ok
-    assert_equal("10:1:g", @seq.patscan("N", 10).first.to_s)
-    assert_equal("19:1:g", @seq.patscan("N", 10).last.to_s)
+  test "#patscan start is ok" do
+    assert_equal("10:1:g", @seq.patscan("N", start: 10).first.to_s)
+    assert_equal("19:1:g", @seq.patscan("N", start: 10).last.to_s)
   end
 
-  def test_BackTrack_patscan_mis_left_is_ok
-    assert_equal("0:7:tacgatg", @seq.patscan("Aacgatg", 0, 1).first.to_s)
+  test "#patscan mis left is ok" do
+    assert_equal("0:7:tacgatg", @seq.patscan("Aacgatg", max_mismatches: 1).first.to_s)
   end
 
-  def test_BackTrack_patscan_mis_right_is_ok
-    assert_equal("13:7:tgcacgg", @seq.patscan("tgcacgA", 0, 1).first.to_s)
+  test "#patscan mis right is ok" do
+    assert_equal("13:7:tgcacgg", @seq.patscan("tgcacgA", max_mismatches: 1).first.to_s)
   end
 
-  def test_BackTrack_patscan_ins_left_is_ok
-    assert_equal("0:7:tacgatg", @seq.patscan("Atacgatg", 0, 0, 1).first.to_s)
+  test "#patscan ins left is ok" do
+    assert_equal("0:7:tacgatg", @seq.patscan("Atacgatg", max_insertions: 1).first.to_s)
   end
 
-  def test_BackTrack_patscan_ins_right_is_ok
-    assert_equal("13:7:tgcacgg", @seq.patscan("tgcacggA", 0, 0, 1).first.to_s)
+  test "#patscan ins right is ok" do
+    assert_equal("13:7:tgcacgg", @seq.patscan("tgcacggA", max_insertions: 1).first.to_s)
   end
 
-  def test_BackTrack_patscan_del_left_is_ok
-    assert_equal("0:7:tacgatg", @seq.patscan("acgatg", 0, 0, 0, 1).first.to_s)
+  test "#patscan del left is ok" do
+    assert_equal("0:7:tacgatg", @seq.patscan("acgatg", max_deletions: 1).first.to_s)
   end
 
-  def test_BackTrack_patscan_del_right_is_ok
-    assert_equal("12:8:atgcacgg", @seq.patscan("tgcacgg", 0, 0, 0, 1).first.to_s)
+  test "#patscan del right is ok" do
+    assert_equal("12:8:atgcacgg", @seq.patscan("tgcacgg", max_deletions: 1).first.to_s)
   end
 
-  def test_BackTrack_patscan_ambiguity_mis_ins_del_all_ok
-    assert_equal("0:20:tacgatgctagcatgcacgg", @seq.patscan("tacatgcNagGatgcCacgg", 0, 1, 1, 1).first.to_s)
+  test "#patscan ambiguity mis ins del all ok" do
+    assert_equal("0:20:tacgatgctagcatgcacgg", @seq.patscan("tacatgcNagGatgcCacgg",
+                                                           max_mismatches: 1,
+                                                           max_insertions: 1,
+                                                           max_deletions: 1).first.to_s)
   end
 end