/test/lib/numeric/mutable_big_integer/test_mutable_big_integer1.e

http://github.com/tybor/Liberty · Specman e · 112 lines · 83 code · 5 blank · 24 comment · 0 complexity · cad7fe414d4d8ca96c9a29723bb2f3e5 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_INTEGER1
  5. --
  6. -- Testing from_integer/to_integer/is_integer/is_zero/negate
  7. --
  8. insert
  9. ARGUMENTS
  10. PLATFORM
  11. EIFFELTEST_TOOLS
  12. create {}
  13. make
  14. feature {ANY}
  15. make
  16. local
  17. mbi1: MUTABLE_BIG_INTEGER; v: INTEGER
  18. do
  19. create mbi1.from_integer(0)
  20. assert(mbi1.is_integer_32)
  21. assert(mbi1.is_zero)
  22. assert(not mbi1.is_one)
  23. assert(mbi1.is_even)
  24. assert(not mbi1.is_odd)
  25. assert(mbi1.to_string.is_equal("0"))
  26. assert(not mbi1.is_negative)
  27. mbi1.negate
  28. assert(not mbi1.is_negative)
  29. create mbi1.from_integer(2)
  30. assert(mbi1.to_integer_32 = 2)
  31. assert(not mbi1.is_zero)
  32. assert(not mbi1.is_negative)
  33. mbi1.negate
  34. assert(mbi1.is_negative)
  35. create mbi1.from_integer(1)
  36. assert(mbi1.to_integer_32 = 1)
  37. assert(not mbi1.is_zero)
  38. assert(mbi1.is_one)
  39. assert(not mbi1.is_even)
  40. assert(mbi1.is_odd)
  41. create mbi1.from_integer(-1)
  42. assert(mbi1.to_integer_32 = -1)
  43. assert(not mbi1.is_zero)
  44. create mbi1.from_integer(-2)
  45. assert(mbi1.to_integer_32 = -2)
  46. assert(not mbi1.is_zero)
  47. assert(not mbi1.is_one)
  48. assert(mbi1.is_even)
  49. assert(not mbi1.is_odd)
  50. create mbi1.from_integer(Maximum_integer)
  51. assert(mbi1.to_integer_32 = Maximum_integer)
  52. assert(not mbi1.is_zero)
  53. create mbi1.from_integer(Minimum_integer)
  54. assert(mbi1.to_integer_32 = Minimum_integer)
  55. assert(not mbi1.is_zero)
  56. v := Minimum_integer + 1
  57. create mbi1.from_integer(v)
  58. assert(mbi1.to_integer_32 = v)
  59. assert(not mbi1.is_zero)
  60. v := Maximum_integer - 1
  61. create mbi1.from_integer(v)
  62. assert(mbi1.to_integer_32 = v)
  63. assert(not mbi1.is_zero)
  64. check_range(Minimum_integer, -2147483600)
  65. check_range(-128, 128)
  66. check_range(2147483600, Maximum_integer)
  67. create mbi1.from_integer_64(2147483648)
  68. assert(not mbi1.is_integer_32)
  69. create mbi1.from_integer_64(-2147483649)
  70. assert(not mbi1.is_integer_32)
  71. end
  72. check_range (min, max: INTEGER)
  73. require
  74. min < max
  75. local
  76. i, mem: INTEGER; mbi: MUTABLE_BIG_INTEGER
  77. do
  78. from
  79. i := min
  80. until
  81. i = max
  82. loop
  83. mem := i
  84. create mbi.from_integer(mem)
  85. assert(mem = mbi.to_integer_32)
  86. i := i + 1
  87. end
  88. end
  89. end -- class TEST_MUTABLE_BIG_INTEGER1
  90. --
  91. -- ------------------------------------------------------------------------------------------------------------------------------
  92. -- Copyright notice below. Please read.
  93. --
  94. -- SmartEiffel is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License,
  95. -- as published by the Free Software Foundation; either version 2, or (at your option) any later version.
  96. -- SmartEiffel is distributed in the hope that it will be useful but WITHOUT ANY WARRANTY; without even the implied warranty
  97. -- of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have
  98. -- received a copy of the GNU General Public License along with SmartEiffel; see the file COPYING. If not, write to the Free
  99. -- Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
  100. --
  101. -- Copyright(C) 1994-2002: INRIA - LORIA (INRIA Lorraine) - ESIAL U.H.P. - University of Nancy 1 - FRANCE
  102. -- Copyright(C) 2003-2006: INRIA - LORIA (INRIA Lorraine) - I.U.T. Charlemagne - University of Nancy 2 - FRANCE
  103. --
  104. -- Authors: Dominique COLNET, Philippe RIBET, Cyril ADRIAN, Vincent CROIZIER, Frederic MERIZEN
  105. --
  106. -- http://SmartEiffel.loria.fr - SmartEiffel@loria.fr
  107. -- ------------------------------------------------------------------------------------------------------------------------------