]> Cypherpunks repositories - gostls13.git/commitdiff
test: new test for issue 30908
authorThan McIntosh <thanm@google.com>
Fri, 22 Mar 2019 18:57:32 +0000 (14:57 -0400)
committerThan McIntosh <thanm@google.com>
Mon, 25 Mar 2019 15:00:08 +0000 (15:00 +0000)
New test case designed to mimic the code in issue 30908, which
features duplicate but non-indentical DWARF abstract subprogram DIEs.

Updates #30908.

Change-Id: Iacb4b53e6a988e46c801cdac236cef883c553f8f
Reviewed-on: https://go-review.googlesource.com/c/go/+/168957
Run-TryBot: Than McIntosh <thanm@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Cherry Zhang <cherryyz@google.com>
Reviewed-by: David Chase <drchase@google.com>
test/fixedbugs/issue30908.dir/a.go [new file with mode: 0644]
test/fixedbugs/issue30908.dir/b.go [new file with mode: 0644]
test/fixedbugs/issue30908.dir/m.go [new file with mode: 0644]
test/fixedbugs/issue30908.go [new file with mode: 0644]

diff --git a/test/fixedbugs/issue30908.dir/a.go b/test/fixedbugs/issue30908.dir/a.go
new file mode 100644 (file)
index 0000000..2f0abc3
--- /dev/null
@@ -0,0 +1,32 @@
+// Copyright 2019 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 a
+
+import (
+       "errors"
+       "strings"
+)
+
+var G interface{}
+
+func Unmarshal(data []byte, o interface{}) error {
+       G = o
+       v, ok := o.(*map[string]interface{})
+       if !ok {
+               return errors.New("eek")
+       }
+       vals := make(map[string]interface{})
+       s := string(data)
+       items := strings.Split(s, " ")
+       var err error
+       for _, item := range items {
+               vals[item] = s
+               if item == "error" {
+                       err = errors.New("ouch")
+               }
+       }
+       *v = vals
+       return err
+}
diff --git a/test/fixedbugs/issue30908.dir/b.go b/test/fixedbugs/issue30908.dir/b.go
new file mode 100644 (file)
index 0000000..2f54398
--- /dev/null
@@ -0,0 +1,35 @@
+// Copyright 2019 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 b
+
+import (
+       "io/ioutil"
+
+       "./a"
+)
+
+var G int
+
+// An inlinable function. To trigger the bug in question this needs
+// to be inlined here within the package and also inlined into some
+// other package that imports it.
+func ReadValues(data []byte) (vals map[string]interface{}, err error) {
+       err = a.Unmarshal(data, &vals)
+       if len(vals) == 0 {
+               vals = map[string]interface{}{}
+       }
+       return
+}
+
+// A local call to the function above, which triggers the "move to heap"
+// of the output param.
+func CallReadValues(filename string) (map[string]interface{}, error) {
+       defer func() { G++ }()
+       data, err := ioutil.ReadFile(filename)
+       if err != nil {
+               return map[string]interface{}{}, err
+       }
+       return ReadValues(data)
+}
diff --git a/test/fixedbugs/issue30908.dir/m.go b/test/fixedbugs/issue30908.dir/m.go
new file mode 100644 (file)
index 0000000..a170a6e
--- /dev/null
@@ -0,0 +1,21 @@
+// Copyright 2019 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 main
+
+import (
+       "os"
+
+       "./b"
+)
+
+func main() {
+       seed := "some things are better"
+       bsl := []byte(seed)
+       b.CallReadValues("/dev/null")
+       vals, err := b.ReadValues(bsl)
+       if vals["better"] != seed || err != nil {
+               os.Exit(1)
+       }
+}
diff --git a/test/fixedbugs/issue30908.go b/test/fixedbugs/issue30908.go
new file mode 100644 (file)
index 0000000..8863b39
--- /dev/null
@@ -0,0 +1,9 @@
+// rundir -P -l=4 -ldflags -strictdups=2
+
+// Copyright 2019 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.
+
+// +build !nacl,!js
+
+package ignored