ladybird/Userland/Libraries/LibJS/Tests/builtins/Intl/DisplayNames/DisplayNames.js
Timothy Flynn e8dd2eea74 LibJS: Implement the Intl.DisplayNames constructor
There is notably FIXME notations in this commit regarding Unicode locale
extensions. We are not parsing extensions (or private use extensions) at
all yet.
2021-08-26 22:04:09 +01:00

57 lines
1.8 KiB
JavaScript

describe("errors", () => {
test("called without new", () => {
expect(() => {
Intl.DisplayNames();
}).toThrowWithMessage(TypeError, "Intl.DisplayNames constructor must be called with 'new'");
});
test("options is undefined", () => {
expect(() => {
new Intl.DisplayNames("en");
}).toThrowWithMessage(TypeError, "options is undefined");
});
test("options is an invalid type", () => {
expect(() => {
new Intl.DisplayNames("en", true);
}).toThrowWithMessage(TypeError, "Options is not an object");
});
test("style option is invalid ", () => {
expect(() => {
new Intl.DisplayNames("en", { style: "hello!" });
}).toThrowWithMessage(RangeError, "hello! is not a valid value for option style");
});
test("type option is invalid ", () => {
expect(() => {
new Intl.DisplayNames("en", { type: "hello!" });
}).toThrowWithMessage(RangeError, "hello! is not a valid value for option type");
});
test("fallback option is invalid ", () => {
expect(() => {
new Intl.DisplayNames("en", { type: "region", fallback: "hello!" });
}).toThrowWithMessage(RangeError, "hello! is not a valid value for option fallback");
});
test("missing type options ", () => {
expect(() => {
new Intl.DisplayNames("en", {});
}).toThrowWithMessage(TypeError, "options.type is undefined");
});
});
describe("normal behavior", () => {
test("length is 2", () => {
expect(Intl.DisplayNames).toHaveLength(2);
});
test("all valid types", () => {
["language", "region", "script", "currency"].forEach(type => {
expect(() => {
new Intl.DisplayNames("en", { type: type });
}).not.toThrow();
});
});
});