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 93 94 95 96
|
// Copyright ©2020 The bíogo Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package fai
import (
"encoding/json"
"io"
"io/ioutil"
"os"
"path/filepath"
"testing"
)
func TestFile(t *testing.T) {
files, err := filepath.Glob("testdata/*.fa")
if err != nil {
t.Fatalf("unexpected error: %v", err)
}
for _, p := range files {
f, err := os.Open(p + ".fai")
if err != nil {
t.Errorf("unexpected error: %v", err)
continue
}
idx, err := ReadFrom(f)
f.Close()
if err != nil {
t.Errorf("unexpected error: %v", err)
continue
}
b, err := ioutil.ReadFile(p + ".json")
if err != nil {
t.Errorf("unexpected error: %v", err)
continue
}
var tests []struct {
Seq string
Start, End int
Want string
}
err = json.Unmarshal(b, &tests)
if err != nil {
t.Errorf("unexpected error: %v", err)
continue
}
f, err = os.Open(p)
if err != nil {
t.Errorf("unexpected error: %v", err)
continue
}
m := NewFile(f, idx)
for _, test := range tests {
var s *Seq
if test.Start == -1 {
s, err = m.Seq(test.Seq)
} else {
s, err = m.SeqRange(test.Seq, test.Start, test.End)
}
if err != nil {
t.Errorf("unexpected error: %v", err)
continue
}
for _, bufSize := range []int{10, 100, 1000} {
buf := make([]byte, bufSize)
var got []byte
for {
n, err := s.Read(buf)
got = append(got, buf[:n]...)
if err != nil {
if err == io.EOF {
break
}
t.Errorf("unexpected error: %v", err)
}
}
if test.Start != -1 && len(got) != test.End-test.Start {
t.Errorf("unexpected sequence length: got:%d want:%d", len(got), test.End-test.Start)
}
if string(got) != test.Want {
t.Errorf("unexpected sequence: got:%q want:%q", got, test.Want)
}
s.Reset()
}
}
f.Close()
}
}
|