diff options
author | Rob Pike <r@golang.org> | 2008-07-08 12:22:21 -0700 |
---|---|---|
committer | Rob Pike <r@golang.org> | 2008-07-08 12:22:21 -0700 |
commit | 317756ffc773b42be493079a66cbe1e3694521e6 (patch) | |
tree | 9c82175e9d591f7613f8ce319c943d88d7960994 | |
parent | 15fb8aa10a824f36187d0b7874c765b797373d8b (diff) | |
download | golang-317756ffc773b42be493079a66cbe1e3694521e6.tar.gz |
test update. also remove two duplicates
SVN=126336
-rw-r--r-- | test/func.go | 36 | ||||
-rw-r--r-- | test/func1.go | 6 | ||||
-rw-r--r-- | test/golden.out | 6 | ||||
-rw-r--r-- | test/ken/robliteral.go | 220 | ||||
-rw-r--r-- | test/ken/robswitch.go | 131 | ||||
-rw-r--r-- | test/literal.go | 5 | ||||
-rw-r--r-- | test/switch.go | 14 |
7 files changed, 31 insertions, 387 deletions
diff --git a/test/func.go b/test/func.go index e5cb1e551..56d392b0c 100644 --- a/test/func.go +++ b/test/func.go @@ -54,13 +54,11 @@ func (t *T) m10(a int, b float) int { } -//BUG func f9(a int) (i int, f float) { // multiple returns not ready yet -// BUG funny return value -// var i float = 9; -// var f float = 9.0; -// return i, f; -// return -// } +func f9(a int) (i int, f float) { + i = 9; + f = 9.0; + return; +} func main() { @@ -74,21 +72,15 @@ func main() { assertequal(r5, 5, "5"); r6 := f6(1); assertequal(r6, 6, "6"); - var r7 int; - var s7 float; - //BUG r7, s7 = f7(1); - //BUG assertequal(r7, 7, "r7"); - //BUG assertequal(int(s7), 7, "s7"); - var r8 int; - var s8 float; - //BUG r8, s8 = f8(1); - //BUG assertequal(r8, 8, "r8"); - //BUG assertequal(int(s8), 8, "s8"); - var r9 int; - var s9 float; - //BUG r9, s9 = f9(1); - //BUG assertequal(r9, 9, "r9"); - //BUG assertequal(int(s9), 9, "s9"); + r7, s7 := f7(1); + assertequal(r7, 7, "r7"); + assertequal(int(s7), 7, "s7"); + r8, s8 := f8(1); + assertequal(r8, 8, "r8"); + assertequal(int(s8), 8, "s8"); + r9, s9 := f9(1); + assertequal(r9, 9, "r9"); + assertequal(int(s9), 9, "s9"); var t *T = new(T); t.x = 1; t.y = 2; diff --git a/test/func1.go b/test/func1.go index 2f92c35b7..895fe94b8 100644 --- a/test/func1.go +++ b/test/func1.go @@ -4,13 +4,15 @@ // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. +// does not compile and should not compile + package main -func f1(a int) (int, float) { // BUG multiple return values must have names +func f1(a int) (int, float) { // BUG (not caught by compiler): multiple return values must have names return 7, 7.0; } -func f2(a int) (a int, b float) { // BUG return value names must be different from parameter names +func f2(a int) (a int, b float) { // return value names must be different from parameter names return 8, 8.0; } diff --git a/test/golden.out b/test/golden.out index 7aca318be..be10993c7 100644 --- a/test/golden.out +++ b/test/golden.out @@ -49,6 +49,8 @@ BUG: known to fail incorrectly =========== ./turing.go Hello World! +=========== ./utf.go + =========== ken/for.go =========== ken/interfun.go @@ -80,10 +82,6 @@ Hello World! =========== ken/robiota.go -=========== ken/robliteral.go - -=========== ken/robswitch.go - =========== ken/simparray.go =========== ken/simpbool.go diff --git a/test/ken/robliteral.go b/test/ken/robliteral.go deleted file mode 100644 index 2a21a6bee..000000000 --- a/test/ken/robliteral.go +++ /dev/null @@ -1,220 +0,0 @@ -// 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. - -// $G $D/$F.go && $L $F.$A && ./$A.out - -package main - -var code int; - -func assert(cond bool, msg string) { - if !cond { - print "assertion fail: " + msg + "\n"; - code = 1; - //panic 1; this file has errors; print them all - } -} - -func main() { - code = 0; - - // bool - var t bool = true; - var f bool = false; - assert(t == !f, "bool"); - - // int8 - var i00 int8 = 0; - var i01 int8 = 1; - var i02 int8 = -1; - var i03 int8 = 127; - var i04 int8 = -127; - var i05 int8 = -128; - var i06 int8 = +127; - assert(i01 == i00 + 1, "i01"); - assert(i02 == -i01, "i02"); - assert(i03 == -i04, "i03"); - assert(-(i05+1) == i06, "i05"); - - // int16 - var i10 int16 = 0; - var i11 int16 = 1; - var i12 int16 = -1; - var i13 int16 = 32767; - var i14 int16 = -32767; - var i15 int16 = -32768; - var i16 int16 = +32767; - assert(i11 == i10 + 1, "i11"); - assert(i12 == -i11, "i12"); - assert(i13 == -i14, "i13"); - assert(-(i15+1) == i16, "i15"); - - // int32 - var i20 int32 = 0; - var i21 int32 = 1; - var i22 int32 = -1; - var i23 int32 = 2147483647; - var i24 int32 = -2147483647; - var i25 int32 = -2147483648; - var i26 int32 = +2147483647; - assert(i21 == i20 + 1, "i21"); - assert(i22 == -i21, "i22"); - assert(i23 == -i24, "i23"); - assert(-(i25+1) == i26, "i25"); - assert(i23 == (1 << 31) - 1, "i23 size"); - - // int64 - var i30 int64 = 0; - var i31 int64 = 1; - var i32 int64 = -1; - var i33 int64 = 9223372036854775807; // BUG? not sure these really work - var i34 int64 = -9223372036854775807; - var i35 int64 = -9223372036854775808; - var i36 int64 = +9223372036854775807; - assert(i31 == i30 + 1, "i31"); - assert(i32 == -i31, "i32"); - assert(i33 == -i34, "i33"); - assert(-(i35+1) == i36, "i35"); - assert(i33 == (1<<63) - 1, "i33 size"); - - // uint8 - var u00 uint8 = 0; - var u01 uint8 = 1; - var u02 uint8 = 255; - var u03 uint8 = +255; - assert(u01 == u00 + 1, "u01"); - assert(u02 == u03, "u02"); - assert(u03 == (1<<8) - 1, "u03 size"); - - // uint16 - var u10 uint16 = 0; - var u11 uint16 = 1; - var u12 uint16 = 65535; - var u13 uint16 = +65535; - assert(u11 == u10 + 1, "u11"); - assert(u12 == u13, "u12"); - - // uint32 - var u20 uint32 = 0; - var u21 uint32 = 1; - var u22 uint32 = 4294967295; - var u23 uint32 = +4294967295; - assert(u21 == u20 + 1, "u21"); - assert(u22 == u23, "u22"); - - // uint64 - var u30 uint64 = 0; - var u31 uint64 = 1; - var u32 uint64 = 18446744073709551615; - var u33 uint64 = +18446744073709551615; - - // float - var f00 float = 3.14159; - var f01 float = -3.14159; - var f02 float = +3.14159; - var f03 float = 0.0; - var f04 float = .0; - var f05 float = 0.; - var f06 float = -0.0; - var f07 float = 1e10; - var f08 float = -1e10; - var f09 float = 1e-10; - var f10 float = 1e+10; - var f11 float = 1.e-10; - var f12 float = 1.e+10; - var f13 float = .1e-10; - var f14 float = .1e+10; - var f15 float = 1.1e-10; - var f16 float = 1.1e+10; - assert(f01 == -f00, "f01"); - assert(f02 == -f01, "f02"); - assert(f03 == f04, "f03"); - assert(f04 == f05, "f04"); - assert(f05 == f06, "f05"); - assert(f07 == -f08, "f07"); - assert(f09 == 1/f10, "f09"); - assert(f11 == f09, "f11"); - assert(f12 == f10, "f12"); - assert(f13 == f09/10.0, "f13"); - assert(f14 == f12/10.0, "f14"); - assert(f15 == f16/1e20, "f15"); - - // character - var c0 uint8 = 'a'; - var c1 uint8 = 'ä'; - var c2 uint8 = '\a'; - var c3 uint8 = '\b'; - var c4 uint8 = '\f'; - var c5 uint8 = '\n'; - var c6 uint8 = '\r'; - var c7 uint8 = '\t'; - var c8 uint8 = '\v'; - // var c9 uint8 = '本'; // correctly caught as error - var c9 uint16 = '本'; - assert(c0 == 0x61, "c0"); - assert(c1 == 0xe4, "c1"); - assert(c2 == 0x07, "c2"); - assert(c3 == 0x08, "c3"); - assert(c4 == 0x0c, "c4"); - assert(c5 == 0x0a, "c4"); - assert(c6 == 0x0d, "c6"); - assert(c7 == 0x09, "c7"); - assert(c8 == 0x0b, "c8"); - assert(c9 == 0x672c, "c9"); - - - var c00 uint8 = '\000'; - var c01 uint8 = '\007'; - var c02 uint8 = '\177'; - var c03 uint8 = '\377'; - assert(c00 == 0, "c00"); - assert(c01 == 7, "c01"); - assert(c02 == 127, "c02"); - assert(c03 == 255, "c03"); - - var cx0 uint8 = '\x00'; - var cx1 uint8 = '\x0f'; - var cx2 uint8 = '\xff'; - assert(cx0 == 0, "cx0"); - assert(cx1 == 15, "cx1"); - assert(cx2 == 255, "cx2"); - - var cu0 uint16 = '\u1234'; - var cu1 uint32 = '\U00101234'; - assert(cu0 == 0x1234, "cu0"); - assert(cu1 == 0x101234, "cu1"); - - // string - var s0 string = ""; - var s1 string = "hellô"; - assert(s1[0] == 'h', "s1-0"); - assert(s1[4] == 0xc3, "s1-4"); - assert(s1[5] == 0xb4, "s1-5"); - var s2 string = "\a\b\f\n\r\t\v"; - - var s00 string = "\000"; - var s01 string = "\007"; - var s02 string = "\377"; - assert(s00[0] == 0, "s00"); - assert(s01[0] == 7, "s01"); - assert(s02[0] == 255, "s02"); - - var x00 string = "\x00"; - var x01 string = "\x0f"; - var x02 string = "\xff"; - assert(x00[0] == 0, "x00"); - assert(x01[0] == 15, "x01"); - assert(x02[0] == 255, "x02"); - - // these are all the same string - var sj0 string = "日本語"; - var sj1 string = "\u65e5\u672c\u8a9e"; - var sj2 string = "\U000065e5\U0000672c\U00008a9e"; - var sj3 string = "\xe6\x97\xa5\xe6\x9c\xac\xe8\xaa\x9e"; - assert(sj0 == sj1, "sj1"); - assert(sj0 == sj2, "sj2"); - assert(sj0 == sj3, "sj3"); - - sys.exit(code); -} diff --git a/test/ken/robswitch.go b/test/ken/robswitch.go deleted file mode 100644 index 26c2330d4..000000000 --- a/test/ken/robswitch.go +++ /dev/null @@ -1,131 +0,0 @@ -// 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. - -// $G $D/$F.go && $L $F.$A && ./$A.out - -package main - -func assert(cond bool, msg string) { - if !cond { - print "assertion fail: " + msg + "\n"; - panic 1; - } -} - -func main() { - i5 := 5; - i7 := 7; - - switch true { - case i5 < 5: assert(false, "<"); - case i5 == 5: assert(true, "!"); - case i5 > 5: assert(false, ">"); - } - - switch { - case i5 < 5: assert(false, "<"); - case i5 == 5: assert(true, "!"); - case i5 > 5: assert(false, ">"); - } - - switch x := 5; true { - case i5 < x: assert(false, "<"); - case i5 == x: assert(true, "!"); - case i5 > x: assert(false, ">"); - } - - switch x := 5; { - case i5 < x: assert(false, "<"); - case i5 == x: assert(true, "!"); - case i5 > x: assert(false, ">"); - } - - switch i5 { - case 0: assert(false, "0"); - case 1: assert(false, "1"); - case 2: assert(false, "2"); - case 3: assert(false, "3"); - case 4: assert(false, "4"); - case 5: assert(true, "5"); - case 6: assert(false, "6"); - case 7: assert(false, "7"); - case 8: assert(false, "8"); - case 9: assert(false, "9"); - default: assert(false, "default"); - } - - switch i5 { - case 0,1,2,3,4: assert(false, "4"); - case 5: assert(true, "5"); - case 6,7,8,9: assert(false, "9"); - default: assert(false, "default"); - } - - switch i5 { - case 0: - case 1: - case 2: - case 3: - case 4: assert(false, "4"); - case 5: assert(true, "5"); - case 6: - case 7: - case 8: - case 9: - default: assert(i5 == 5, "good"); - } - - switch i5 { - case 0: dummy := 0; fallthrough; - case 1: dummy := 0; fallthrough; - case 2: dummy := 0; fallthrough; - case 3: dummy := 0; fallthrough; - case 4: dummy := 0; assert(false, "4"); - case 5: dummy := 0; fallthrough; - case 6: dummy := 0; fallthrough; - case 7: dummy := 0; fallthrough; - case 8: dummy := 0; fallthrough; - case 9: dummy := 0; fallthrough; - default: dummy := 0; assert(i5 == 5, "good"); - } - - fired := 0; // BUG: should be able to use 'false' - switch i5 { - case 0: dummy := 0; fallthrough; // tests scoping of cases - case 1: dummy := 0; fallthrough; - case 2: dummy := 0; fallthrough; - case 3: dummy := 0; fallthrough; - case 4: dummy := 0; assert(false, "4"); - case 5: dummy := 0; fallthrough; - case 6: dummy := 0; fallthrough; - case 7: dummy := 0; fallthrough; - case 8: dummy := 0; fallthrough; - case 9: dummy := 0; fallthrough; - default: dummy := 0; fired = fired + 1; assert(i5 == 5, "good"); - } - assert(fired > 0, "fired"); - - count := 0; - switch i5 { - case 0: count = count + 1; fallthrough; - case 1: count = count + 1; fallthrough; - case 2: count = count + 1; fallthrough; - case 3: count = count + 1; fallthrough; - case 4: count = count + 1; assert(false, "4"); - case 5: count = count + 1; fallthrough; - case 6: count = count + 1; fallthrough; - case 7: count = count + 1; fallthrough; - case 8: count = count + 1; fallthrough; - case 9: count = count + 1; fallthrough; - default: assert(i5 == count, "good"); - } - assert(fired > 0, "fired"); - - fired = 0; - switch i := i5 + 2; i { - case i7: fired = 1; - default: assert(false, "fail"); - } - assert(fired == 1, "var"); -} diff --git a/test/literal.go b/test/literal.go index becca6f9a..6681243bd 100644 --- a/test/literal.go +++ b/test/literal.go @@ -63,7 +63,7 @@ func main() { var i30 int64 = 0; var i31 int64 = 1; var i32 int64 = -1; - var i33 int64 = 9223372036854775807; // BUG? not sure these really work + var i33 int64 = 9223372036854775807; var i34 int64 = -9223372036854775807; var i35 int64 = -9223372036854775808; var i36 int64 = +9223372036854775807; @@ -207,4 +207,7 @@ func main() { var sj1 string = "\u65e5\u672c\u8a9e"; var sj2 string = "\U000065e5\U0000672c\U00008a9e"; var sj3 string = "\xe6\x97\xa5\xe6\x9c\xac\xe8\xaa\x9e"; + assert(sj0 == sj1, "sj1"); + assert(sj0 == sj2, "sj2"); + assert(sj0 == sj3, "sj3"); } diff --git a/test/switch.go b/test/switch.go index 5fb80c497..af1dc8fb9 100644 --- a/test/switch.go +++ b/test/switch.go @@ -91,7 +91,7 @@ func main() { default: dummy := 0; assert(i5 == 5, "good"); } - fired := 0; // BUG: should be able to use 'false' + fired := false; switch i5 { case 0: dummy := 0; fallthrough; // tests scoping of cases case 1: dummy := 0; fallthrough; @@ -103,9 +103,9 @@ func main() { case 7: dummy := 0; fallthrough; case 8: dummy := 0; fallthrough; case 9: dummy := 0; fallthrough; - default: dummy := 0; fired = fired + 1; assert(i5 == 5, "good"); + default: dummy := 0; fired = !fired; assert(i5 == 5, "good"); } - assert(fired > 0, "fired"); + assert(fired, "fired"); count := 0; switch i5 { @@ -121,7 +121,7 @@ func main() { case 9: count = count + 1; fallthrough; default: assert(i5 == count, "good"); } - assert(fired > 0, "fired"); + assert(fired, "fired"); switch hello { case "wowie": assert(false, "wowie"); @@ -130,10 +130,10 @@ func main() { default: assert(false, "default"); } - fired = 0; + fired = false; switch i := i5 + 2; i { - case i7: fired = 1; + case i7: fired = true; default: assert(false, "fail"); } - assert(fired == 1, "var"); + assert(fired, "var"); } |