diff options
Diffstat (limited to 'src/lib/strconv/testdecimal.go')
-rw-r--r-- | src/lib/strconv/testdecimal.go | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/src/lib/strconv/testdecimal.go b/src/lib/strconv/testdecimal.go new file mode 100644 index 000000000..767701f15 --- /dev/null +++ b/src/lib/strconv/testdecimal.go @@ -0,0 +1,128 @@ +// 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 strconv + +import ( + "fmt"; + "strconv" +) + +type ShiftTest struct { + i uint64; + shift int; + out string; +} + +var shifttests = []ShiftTest { + ShiftTest{ 0, -100, "0" }, + ShiftTest{ 0, 100, "0" }, + ShiftTest{ 1, 100, "1267650600228229401496703205376" }, + ShiftTest{ 1, -100, + "0.00000000000000000000000000000078886090522101180541" + "17285652827862296732064351090230047702789306640625" }, + ShiftTest{ 12345678, 8, "3160493568" }, + ShiftTest{ 12345678, -8, "48225.3046875" }, + ShiftTest{ 195312, 9, "99999744" }, + ShiftTest{ 1953125, 9, "1000000000" }, +} + +export func TestDecimalShift() bool { + ok := true; + for i := 0; i < len(shifttests); i++ { + t := &shifttests[i]; + s := strconv.NewDecimal(t.i).Shift(t.shift).String(); + if s != t.out { + fmt.printf("Decimal %v << %v = %v, want %v\n", + t.i, t.shift, s, t.out); + ok = false; + } + } + return ok; +} + +type RoundTest struct { + i uint64; + nd int; + down, round, up string; + int uint64; +} + +var roundtests = []RoundTest { + RoundTest{ 0, 4, "0", "0", "0", 0 }, + RoundTest{ 12344999, 4, "12340000", "12340000", "12350000", 12340000 }, + RoundTest{ 12345000, 4, "12340000", "12340000", "12350000", 12340000 }, + RoundTest{ 12345001, 4, "12340000", "12350000", "12350000", 12350000 }, + RoundTest{ 23454999, 4, "23450000", "23450000", "23460000", 23450000 }, + RoundTest{ 23455000, 4, "23450000", "23460000", "23460000", 23460000 }, + RoundTest{ 23455001, 4, "23450000", "23460000", "23460000", 23460000 }, + + RoundTest{ 99994999, 4, "99990000", "99990000", "100000000", 99990000 }, + RoundTest{ 99995000, 4, "99990000", "100000000", "100000000", 100000000 }, + RoundTest{ 99999999, 4, "99990000", "100000000", "100000000", 100000000 }, + + RoundTest{ 12994999, 4, "12990000", "12990000", "13000000", 12990000 }, + RoundTest{ 12995000, 4, "12990000", "13000000", "13000000", 13000000 }, + RoundTest{ 12999999, 4, "12990000", "13000000", "13000000", 13000000 }, +} + +export func TestDecimalRound() bool { + ok := true; + for i := 0; i < len(roundtests); i++ { + t := &roundtests[i]; + s := strconv.NewDecimal(t.i).RoundDown(t.nd).String(); + if s != t.down { + fmt.printf("Decimal %v RoundDown %d = %v, want %v\n", + t.i, t.nd, s, t.down); + ok = false; + } + s = strconv.NewDecimal(t.i).Round(t.nd).String(); + if s != t.round { + fmt.printf("Decimal %v Round %d = %v, want %v\n", + t.i, t.nd, s, t.down); + ok = false; + } + s = strconv.NewDecimal(t.i).RoundUp(t.nd).String(); + if s != t.up { + fmt.printf("Decimal %v RoundUp %d = %v, want %v\n", + t.i, t.nd, s, t.up); + ok = false; + } + } + return ok; +} + +type RoundIntTest struct { + i uint64; + shift int; + int uint64; +} + +var roundinttests = []RoundIntTest { + RoundIntTest{ 0, 100, 0 }, + RoundIntTest{ 512, -8, 2 }, + RoundIntTest{ 513, -8, 2 }, + RoundIntTest{ 640, -8, 2 }, + RoundIntTest{ 641, -8, 3 }, + RoundIntTest{ 384, -8, 2 }, + RoundIntTest{ 385, -8, 2 }, + RoundIntTest{ 383, -8, 1 }, + RoundIntTest{ 1, 100, 1<<64-1 }, + RoundIntTest{ 1000, 0, 1000 }, +} + +export func TestDecimalRoundedInteger() bool { + ok := true; + for i := 0; i < len(roundinttests); i++ { + t := roundinttests[i]; + // TODO: should be able to use int := here. + int1 := strconv.NewDecimal(t.i).Shift(t.shift).RoundedInteger(); + if int1 != t.int { + fmt.printf("Decimal %v >> %v RoundedInteger = %v, want %v\n", + t.i, t.shift, int1, t.int); + ok = false; + } + } + return ok; +} |