numbers_test.go 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. // Copyright 2015 The go-ethereum Authors
  2. // This file is part of go-ethereum.
  3. //
  4. // go-ethereum is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // go-ethereum is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with go-ethereum. If not, see <http://www.gnu.org/licenses/>.
  16. package abi
  17. import (
  18. "bytes"
  19. "math/big"
  20. "reflect"
  21. "testing"
  22. )
  23. func TestNumberTypes(t *testing.T) {
  24. ubytes := make([]byte, 32)
  25. ubytes[31] = 1
  26. sbytesmin := []byte{1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
  27. unsigned := U256(big.NewInt(1))
  28. if !bytes.Equal(unsigned, ubytes) {
  29. t.Error("expected %x got %x", ubytes, unsigned)
  30. }
  31. signed := S256(big.NewInt(1))
  32. if !bytes.Equal(signed, ubytes) {
  33. t.Error("expected %x got %x", ubytes, unsigned)
  34. }
  35. signed = S256(big.NewInt(-1))
  36. if !bytes.Equal(signed, sbytesmin) {
  37. t.Error("expected %x got %x", ubytes, unsigned)
  38. }
  39. }
  40. func TestPackNumber(t *testing.T) {
  41. ubytes := make([]byte, 32)
  42. ubytes[31] = 1
  43. sbytesmin := []byte{1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
  44. maxunsigned := []byte{255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255}
  45. packed := packNum(reflect.ValueOf(1), IntTy)
  46. if !bytes.Equal(packed, ubytes) {
  47. t.Errorf("expected %x got %x", ubytes, packed)
  48. }
  49. packed = packNum(reflect.ValueOf(-1), IntTy)
  50. if !bytes.Equal(packed, sbytesmin) {
  51. t.Errorf("expected %x got %x", ubytes, packed)
  52. }
  53. packed = packNum(reflect.ValueOf(1), UintTy)
  54. if !bytes.Equal(packed, ubytes) {
  55. t.Errorf("expected %x got %x", ubytes, packed)
  56. }
  57. packed = packNum(reflect.ValueOf(-1), UintTy)
  58. if !bytes.Equal(packed, maxunsigned) {
  59. t.Errorf("expected %x got %x", maxunsigned, packed)
  60. }
  61. packed = packNum(reflect.ValueOf("string"), UintTy)
  62. if packed != nil {
  63. t.Errorf("expected 'string' to pack to nil. got %x instead", packed)
  64. }
  65. }
  66. func TestSigned(t *testing.T) {
  67. if isSigned(reflect.ValueOf(uint(10))) {
  68. t.Error()
  69. }
  70. if !isSigned(reflect.ValueOf(int(10))) {
  71. t.Error()
  72. }
  73. if !isSigned(reflect.ValueOf(big.NewInt(10))) {
  74. t.Error()
  75. }
  76. }