summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Griesemer <gri@golang.org>2009-05-05 17:05:58 -0700
committerRobert Griesemer <gri@golang.org>2009-05-05 17:05:58 -0700
commit53e093ac4ce25c5e138cc56f0769aa4d9c112c0a (patch)
treeda7f41930acbe1999c916bcd911cf7064bb20176
parentb6708b2dad4af458e69fde7fc596ecdce03280d0 (diff)
downloadgolang-53e093ac4ce25c5e138cc56f0769aa4d9c112c0a.tar.gz
wrong type used for dynamic type test
R=r DELTA=40 (40 added, 0 deleted, 0 changed) OCL=28308 CL=28311
-rw-r--r--test/bugs/bug148.go39
-rw-r--r--test/golden.out5
2 files changed, 44 insertions, 0 deletions
diff --git a/test/bugs/bug148.go b/test/bugs/bug148.go
new file mode 100644
index 000000000..daedff105
--- /dev/null
+++ b/test/bugs/bug148.go
@@ -0,0 +1,39 @@
+// $G $D/$F.go && $L $F.$A && ! ./$A.out || echo BUG: should crash
+
+// 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.
+
+package main
+
+type T struct {a, b int};
+
+func f(x interface{}) interface{} {
+ type T struct {a, b int};
+
+ if x == nil {
+ return T{2, 3};
+ }
+
+ t := x.(T);
+ println(t.a, t.b);
+ return x;
+}
+
+func main() {
+ inner_T := f(nil);
+ f(inner_T);
+
+ outer_T := T{5, 7};
+ f(outer_T);
+}
+
+/*
+This prints:
+
+2 3
+5 7
+
+but it should crash: The type assertion on line 14 should fail
+for the 2nd call to f with outer_T.
+*/
diff --git a/test/golden.out b/test/golden.out
index 223aa9614..1998061ff 100644
--- a/test/golden.out
+++ b/test/golden.out
@@ -96,6 +96,11 @@ bugs/bug140.go:6: syntax error near L1
bugs/bug140.go:7: syntax error near L2
BUG should compile
+=========== bugs/bug148.go
+2 3
+5 7
+BUG: should crash
+
=========== fixedbugs/bug016.go
fixedbugs/bug016.go:7: constant -3 overflows uint