/test/lib/numeric/mutable_big_integer/test_mutable_big_integer2.e

http://github.com/tybor/Liberty · Specman e · 122 lines · 91 code · 7 blank · 24 comment · 1 complexity · b29ba5cba710ffb7202235372f5a3a7f MD5 · raw file

  1. -- This file is part of SmartEiffel The GNU Eiffel Compiler Tools and Libraries.
  2. -- See the Copyright notice at the end of this file.
  3. --
  4. class TEST_MUTABLE_BIG_INTEGER2
  5. --
  6. -- Testing from_integer_64/to_integer_64/is_integer_64/is_zero
  7. --
  8. insert
  9. ANY
  10. PLATFORM
  11. create {}
  12. make
  13. feature {ANY}
  14. make
  15. local
  16. mbi1: MUTABLE_BIG_INTEGER; v: INTEGER_64
  17. do
  18. mbi1 := create {MUTABLE_BIG_INTEGER}.from_integer_64(0)
  19. create mbi1.from_integer_64(0)
  20. assert(mbi1.is_integer_64)
  21. assert(mbi1.is_zero)
  22. assert(mbi1.to_string.is_equal("0"))
  23. create mbi1.from_integer_64(2)
  24. assert(mbi1.to_integer_64 = 2)
  25. assert(not mbi1.is_zero)
  26. create mbi1.from_integer_64(1)
  27. assert(mbi1.to_integer_64 = 1)
  28. assert(not mbi1.is_zero)
  29. create mbi1.from_integer_64(-1)
  30. assert(mbi1.to_integer_64 = -1)
  31. assert(not mbi1.is_zero)
  32. create mbi1.from_integer_64(-2)
  33. assert(mbi1.to_integer_64 = -2)
  34. assert(not mbi1.is_zero)
  35. create mbi1.from_integer_64(Maximum_integer_64)
  36. assert(mbi1.to_integer_64 = Maximum_integer_64)
  37. assert(not mbi1.is_zero)
  38. create mbi1.from_integer_64(Minimum_integer_64)
  39. assert(mbi1.to_integer_64 = Minimum_integer_64)
  40. assert(not mbi1.is_zero)
  41. v := Minimum_integer_64 + 1
  42. create mbi1.from_integer_64(v)
  43. assert(mbi1.to_integer_64 = v)
  44. assert(not mbi1.is_zero)
  45. v := Maximum_integer_64 - 1
  46. create mbi1.from_integer_64(v)
  47. assert(mbi1.to_integer_64 = v)
  48. assert(not mbi1.is_zero)
  49. create mbi1.from_integer_64(Maximum_integer)
  50. assert(mbi1.to_integer_64 = Maximum_integer)
  51. assert(not mbi1.is_zero)
  52. create mbi1.from_integer_64(Minimum_integer)
  53. assert(mbi1.to_integer_64 = Minimum_integer)
  54. assert(not mbi1.is_zero)
  55. v := Minimum_integer + 1
  56. create mbi1.from_integer_64(v)
  57. assert(mbi1.to_integer_64 = v)
  58. assert(not mbi1.is_zero)
  59. v := Maximum_integer - 1
  60. create mbi1.from_integer_64(v)
  61. assert(mbi1.to_integer_64 = v)
  62. assert(not mbi1.is_zero)
  63. check_range(Minimum_integer_64, -9223372036854775800)
  64. check_range(-2147483680, -2147483600)
  65. check_range(-128, 128)
  66. check_range(2147483600, 2147483680)
  67. check_range(9223372036854775800, Maximum_integer_64)
  68. end
  69. count: INTEGER
  70. assert (b: BOOLEAN)
  71. do
  72. count := count + 1
  73. if not b then
  74. sedb_breakpoint
  75. io.put_string("TEST_MUTABLE_BIG_INTEGER2 : ERROR Test # ")
  76. io.put_integer(count)
  77. io.put_string("%N")
  78. end
  79. end
  80. check_range (min, max: INTEGER_64)
  81. require
  82. min < max
  83. local
  84. i, mem: INTEGER_64; mbi: MUTABLE_BIG_INTEGER
  85. do
  86. from
  87. i := min
  88. until
  89. i = max
  90. loop
  91. mem := i
  92. create mbi.from_integer_64(mem)
  93. assert(mem = mbi.to_integer_64)
  94. i := i + 1
  95. end
  96. end
  97. end -- class TEST_MUTABLE_BIG_INTEGER2
  98. --
  99. -- ------------------------------------------------------------------------------------------------------------------------------
  100. -- Copyright notice below. Please read.
  101. --
  102. -- SmartEiffel is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License,
  103. -- as published by the Free Software Foundation; either version 2, or (at your option) any later version.
  104. -- SmartEiffel is distributed in the hope that it will be useful but WITHOUT ANY WARRANTY; without even the implied warranty
  105. -- of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have
  106. -- received a copy of the GNU General Public License along with SmartEiffel; see the file COPYING. If not, write to the Free
  107. -- Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
  108. --
  109. -- Copyright(C) 1994-2002: INRIA - LORIA (INRIA Lorraine) - ESIAL U.H.P. - University of Nancy 1 - FRANCE
  110. -- Copyright(C) 2003-2006: INRIA - LORIA (INRIA Lorraine) - I.U.T. Charlemagne - University of Nancy 2 - FRANCE
  111. --
  112. -- Authors: Dominique COLNET, Philippe RIBET, Cyril ADRIAN, Vincent CROIZIER, Frederic MERIZEN
  113. --
  114. -- http://SmartEiffel.loria.fr - SmartEiffel@loria.fr
  115. -- ------------------------------------------------------------------------------------------------------------------------------