bigint-basic.js 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. describe("correct behavior", () => {
  2. test("typeof bigint", () => {
  3. expect(typeof 1n).toBe("bigint");
  4. });
  5. test("bigint string coercion", () => {
  6. expect("" + 123n).toBe("123");
  7. });
  8. test("hex literals", () => {
  9. expect(0xffn).toBe(255n);
  10. });
  11. test("octal literals", () => {
  12. expect(0o10n).toBe(8n);
  13. });
  14. test("binary literals", () => {
  15. expect(0b10n).toBe(2n);
  16. });
  17. test("arithmetic operators", () => {
  18. let bigint = 123n;
  19. expect(-bigint).toBe(-123n);
  20. expect(12n + 34n).toBe(46n);
  21. expect(12n - 34n).toBe(-22n);
  22. expect(8n * 12n).toBe(96n);
  23. expect(123n / 10n).toBe(12n);
  24. expect(2n ** 3n).toBe(8n);
  25. expect(5n % 3n).toBe(2n);
  26. expect(
  27. 45977665298704210987n +
  28. (714320987142450987412098743217984576n / 4598741987421098765327980n) * 987498743n
  29. ).toBe(199365500239020623962n);
  30. });
  31. test("bitwise operators", () => {
  32. expect(12n & 5n).toBe(4n);
  33. expect(3n & -2n).toBe(2n);
  34. expect(-3n & -2n).toBe(-4n);
  35. expect(-3n & 2n).toBe(0n);
  36. expect(0xffff_ffffn & -1n).toBe(0xffff_ffffn);
  37. expect(1n | 2n).toBe(3n);
  38. expect(0n | -1n).toBe(-1n);
  39. expect(0n | -2n).toBe(-2n);
  40. expect(5n ^ 3n).toBe(6n);
  41. expect(~1n).toBe(-2n);
  42. expect(~-1n).toBe(0n);
  43. expect(5n << 2n).toBe(20n);
  44. expect(7n >> 1n).toBe(3n);
  45. });
  46. test("increment operators", () => {
  47. let bigint = 1n;
  48. expect(bigint++).toBe(1n);
  49. expect(bigint).toBe(2n);
  50. expect(bigint--).toBe(2n);
  51. expect(bigint).toBe(1n);
  52. expect(++bigint).toBe(2n);
  53. expect(bigint).toBe(2n);
  54. expect(--bigint).toBe(1n);
  55. expect(bigint).toBe(1n);
  56. });
  57. test("weak equality operators", () => {
  58. expect(1n == 1n).toBeTrue();
  59. expect(1n == 1).toBeTrue();
  60. expect(1 == 1n).toBeTrue();
  61. expect(1n == 1.23).toBeFalse();
  62. expect(1.23 == 1n).toBeFalse();
  63. expect(1n != 1n).toBeFalse();
  64. expect(1n != 1).toBeFalse();
  65. expect(1 != 1n).toBeFalse();
  66. expect(1n != 1.23).toBeTrue();
  67. expect(1.23 != 1n).toBeTrue();
  68. const a = 552141064586571465517761649840658n;
  69. const b = 704179908449526267977309288010258n;
  70. expect(a == a).toBeTrue();
  71. expect(a == b).toBeFalse();
  72. expect(0n == Object(0n)).toBeTrue();
  73. expect(Object(0n) == 0n).toBeTrue();
  74. expect(0n != Object(0n)).toBeFalse();
  75. expect(Object(0n) != 0n).toBeFalse();
  76. expect(1n == Object(1n)).toBeTrue();
  77. expect(Object(1n) == 1n).toBeTrue();
  78. expect(1n != Object(1n)).toBeFalse();
  79. expect(Object(1n) != 1n).toBeFalse();
  80. expect(1n == Object(2n)).toBeFalse();
  81. expect(Object(2n) == 1n).toBeFalse();
  82. expect(1n != Object(2n)).toBeTrue();
  83. expect(Object(2n) != 1n).toBeTrue();
  84. expect(2n == "2").toBeTrue();
  85. expect(2n == "0b10").toBeTrue();
  86. expect(2n == "0o2").toBeTrue();
  87. expect(2n == "0x2").toBeTrue();
  88. expect(1n == "2").toBeFalse();
  89. expect(1n == "0b10").toBeFalse();
  90. expect(1n == "0o2").toBeFalse();
  91. expect(1n == "0x2").toBeFalse();
  92. });
  93. test("strong equality operators", () => {
  94. expect(1n === 1n).toBeTrue();
  95. expect(1n === 1).toBeFalse();
  96. expect(1 === 1n).toBeFalse();
  97. expect(1n === 1.23).toBeFalse();
  98. expect(1.23 === 1n).toBeFalse();
  99. expect(1n !== 1n).toBeFalse();
  100. expect(1n !== 1).toBeTrue();
  101. expect(1 !== 1n).toBeTrue();
  102. expect(1n !== 1.23).toBeTrue();
  103. expect(1.23 !== 1n).toBeTrue();
  104. const a = 552141064586571465517761649840658n;
  105. const b = 704179908449526267977309288010258n;
  106. expect(a === a).toBeTrue();
  107. expect(a === b).toBeFalse();
  108. });
  109. test("less-than operators", () => {
  110. expect(1n < 1n).toBeFalse();
  111. expect(1n < 1).toBeFalse();
  112. expect(1 < 1n).toBeFalse();
  113. expect(1n < 2n).toBeTrue();
  114. expect(1n < 2).toBeTrue();
  115. expect(1 < 2n).toBeTrue();
  116. expect(1n < 1.23).toBeTrue();
  117. expect(1.23 < 1n).toBeFalse();
  118. expect(1n <= 1n).toBeTrue();
  119. expect(1n <= 1).toBeTrue();
  120. expect(1 <= 1n).toBeTrue();
  121. expect(1n <= 2n).toBeTrue();
  122. expect(1n <= 2).toBeTrue();
  123. expect(1 <= 2n).toBeTrue();
  124. expect(1n <= 1.23).toBeTrue();
  125. expect(1.23 <= 1n).toBeFalse();
  126. expect(1n < "1").toBeFalse();
  127. expect(1n < "2").toBeTrue();
  128. expect(1n < "1.23").toBeFalse();
  129. expect(1n <= "1").toBeTrue();
  130. expect(1n <= "2").toBeTrue();
  131. expect(1n <= "1.23").toBeFalse();
  132. expect(1n < "0b1").toBeFalse();
  133. expect(1n < "0B10").toBeTrue();
  134. expect(1n < "0o1").toBeFalse();
  135. expect(1n < "0O2").toBeTrue();
  136. expect(1n < "0x1").toBeFalse();
  137. expect(1n < "0X2").toBeTrue();
  138. expect(1n <= "0b1").toBeTrue();
  139. expect(1n <= "0B10").toBeTrue();
  140. expect(1n <= "0o1").toBeTrue();
  141. expect(1n <= "0O2").toBeTrue();
  142. expect(1n <= "0x1").toBeTrue();
  143. expect(1n <= "0X2").toBeTrue();
  144. expect("1" < 1n).toBeFalse();
  145. expect("1" < 2n).toBeTrue();
  146. expect("1.23" < 1n).toBeFalse();
  147. expect("1" <= 1n).toBeTrue();
  148. expect("1" <= 2n).toBeTrue();
  149. expect("1.23" <= 1n).toBeFalse();
  150. expect("0b1" < 1n).toBeFalse();
  151. expect("0B1" < 2n).toBeTrue();
  152. expect("0o1" < 1n).toBeFalse();
  153. expect("0O1" < 2n).toBeTrue();
  154. expect("0x1" < 1n).toBeFalse();
  155. expect("0X1" < 2n).toBeTrue();
  156. expect("0b1" <= 1n).toBeTrue();
  157. expect("0B10" <= 2n).toBeTrue();
  158. expect("0o1" <= 1n).toBeTrue();
  159. expect("0O2" <= 2n).toBeTrue();
  160. expect("0x1" <= 1n).toBeTrue();
  161. expect("0X2" <= 2n).toBeTrue();
  162. });
  163. });
  164. describe("errors", () => {
  165. test("conversion to number", () => {
  166. expect(() => {
  167. +123n;
  168. }).toThrowWithMessage(TypeError, "Cannot convert BigInt to number");
  169. });
  170. test("division by zero", () => {
  171. expect(() => {
  172. 1n / 0n;
  173. }).toThrowWithMessage(RangeError, "Division by zero");
  174. expect(() => {
  175. 1n % 0n;
  176. }).toThrowWithMessage(RangeError, "Division by zero");
  177. });
  178. test("negative exponent", () => {
  179. expect(() => {
  180. 1n ** -1n;
  181. }).toThrowWithMessage(RangeError, "Exponent must be positive");
  182. });
  183. });