| // Copyright 2020 The Go 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 dwarf |
| |
| import ( |
| "encoding/binary" |
| "os" |
| "reflect" |
| "testing" |
| ) |
| |
| func TestDwarf5Ranges(t *testing.T) { |
| rngLists, err := os.ReadFile("testdata/debug_rnglists") |
| if err != nil { |
| t.Fatalf("could not read test data: %v", err) |
| } |
| |
| d := &Data{} |
| d.order = binary.LittleEndian |
| if err := d.AddSection(".debug_rnglists", rngLists); err != nil { |
| t.Fatal(err) |
| } |
| u := &unit{ |
| asize: 8, |
| vers: 5, |
| is64: true, |
| } |
| ret, err := d.dwarf5Ranges(u, nil, 0x5fbd, 0xc, [][2]uint64{}) |
| if err != nil { |
| t.Fatalf("could not read rnglist: %v", err) |
| } |
| t.Logf("%#v", ret) |
| |
| tgt := [][2]uint64{{0x0000000000006712, 0x000000000000679f}, {0x00000000000067af}, {0x00000000000067b3}} |
| |
| if reflect.DeepEqual(ret, tgt) { |
| t.Errorf("expected %#v got %#x", tgt, ret) |
| } |
| } |