github.com/peggyl/go@v0.0.0-20151008231540-ae315999c2d5/src/strconv/decimal_test.go (about)

     1  // Copyright 2009 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 strconv_test
     6  
     7  import (
     8  	. "strconv"
     9  	"testing"
    10  )
    11  
    12  type shiftTest struct {
    13  	i     uint64
    14  	shift int
    15  	out   string
    16  }
    17  
    18  var shifttests = []shiftTest{
    19  	{0, -100, "0"},
    20  	{0, 100, "0"},
    21  	{1, 100, "1267650600228229401496703205376"},
    22  	{1, -100,
    23  		"0.00000000000000000000000000000078886090522101180541" +
    24  			"17285652827862296732064351090230047702789306640625",
    25  	},
    26  	{12345678, 8, "3160493568"},
    27  	{12345678, -8, "48225.3046875"},
    28  	{195312, 9, "99999744"},
    29  	{1953125, 9, "1000000000"},
    30  }
    31  
    32  func TestDecimalShift(t *testing.T) {
    33  	for i := 0; i < len(shifttests); i++ {
    34  		test := &shifttests[i]
    35  		d := NewDecimal(test.i)
    36  		d.Shift(test.shift)
    37  		s := d.String()
    38  		if s != test.out {
    39  			t.Errorf("Decimal %v << %v = %v, want %v",
    40  				test.i, test.shift, s, test.out)
    41  		}
    42  	}
    43  }
    44  
    45  type roundTest struct {
    46  	i               uint64
    47  	nd              int
    48  	down, round, up string
    49  	int             uint64
    50  }
    51  
    52  var roundtests = []roundTest{
    53  	{0, 4, "0", "0", "0", 0},
    54  	{12344999, 4, "12340000", "12340000", "12350000", 12340000},
    55  	{12345000, 4, "12340000", "12340000", "12350000", 12340000},
    56  	{12345001, 4, "12340000", "12350000", "12350000", 12350000},
    57  	{23454999, 4, "23450000", "23450000", "23460000", 23450000},
    58  	{23455000, 4, "23450000", "23460000", "23460000", 23460000},
    59  	{23455001, 4, "23450000", "23460000", "23460000", 23460000},
    60  
    61  	{99994999, 4, "99990000", "99990000", "100000000", 99990000},
    62  	{99995000, 4, "99990000", "100000000", "100000000", 100000000},
    63  	{99999999, 4, "99990000", "100000000", "100000000", 100000000},
    64  
    65  	{12994999, 4, "12990000", "12990000", "13000000", 12990000},
    66  	{12995000, 4, "12990000", "13000000", "13000000", 13000000},
    67  	{12999999, 4, "12990000", "13000000", "13000000", 13000000},
    68  }
    69  
    70  func TestDecimalRound(t *testing.T) {
    71  	for i := 0; i < len(roundtests); i++ {
    72  		test := &roundtests[i]
    73  		d := NewDecimal(test.i)
    74  		d.RoundDown(test.nd)
    75  		s := d.String()
    76  		if s != test.down {
    77  			t.Errorf("Decimal %v RoundDown %d = %v, want %v",
    78  				test.i, test.nd, s, test.down)
    79  		}
    80  		d = NewDecimal(test.i)
    81  		d.Round(test.nd)
    82  		s = d.String()
    83  		if s != test.round {
    84  			t.Errorf("Decimal %v Round %d = %v, want %v",
    85  				test.i, test.nd, s, test.down)
    86  		}
    87  		d = NewDecimal(test.i)
    88  		d.RoundUp(test.nd)
    89  		s = d.String()
    90  		if s != test.up {
    91  			t.Errorf("Decimal %v RoundUp %d = %v, want %v",
    92  				test.i, test.nd, s, test.up)
    93  		}
    94  	}
    95  }
    96  
    97  type roundIntTest struct {
    98  	i     uint64
    99  	shift int
   100  	int   uint64
   101  }
   102  
   103  var roundinttests = []roundIntTest{
   104  	{0, 100, 0},
   105  	{512, -8, 2},
   106  	{513, -8, 2},
   107  	{640, -8, 2},
   108  	{641, -8, 3},
   109  	{384, -8, 2},
   110  	{385, -8, 2},
   111  	{383, -8, 1},
   112  	{1, 100, 1<<64 - 1},
   113  	{1000, 0, 1000},
   114  }
   115  
   116  func TestDecimalRoundedInteger(t *testing.T) {
   117  	for i := 0; i < len(roundinttests); i++ {
   118  		test := roundinttests[i]
   119  		d := NewDecimal(test.i)
   120  		d.Shift(test.shift)
   121  		int := d.RoundedInteger()
   122  		if int != test.int {
   123  			t.Errorf("Decimal %v >> %v RoundedInteger = %v, want %v",
   124  				test.i, test.shift, int, test.int)
   125  		}
   126  	}
   127  }