blob: 56f5fb97c84ae625cc93cf5cd46a6d40c124a419 [file] [log] [blame]
// 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_test
import (
. "strconv";
"testing";
)
type itob64Test struct {
in int64;
base uint;
out string;
}
var itob64tests = []itob64Test {
itob64Test{ 0, 10, "0" },
itob64Test{ 1, 10, "1" },
itob64Test{ -1, 10, "-1" },
itob64Test{ 12345678, 10, "12345678" },
itob64Test{ -987654321, 10, "-987654321" },
itob64Test{ 1<<31-1, 10, "2147483647" },
itob64Test{ -1<<31+1, 10, "-2147483647" },
itob64Test{ 1<<31, 10, "2147483648" },
itob64Test{ -1<<31, 10, "-2147483648" },
itob64Test{ 1<<31+1, 10, "2147483649" },
itob64Test{ -1<<31-1, 10, "-2147483649" },
itob64Test{ 1<<32-1, 10, "4294967295" },
itob64Test{ -1<<32+1, 10, "-4294967295" },
itob64Test{ 1<<32, 10, "4294967296" },
itob64Test{ -1<<32, 10, "-4294967296" },
itob64Test{ 1<<32+1, 10, "4294967297" },
itob64Test{ -1<<32-1, 10, "-4294967297" },
itob64Test{ 1<<50, 10, "1125899906842624" },
itob64Test{ 1<<63-1, 10, "9223372036854775807" },
itob64Test{ -1<<63+1, 10, "-9223372036854775807" },
itob64Test{ -1<<63, 10, "-9223372036854775808" },
itob64Test{ 0, 2, "0" },
itob64Test{ 10, 2, "1010" },
itob64Test{ -1, 2, "-1" },
itob64Test{ 1<<15, 2, "1000000000000000" },
itob64Test{ -8, 8, "-10" },
itob64Test{ 057635436545, 8, "57635436545" },
itob64Test{ 1<<24, 8, "100000000" },
itob64Test{ 16, 16, "10" },
itob64Test{ -0x123456789abcdef, 16, "-123456789abcdef" },
itob64Test{ 1<<63-1, 16, "7fffffffffffffff" },
itob64Test{ 16, 17, "g" },
itob64Test{ 25, 25, "10" },
itob64Test{ (((((17*35+24)*35+21)*35+34)*35+12)*35+24)*35+32, 35, "holycow" },
itob64Test{ (((((17*36+24)*36+21)*36+34)*36+12)*36+24)*36+32, 36, "holycow" },
}
func TestItoa(t *testing.T) {
for _, test := range itob64tests {
s := Itob64(test.in, test.base);
if s != test.out {
t.Errorf("Itob64(%v, %v) = %v want %v\n",
test.in, test.base, s, test.out);
}
if test.in >= 0 {
s := Uitob64(uint64(test.in), test.base);
if s != test.out {
t.Errorf("Uitob64(%v, %v) = %v want %v\n",
test.in, test.base, s, test.out);
}
}
if int64(int(test.in)) == test.in {
s := Itob(int(test.in), test.base);
if s != test.out {
t.Errorf("Itob(%v, %v) = %v want %v\n",
test.in, test.base, s, test.out);
}
if test.in >= 0 {
s := Uitob(uint(test.in), test.base);
if s != test.out {
t.Errorf("Uitob(%v, %v) = %v want %v\n",
test.in, test.base, s, test.out);
}
}
}
if test.base == 10 {
s := Itoa64(test.in);
if s != test.out {
t.Errorf("Itoa64(%v) = %v want %v\n",
test.in, s, test.out);
}
if test.in >= 0 {
s := Uitob64(uint64(test.in), test.base);
if s != test.out {
t.Errorf("Uitob64(%v, %v) = %v want %v\n",
test.in, test.base, s, test.out);
}
}
if int64(int(test.in)) == test.in {
s := Itoa(int(test.in));
if s != test.out {
t.Errorf("Itoa(%v) = %v want %v\n",
test.in, s, test.out);
}
if test.in >= 0 {
s := Uitoa(uint(test.in));
if s != test.out {
t.Errorf("Uitoa(%v) = %v want %v\n",
test.in, s, test.out);
}
}
}
}
}
}
type uitob64Test struct {
in uint64;
base uint;
out string;
}
var uitob64tests = []uitob64Test {
uitob64Test{ 1<<63-1, 10, "9223372036854775807" },
uitob64Test{ 1<<63, 10, "9223372036854775808" },
uitob64Test{ 1<<63+1, 10, "9223372036854775809" },
uitob64Test{ 1<<64-2, 10, "18446744073709551614" },
uitob64Test{ 1<<64-1, 10, "18446744073709551615" },
}
func TestUitoa(t *testing.T) {
for _, test := range uitob64tests {
s := Uitob64(test.in, test.base);
if s != test.out {
t.Errorf("Uitob64(%v, %v) = %v want %v\n",
test.in, test.base, s, test.out);
}
if uint64(uint(test.in)) == test.in {
s := Uitob(uint(test.in), test.base);
if s != test.out {
t.Errorf("Uitob(%v, %v) = %v want %v\n",
test.in, test.base, s, test.out);
}
}
if test.base == 10 {
s := Uitoa64(test.in);
if s != test.out {
t.Errorf("Uitoa64(%v) = %v want %v\n",
test.in, s, test.out);
}
if uint64(uint(test.in)) == test.in {
s := Uitoa(uint(test.in));
if s != test.out {
t.Errorf("Uitoa(%v) = %v want %v\n",
test.in, s, test.out);
}
}
}
}
}