ladybird/Userland/Libraries/LibJS/Tests/builtins/String/String.raw.js
Idan Horowitz 596324ae9c LibJS: Rewrite String.raw() closer to the specification
This includes not throwing a custom exception and using the
length_of_array_like abstract operation where required.
2021-06-28 13:27:13 +01:00

31 lines
844 B
JavaScript

test("basic functionality", () => {
expect(String.raw).toHaveLength(1);
let str = String.raw`foo\nbar`;
expect(str).toHaveLength(8);
expect(str).toBe("foo\\nbar");
str = String.raw`foo ${1 + 9}\nbar${"hf!"}`;
expect(str).toBe("foo 10\\nbarhf!");
str = String.raw`${10}${20}${30}`;
expect(str).toBe("102030");
str = String.raw({ raw: ["foo ", "\\nbar"] }, 10, "hf!");
expect(str).toBe("foo 10\\nbar");
str = String.raw({ raw: ["foo ", "\\nbar"] });
expect(str).toBe("foo \\nbar");
str = String.raw({ raw: [] }, 10, "hf!");
expect(str).toBe("");
str = String.raw({ raw: 1 });
expect(str).toBe("");
});
test("passing object with no 'raw' property", () => {
expect(() => {
String.raw({});
}).toThrowWithMessage(TypeError, "ToObject on null or undefined");
});