github.com/yanyiwu/go@v0.0.0-20150106053140-03d6637dbb7f/test/bigalg.go (about) 1 // run 2 3 // Copyright 2009 The Go Authors. All rights reserved. 4 // Use of this source code is governed by a BSD-style 5 // license that can be found in the LICENSE file. 6 7 // Test the internal "algorithms" for objects larger than a word: hashing, equality etc. 8 9 package main 10 11 type T struct { 12 a float64 13 b int64 14 c string 15 d byte 16 } 17 18 var a = []int{1, 2, 3} 19 var NIL []int 20 21 func arraycmptest() { 22 if NIL != nil { 23 println("fail1:", NIL, "!= nil") 24 panic("bigalg") 25 } 26 if nil != NIL { 27 println("fail2: nil !=", NIL) 28 panic("bigalg") 29 } 30 if a == nil || nil == a { 31 println("fail3:", a, "== nil") 32 panic("bigalg") 33 } 34 } 35 36 func SameArray(a, b []int) bool { 37 if len(a) != len(b) || cap(a) != cap(b) { 38 return false 39 } 40 if len(a) > 0 && &a[0] != &b[0] { 41 return false 42 } 43 return true 44 } 45 46 var t = T{1.5, 123, "hello", 255} 47 var mt = make(map[int]T) 48 var ma = make(map[int][]int) 49 50 func maptest() { 51 mt[0] = t 52 t1 := mt[0] 53 if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d { 54 println("fail: map val struct", t1.a, t1.b, t1.c, t1.d) 55 panic("bigalg") 56 } 57 58 ma[1] = a 59 a1 := ma[1] 60 if !SameArray(a, a1) { 61 println("fail: map val array", a, a1) 62 panic("bigalg") 63 } 64 } 65 66 var ct = make(chan T) 67 var ca = make(chan []int) 68 69 func send() { 70 ct <- t 71 ca <- a 72 } 73 74 func chantest() { 75 go send() 76 77 t1 := <-ct 78 if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d { 79 println("fail: map val struct", t1.a, t1.b, t1.c, t1.d) 80 panic("bigalg") 81 } 82 83 a1 := <-ca 84 if !SameArray(a, a1) { 85 println("fail: map val array", a, a1) 86 panic("bigalg") 87 } 88 } 89 90 type E struct{} 91 92 var e E 93 94 func interfacetest() { 95 var i interface{} 96 97 i = a 98 a1 := i.([]int) 99 if !SameArray(a, a1) { 100 println("interface <-> []int", a, a1) 101 panic("bigalg") 102 } 103 pa := new([]int) 104 *pa = a 105 i = pa 106 a1 = *i.(*[]int) 107 if !SameArray(a, a1) { 108 println("interface <-> *[]int", a, a1) 109 panic("bigalg") 110 } 111 112 i = t 113 t1 := i.(T) 114 if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d { 115 println("interface <-> struct", t1.a, t1.b, t1.c, t1.d) 116 panic("bigalg") 117 } 118 119 i = e 120 e1 := i.(E) 121 // nothing to check; just verify it doesn't crash 122 _ = e1 123 } 124 125 func main() { 126 arraycmptest() 127 maptest() 128 chantest() 129 interfacetest() 130 }