mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 16:22:43 +00:00 
			
		
		
		
	 09536f5f48
			
		
	
	
		09536f5f48
		
	
	
	
	
		
			
			Step 12 was using `lhs.is_bigint()` instead of `rhs.is_bigint()`, meaning you got: ```js 1n == Object(1n); // true Object(1n) == 1n; // false ``` This also adds spec comments to is_loosely_equal.
		
			
				
	
	
		
			134 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 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();
 | |
| 
 | |
|         expect(0n == Object(0n)).toBeTrue();
 | |
|         expect(Object(0n) == 0n).toBeTrue();
 | |
|         expect(0n != Object(0n)).toBeFalse();
 | |
|         expect(Object(0n) != 0n).toBeFalse();
 | |
| 
 | |
|         expect(1n == Object(1n)).toBeTrue();
 | |
|         expect(Object(1n) == 1n).toBeTrue();
 | |
|         expect(1n != Object(1n)).toBeFalse();
 | |
|         expect(Object(1n) != 1n).toBeFalse();
 | |
| 
 | |
|         expect(1n == Object(2n)).toBeFalse();
 | |
|         expect(Object(2n) == 1n).toBeFalse();
 | |
|         expect(1n != Object(2n)).toBeTrue();
 | |
|         expect(Object(2n) != 1n).toBeTrue();
 | |
|     });
 | |
| 
 | |
|     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");
 | |
|     });
 | |
| });
 |