// Copyright (c) 2017, Google Inc. // // Permission to use, copy, modify, and/or distribute this software for any // purpose with or without fee is hereby granted, provided that the above // copyright notice and this permission notice appear in all copies. // // THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES // WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY // SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES // WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION // OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN // CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ package main import ( "bytes" "flag" "io/ioutil" "path/filepath" "testing" ) var ( testDataDir = flag.String("testdata", "testdata", "The path to the test data directory.") update = flag.Bool("update", false, "If true, update output files rather than compare them.") ) type delocateTest struct { name string in []string out string } func (test *delocateTest) Path(file string) string { return filepath.Join(*testDataDir, test.name, file) } var delocateTests = []delocateTest{ {"ppc64le-GlobalEntry", []string{"in.s"}, "out.s"}, {"ppc64le-LoadToR0", []string{"in.s"}, "out.s"}, {"ppc64le-Sample2", []string{"in.s"}, "out.s"}, {"ppc64le-Sample", []string{"in.s"}, "out.s"}, {"ppc64le-TOCWithOffset", []string{"in.s"}, "out.s"}, {"x86_64-Basic", []string{"in.s"}, "out.s"}, {"x86_64-BSS", []string{"in.s"}, "out.s"}, {"x86_64-GOTRewrite", []string{"in.s"}, "out.s"}, {"x86_64-LabelRewrite", []string{"in1.s", "in2.s"}, "out.s"}, {"x86_64-Sections", []string{"in.s"}, "out.s"}, } func TestDelocate(t *testing.T) { for _, test := range delocateTests { t.Run(test.name, func(t *testing.T) { var inputs []inputFile for i, in := range test.in { inputs = append(inputs, inputFile{ index: i, path: test.Path(in), }) } if err := parseInputs(inputs); err != nil { t.Fatalf("parseInputs failed: %s", err) } var buf bytes.Buffer if err := transform(&buf, inputs); err != nil { t.Fatalf("transform failed: %s", err) } if *update { ioutil.WriteFile(test.Path(test.out), buf.Bytes(), 0666) } else { expected, err := ioutil.ReadFile(test.Path(test.out)) if err != nil { t.Fatalf("could not read %q: %s", test.Path(test.out), err) } if !bytes.Equal(buf.Bytes(), expected) { t.Errorf("delocated output differed. Wanted:\n%s\nGot:\n%s\n", expected, buf.Bytes()) } } }) } }