2014-08-04 23:02:08 +00:00
|
|
|
package frame
|
|
|
|
|
|
|
|
import (
|
2014-09-19 04:00:41 +00:00
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
2014-08-04 23:02:08 +00:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestFDEForPC(t *testing.T) {
|
2014-10-11 06:05:27 +00:00
|
|
|
fde1 := &FrameDescriptionEntry{begin: 100, end: 200}
|
|
|
|
fde2 := &FrameDescriptionEntry{begin: 50, end: 99}
|
|
|
|
fde3 := &FrameDescriptionEntry{begin: 0, end: 49}
|
|
|
|
fde4 := &FrameDescriptionEntry{begin: 201, end: 245}
|
2014-08-04 23:02:08 +00:00
|
|
|
|
|
|
|
tree := NewFrameIndex()
|
|
|
|
tree.Put(fde1)
|
|
|
|
tree.Put(fde2)
|
|
|
|
tree.Put(fde3)
|
|
|
|
tree.Put(fde4)
|
|
|
|
|
2014-08-07 16:03:42 +00:00
|
|
|
node, ok := tree.Find(Addr(35))
|
2014-08-04 23:02:08 +00:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("Could not find FDE")
|
|
|
|
}
|
|
|
|
|
2014-08-07 16:03:42 +00:00
|
|
|
if node != fde3 {
|
2014-08-04 23:02:08 +00:00
|
|
|
t.Fatal("Got incorrect fde")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkFDEForPC(b *testing.B) {
|
2014-09-19 04:00:41 +00:00
|
|
|
f, err := os.Open("testdata/frame")
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
defer f.Close()
|
2014-08-04 23:02:08 +00:00
|
|
|
|
2014-09-19 04:00:41 +00:00
|
|
|
data, err := ioutil.ReadAll(f)
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
fdes := Parse(data)
|
2014-08-04 23:02:08 +00:00
|
|
|
|
|
|
|
for i := 0; i < b.N; i++ {
|
2014-09-19 04:00:41 +00:00
|
|
|
// bench worst case, exhaustive search
|
|
|
|
_, _ = fdes.FDEForPC(0x455555555)
|
2014-08-04 23:02:08 +00:00
|
|
|
}
|
|
|
|
}
|