blob: 1aa114cae35566165b44df3d9450e99e10275fbd [file] [log] [blame]
package gccgoexportdata_test
import (
"go/types"
"os"
"testing"
"golang.org/x/tools/go/gccgoexportdata"
)
// Test ensures this package can read gccgo export data from the
// .go_export from a standalone ELF file or such a file in an archive
// library.
//
// The testdata/{short,long}.a ELF archive files were produced by:
//
// $ echo 'package foo; func F()' > foo.go
// $ gccgo -c -fgo-pkgpath blah foo.go
// $ objcopy -j .go_export foo.o foo.gox
// $ ar q short.a foo.gox
// $ objcopy -j .go_export foo.o name-longer-than-16-bytes.gox
// $ ar q long.a name-longer-than-16-bytes.gox
//
// The file long.a contains an archive string table.
//
// The errors.gox file (an ELF object file) comes from the toolchain's
// standard library.
func Test(t *testing.T) {
for _, test := range []struct {
filename, path, member, wantType string
}{
{"testdata/errors.gox", "errors", "New", "func(text string) error"},
{"testdata/short.a", "short", "F", "func()"},
{"testdata/long.a", "long", "F", "func()"},
} {
t.Logf("filename = %s", test.filename)
f, err := os.Open(test.filename)
if err != nil {
t.Error(err)
continue
}
defer f.Close()
r, err := gccgoexportdata.NewReader(f)
if err != nil {
t.Error(err)
continue
}
imports := make(map[string]*types.Package)
pkg, err := gccgoexportdata.Read(r, nil, imports, test.path)
if err != nil {
t.Error(err)
continue
}
// Check type of designated package member.
obj := pkg.Scope().Lookup(test.member)
if obj == nil {
t.Errorf("%s.%s not found", test.path, test.member)
continue
}
if obj.Type().String() != test.wantType {
t.Errorf("%s.%s.Type = %s, want %s",
test.path, test.member, obj.Type(), test.wantType)
}
}
}