1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-10-26 00:52:35 +00:00
serenity/Userland/Libraries/LibJS/Tests/template-literals.js
davidot e5adc51e27 LibJS: Allow invalid string in tagged template literals
Since tagged template literals can inspect the raw string it is not a
syntax error to have invalid escapes. However the cooked value should be
`undefined`.
We accomplish this by tracking whether parse_string_literal
fails and then using a NullLiteral (since UndefinedLiteral is not a
thing) and finally converting null in tagged template execution to
undefined.
2022-08-17 23:56:24 +01:00

71 lines
2 KiB
JavaScript

test("plain literals with expression-like characters", () => {
expect(`foo`).toBe("foo");
expect(`foo{`).toBe("foo{");
expect(`foo}`).toBe("foo}");
expect(`foo$`).toBe("foo$");
});
test("plain literals with escaped special characters", () => {
expect(`foo\``).toBe("foo`");
expect(`foo\$`).toBe("foo$");
expect(`foo \${"bar"}`).toBe('foo ${"bar"}');
});
test("literals in expressions", () => {
expect(`foo ${undefined}`).toBe("foo undefined");
expect(`foo ${null}`).toBe("foo null");
expect(`foo ${5}`).toBe("foo 5");
expect(`foo ${true}`).toBe("foo true");
expect(`foo ${"bar"}`).toBe("foo bar");
});
test("objects in expressions", () => {
expect(`foo ${{}}`).toBe("foo [object Object]");
expect(`foo ${{ bar: { baz: "qux" } }}`).toBe("foo [object Object]");
});
test("expressions at beginning of template literal", () => {
expect(`${"foo"} bar baz`).toBe("foo bar baz");
expect(`${"foo bar baz"}`).toBe("foo bar baz");
});
test("multiple template literals", () => {
expect(`foo ${"bar"} ${"baz"}`).toBe("foo bar baz");
});
test("variables in expressions", () => {
let a = 27;
expect(`${a}`).toBe("27");
expect(`foo ${a}`).toBe("foo 27");
expect(`foo ${a ? "bar" : "baz"}`).toBe("foo bar");
expect(`foo ${(() => a)()}`).toBe("foo 27");
});
test("template literals in expressions", () => {
expect(`foo ${`bar`}`).toBe("foo bar");
expect(`${`${`${`${"foo"}`} bar`}`}`).toBe("foo bar");
});
test("newline literals (not characters)", () => {
expect(
`foo
bar`
).toBe("foo\n bar");
});
test("line continuation in literals (not characters)", () => {
expect(
`foo\
bar`
).toBe("foo bar");
});
test("reference error from expressions", () => {
expect(() => `${b}`).toThrowWithMessage(ReferenceError, "'b' is not defined");
});
test("invalid escapes should give syntax error", () => {
expect("`\\u`").not.toEval();
expect("`\\01`").not.toEval();
expect("`\\u{10FFFFF}`").not.toEval();
});