File: normalize_test.go

package info (click to toggle)
golang-github-brentp-vcfgo 0.0~git20190824.654ed2e-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 2,924 kB
  • sloc: makefile: 5; sh: 1
file content (77 lines) | stat: -rw-r--r-- 1,757 bytes parent folder | download
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
package vcfgo

import (
	"testing"
)

var leftaligntests = []struct {
	pos int
	ref []byte
	alt []byte
	seq []byte

	outPos int
	outRef string
	outAlt string
}{
	{123, []byte{'C', 'A', 'C'}, []byte{'C'}, []byte("GGGCACACAC"), 118, "GCA", "G"},
	{123, []byte{'C', 'A', 'C'}, []byte{'C'}, []byte("CACACAC"), 119, "CAC", "C"},
	{123, []byte{'C', 'C', 'A'}, []byte{'C', 'A', 'A'}, []byte("ACCCCCCA"), 123, "CC", "CA"},
	{123, []byte{'C'}, []byte{'A'}, []byte("ACCCCCC"), 123, "C", "A"},
}

var lefttrimtests = []struct {
	pos int
	ref []byte
	alt []byte

	outPos int
	outRef string
	outAlt string
}{
	{123, []byte{'C', 'C'}, []byte{'C', 'A'}, 124, "C", "A"},
	{123, []byte{'C', 'C'}, []byte{'C', 'C', 'T'}, 124, "C", "CT"},
	{123, []byte{'C', 'C', 'C'}, []byte{'C', 'C', 'C', 'T'}, 125, "C", "CT"},
	{123, []byte{'C'}, []byte{'T'}, 123, "C", "T"},
}

func TestLeftAlign(t *testing.T) {

	for _, v := range leftaligntests {
		p, r, a, err := leftalign(v.pos, v.ref, v.alt, v.seq)

		if p != v.outPos {
			t.Errorf("position should be %d instead of %d\n", v.outPos, p)
		}
		if string(r) != v.outRef {
			t.Errorf("ref should be %s instead of %s\n", v.outRef, string(r))
		}
		if string(a) != v.outAlt {
			t.Errorf("alt should be '%s' instead of %s", v.outAlt, a)
		}
		if err != nil {
			t.Error(err)
		}
	}
}

func TestLeftTrim(t *testing.T) {

	for _, v := range lefttrimtests {
		p, r, a, err := lefttrim(v.pos, v.ref, v.alt)

		if p != v.outPos {
			t.Errorf("position should be %d instead of %d\n", v.outPos, p)
		}
		if string(r) != v.outRef {
			t.Errorf("ref should be %s instead of %s\n", v.outRef, string(r))
		}
		if string(a) != v.outAlt {
			t.Errorf("alt should be '%s' instead of %s", v.outAlt, a)
		}
		if err != nil {
			t.Error(err)
		}

	}
}