Commit 34305993 authored by David Symonds's avatar David Symonds

debug/gosym: Remove Makefile, rewrite test using go tool.

Update #2573.

R=r
CC=golang-dev
https://golang.org/cl/5656071
parent 8bb7f779
# Copyright 2009 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.
include ../../../Make.inc
TARG=debug/gosym
GOFILES=\
pclntab.go\
symtab.go\
include ../../../Make.pkg
test: make-pclinetest
testshort: make-pclinetest
make-pclinetest:
@if [ "`uname`-`uname -m`" = Linux-x86_64 -a $(GOARCH) = amd64 ]; then mkdir -p _test && $(AS) pclinetest.s && $(LD) -E main -o _test/pclinetest pclinetest.$O; fi
// +build ignore
TEXT linefrompc(SB),7,$0 // Each byte stores its line delta TEXT linefrompc(SB),7,$0 // Each byte stores its line delta
BYTE $2; BYTE $2;
BYTE $1; BYTE $1;
......
...@@ -7,14 +7,31 @@ package gosym ...@@ -7,14 +7,31 @@ package gosym
import ( import (
"debug/elf" "debug/elf"
"os" "os"
"os/exec"
"runtime" "runtime"
"strings"
"testing" "testing"
) )
var pclinetestBinary string
func dotest() bool { func dotest() bool {
// For now, only works on ELF platforms. // For now, only works on ELF platforms.
// TODO: convert to work with new go tool if runtime.GOOS != "linux" || runtime.GOARCH != "amd64" {
return false && runtime.GOOS == "linux" && runtime.GOARCH == "amd64" return false
}
if pclinetestBinary != "" {
return true
}
// This command builds pclinetest from pclinetest.asm;
// the resulting binary looks like it was built from pclinetest.s,
// but we have renamed it to keep it away from the go tool.
pclinetestBinary = os.TempDir() + "/pclinetest"
cmd := exec.Command("sh", "-c", "go tool 6a pclinetest.asm && go tool 6l -E main -o "+pclinetestBinary+" pclinetest.6")
if err := cmd.Run(); err != nil {
panic(err)
}
return true
} }
func getTable(t *testing.T) *Table { func getTable(t *testing.T) *Table {
...@@ -149,7 +166,7 @@ func TestPCLine(t *testing.T) { ...@@ -149,7 +166,7 @@ func TestPCLine(t *testing.T) {
return return
} }
f, tab := crack("_test/pclinetest", t) f, tab := crack(pclinetestBinary, t)
text := f.Section(".text") text := f.Section(".text")
textdat, err := text.Data() textdat, err := text.Data()
if err != nil { if err != nil {
...@@ -163,10 +180,13 @@ func TestPCLine(t *testing.T) { ...@@ -163,10 +180,13 @@ func TestPCLine(t *testing.T) {
file, line, fn := tab.PCToLine(pc) file, line, fn := tab.PCToLine(pc)
off := pc - text.Addr // TODO(rsc): should not need off; bug in 8g off := pc - text.Addr // TODO(rsc): should not need off; bug in 8g
wantLine += int(textdat[off]) wantLine += int(textdat[off])
t.Logf("off is %d", off)
if fn == nil { if fn == nil {
t.Errorf("failed to get line of PC %#x", pc) t.Errorf("failed to get line of PC %#x", pc)
} else if len(file) < 12 || file[len(file)-12:] != "pclinetest.s" || line != wantLine || fn != sym { } else if !strings.HasSuffix(file, "pclinetest.s") {
t.Errorf("expected %s:%d (%s) at PC %#x, got %s:%d (%s)", "pclinetest.s", wantLine, sym.Name, pc, file, line, fn.Name) t.Errorf("expected %s (%s) at PC %#x, got %s (%s)", "pclinetest.s", sym.Name, pc, file, fn.Name)
} else if line != wantLine || fn != sym {
t.Errorf("expected :%d (%s) at PC %#x, got :%d (%s)", wantLine, sym.Name, pc, line, fn.Name)
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment