github.com/gagliardetto/golang-go@v0.0.0-20201020153340-53909ea70814/cmd/compile/internal/gc/testdata/sqrtConst_test.go (about) 1 // Copyright 2016 The Go Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style 3 // license that can be found in the LICENSE file. 4 5 package main 6 7 import ( 8 "math" 9 "testing" 10 ) 11 12 var tests = [...]struct { 13 name string 14 in float64 // used for error messages, not an input 15 got float64 16 want float64 17 }{ 18 {"sqrt0", 0, math.Sqrt(0), 0}, 19 {"sqrt1", 1, math.Sqrt(1), 1}, 20 {"sqrt2", 2, math.Sqrt(2), math.Sqrt2}, 21 {"sqrt4", 4, math.Sqrt(4), 2}, 22 {"sqrt100", 100, math.Sqrt(100), 10}, 23 {"sqrt101", 101, math.Sqrt(101), 10.04987562112089}, 24 } 25 26 var nanTests = [...]struct { 27 name string 28 in float64 // used for error messages, not an input 29 got float64 30 }{ 31 {"sqrtNaN", math.NaN(), math.Sqrt(math.NaN())}, 32 {"sqrtNegative", -1, math.Sqrt(-1)}, 33 {"sqrtNegInf", math.Inf(-1), math.Sqrt(math.Inf(-1))}, 34 } 35 36 func TestSqrtConst(t *testing.T) { 37 for _, test := range tests { 38 if test.got != test.want { 39 t.Errorf("%s: math.Sqrt(%f): got %f, want %f\n", test.name, test.in, test.got, test.want) 40 } 41 } 42 for _, test := range nanTests { 43 if math.IsNaN(test.got) != true { 44 t.Errorf("%s: math.Sqrt(%f): got %f, want NaN\n", test.name, test.in, test.got) 45 } 46 } 47 if got := math.Sqrt(math.Inf(1)); !math.IsInf(got, 1) { 48 t.Errorf("math.Sqrt(+Inf), got %f, want +Inf\n", got) 49 } 50 }