|  | // 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) | 
|  | } | 
|  | } |