123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- describe("correct behavior", () => {
- test("typeof bigint", () => {
- expect(typeof 1n).toBe("bigint");
- });
- test("bigint string coercion", () => {
- expect("" + 123n).toBe("123");
- });
- test("hex literals", () => {
- expect(0xffn).toBe(255n);
- });
- test("octal literals", () => {
- expect(0o10n).toBe(8n);
- });
- test("binary literals", () => {
- expect(0b10n).toBe(2n);
- });
- test("arithmetic operators", () => {
- let bigint = 123n;
- expect(-bigint).toBe(-123n);
- expect(12n + 34n).toBe(46n);
- expect(12n - 34n).toBe(-22n);
- expect(8n * 12n).toBe(96n);
- expect(123n / 10n).toBe(12n);
- expect(2n ** 3n).toBe(8n);
- expect(5n % 3n).toBe(2n);
- expect(
- 45977665298704210987n +
- (714320987142450987412098743217984576n / 4598741987421098765327980n) * 987498743n
- ).toBe(199365500239020623962n);
- });
- test("bitwise operators", () => {
- expect(12n & 5n).toBe(4n);
- expect(1n | 2n).toBe(3n);
- expect(5n ^ 3n).toBe(6n);
- expect(~1n).toBe(-2n);
- expect(5n << 2n).toBe(20n);
- expect(7n >> 1n).toBe(3n);
- });
- test("increment operators", () => {
- let bigint = 1n;
- expect(bigint++).toBe(1n);
- expect(bigint).toBe(2n);
- expect(bigint--).toBe(2n);
- expect(bigint).toBe(1n);
- expect(++bigint).toBe(2n);
- expect(bigint).toBe(2n);
- expect(--bigint).toBe(1n);
- expect(bigint).toBe(1n);
- });
- test("weak equality operators", () => {
- expect(1n == 1n).toBeTrue();
- expect(1n == 1).toBeTrue();
- expect(1 == 1n).toBeTrue();
- expect(1n == 1.23).toBeFalse();
- expect(1.23 == 1n).toBeFalse();
- expect(1n != 1n).toBeFalse();
- expect(1n != 1).toBeFalse();
- expect(1 != 1n).toBeFalse();
- expect(1n != 1.23).toBeTrue();
- expect(1.23 != 1n).toBeTrue();
- const a = 552141064586571465517761649840658n;
- const b = 704179908449526267977309288010258n;
- expect(a == a).toBeTrue();
- expect(a == b).toBeFalse();
- });
- test("strong equality operators", () => {
- expect(1n === 1n).toBeTrue();
- expect(1n === 1).toBeFalse();
- expect(1 === 1n).toBeFalse();
- expect(1n === 1.23).toBeFalse();
- expect(1.23 === 1n).toBeFalse();
- expect(1n !== 1n).toBeFalse();
- expect(1n !== 1).toBeTrue();
- expect(1 !== 1n).toBeTrue();
- expect(1n !== 1.23).toBeTrue();
- expect(1.23 !== 1n).toBeTrue();
- const a = 552141064586571465517761649840658n;
- const b = 704179908449526267977309288010258n;
- expect(a === a).toBeTrue();
- expect(a === b).toBeFalse();
- });
- });
- describe("errors", () => {
- test("conversion to number", () => {
- expect(() => {
- +123n;
- }).toThrowWithMessage(TypeError, "Cannot convert BigInt to number");
- });
- test("division by zero", () => {
- expect(() => {
- 1n / 0n;
- }).toThrowWithMessage(RangeError, "Division by zero");
- expect(() => {
- 1n % 0n;
- }).toThrowWithMessage(RangeError, "Division by zero");
- });
- test("negative exponent", () => {
- expect(() => {
- 1n ** -1n;
- }).toThrowWithMessage(RangeError, "Exponent must be positive");
- });
- });
|