From: Ian Lance Taylor Date: Mon, 26 Nov 2012 16:31:15 +0000 (-0800) Subject: test: add test for floating point rounding of constants X-Git-Tag: go1.1rc2~1797 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=76fa4f430ad1768450dd052f0fefefba0cc022b7;p=gostls13.git test: add test for floating point rounding of constants Failed with gccgo. R=golang-dev, remyoudompheng, rsc CC=golang-dev https://golang.org/cl/6855053 --- diff --git a/test/fixedbugs/bug470.go b/test/fixedbugs/bug470.go new file mode 100644 index 0000000000..0a359184c6 --- /dev/null +++ b/test/fixedbugs/bug470.go @@ -0,0 +1,26 @@ +// run + +// Copyright 2012 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. + +// Converting constants between types must introduce rounding. + +package main + +import "fmt" + +const ( + F32 = 0.00999999977648258209228515625 + F64 = 0.01000000000000000020816681711721685132943093776702880859375 +) + +var F = float64(float32(0.01)) + +func main() { + // 0.01 rounded to float32 then to float64 is F32. + // 0.01 represented directly in float64 is F64. + if F != F32 { + panic(fmt.Sprintf("F=%.1000g, want %.1000g", F, F32)) + } +}