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