File: test_test2.rb

package info (click to toggle)
ruby-crb-blast 0.6.9-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 348 kB
  • sloc: ruby: 820; makefile: 7
file content (92 lines) | stat: -rw-r--r-- 2,334 bytes parent folder | download | duplicates (3)
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#!/usr/bin/env  ruby

require 'helper'
require 'etc'

class Test2CRBBlast < Test::Unit::TestCase

  context 'crb-blast' do

    setup do
      @blaster = CRB_Blast::CRB_Blast.new('test/query2.fasta', 'test/target2.fasta')
      @dbs = @blaster.makedb
      @run = @blaster.run_blast(1e-5, Etc.nprocessors, false)
      @load = @blaster.load_outputs
      @recips = @blaster.find_reciprocals
      @secondaries = @blaster.find_secondaries
    end

    teardown do
      extensions  = ["blast", "nsq", "nin", "nhr", "psq", "pin", "phr"]
      Dir["*"].each do |file|
        extensions.each do |extension|
          if file =~ /.*\.#{extension}$/
            File.delete(file)
          end
        end
      end
    end

    should 'setup2 should run ok' do
      ans = @blaster != nil
      assert_equal ans, true
    end

    should 'break input file into pieces' do
      files = @blaster.split_input('test/query2.fasta', 4)
      assert_equal 4, files.size
      files.each do |file|
        assert File.exist?(file)
      end
      # little teardown
      files.each do |file|
        File.delete(file)
      end
    end

    should 'break input file into no more pieces than there are sequences' do
      files = @blaster.split_input('test/query.fasta', 16)
      assert_equal 11, files.size
      files.each do |file|
        assert File.exist?(file)
      end
      # little teardown
      files.each do |file|
        File.delete(file)
      end
    end

    should 'run blast should check if the databases exist yet' do
      tmp = CRB_Blast::CRB_Blast.new('test/query2.fasta',
                                     'test/target2.fasta')
      assert_equal false, tmp.run_blast(10,1,false)
    end

    should 'load output should check if the databases exist' do
      tmp = CRB_Blast::CRB_Blast.new('test/query2.fasta',
                                     'test/target2.fasta')
      assert_raise RuntimeError do
        tmp.load_outputs
      end
    end

    should 'find reciprocals' do
      assert_equal 7, @recips
    end

    should 'add secondary hits' do
      assert_equal 2, @secondaries
    end

    should 'get non reciprocal hits' do
      count=0
      @blaster.missed.each_pair do |key, value|
        value.each do |i|
          count+=1
        end
      end
      assert_equal count,70
    end

  end
end