2021-02-04 07:52:17 +08:00
|
|
|
import { JSDOM } from "jsdom"
|
2021-07-28 07:52:57 +08:00
|
|
|
import * as util from "../../../src/common/util"
|
|
|
|
import { createLoggerMock } from "../../utils/helpers"
|
2021-02-04 02:22:13 +08:00
|
|
|
|
2021-02-04 07:52:17 +08:00
|
|
|
const dom = new JSDOM()
|
|
|
|
global.document = dom.window.document
|
|
|
|
|
2021-04-24 07:31:56 +08:00
|
|
|
export type LocationLike = Pick<Location, "pathname" | "origin">
|
2020-02-05 03:27:46 +08:00
|
|
|
|
|
|
|
describe("util", () => {
|
|
|
|
describe("normalize", () => {
|
|
|
|
it("should remove multiple slashes", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.normalize("//foo//bar//baz///mumble")).toBe("/foo/bar/baz/mumble")
|
2020-02-05 03:27:46 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
it("should remove trailing slashes", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.normalize("qux///")).toBe("qux")
|
2020-02-05 03:27:46 +08:00
|
|
|
})
|
2020-02-05 08:16:45 +08:00
|
|
|
|
|
|
|
it("should preserve trailing slash if it exists", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.normalize("qux///", true)).toBe("qux/")
|
|
|
|
expect(util.normalize("qux", true)).toBe("qux")
|
2020-02-05 08:16:45 +08:00
|
|
|
})
|
2020-02-05 03:27:46 +08:00
|
|
|
})
|
2021-02-04 02:22:13 +08:00
|
|
|
|
|
|
|
describe("split", () => {
|
|
|
|
it("should split at a comma", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.split("Hello,world", ",")).toStrictEqual(["Hello", "world"])
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
it("shouldn't split if the delimiter doesn't exist", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.split("Hello world", ",")).toStrictEqual(["Hello world", ""])
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe("plural", () => {
|
|
|
|
it("should add an s if count is greater than 1", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.plural(2, "dog")).toBe("dogs")
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
it("should NOT add an s if the count is 1", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.plural(1, "dog")).toBe("dog")
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2021-02-04 07:52:17 +08:00
|
|
|
describe("generateUuid", () => {
|
|
|
|
it("should generate a unique uuid", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
const uuid = util.generateUuid()
|
|
|
|
const uuid2 = util.generateUuid()
|
2021-02-04 07:52:17 +08:00
|
|
|
expect(uuid).toHaveLength(24)
|
|
|
|
expect(typeof uuid).toBe("string")
|
|
|
|
expect(uuid).not.toBe(uuid2)
|
|
|
|
})
|
|
|
|
it("should generate a uuid of a specific length", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
const uuid = util.generateUuid(10)
|
2021-02-04 07:52:17 +08:00
|
|
|
expect(uuid).toHaveLength(10)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2021-02-04 02:22:13 +08:00
|
|
|
describe("trimSlashes", () => {
|
|
|
|
it("should remove leading slashes", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.trimSlashes("/hello-world")).toBe("hello-world")
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
it("should remove trailing slashes", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.trimSlashes("hello-world/")).toBe("hello-world")
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
it("should remove both leading and trailing slashes", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.trimSlashes("/hello-world/")).toBe("hello-world")
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
it("should remove multiple leading and trailing slashes", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.trimSlashes("///hello-world////")).toBe("hello-world")
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe("arrayify", () => {
|
|
|
|
it("should return value it's already an array", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.arrayify(["hello", "world"])).toStrictEqual(["hello", "world"])
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
2021-02-04 07:10:17 +08:00
|
|
|
|
2021-02-04 02:22:13 +08:00
|
|
|
it("should wrap the value in an array if not an array", () => {
|
|
|
|
expect(
|
2021-06-26 01:15:12 +08:00
|
|
|
util.arrayify({
|
2021-02-04 02:22:13 +08:00
|
|
|
name: "Coder",
|
|
|
|
version: "3.8",
|
|
|
|
}),
|
|
|
|
).toStrictEqual([{ name: "Coder", version: "3.8" }])
|
|
|
|
})
|
2021-02-04 07:10:17 +08:00
|
|
|
|
2021-02-04 02:22:13 +08:00
|
|
|
it("should return an empty array if the value is undefined", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
expect(util.arrayify(undefined)).toStrictEqual([])
|
2021-02-04 02:22:13 +08:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2021-02-04 07:10:17 +08:00
|
|
|
describe("logError", () => {
|
|
|
|
afterEach(() => {
|
|
|
|
jest.clearAllMocks()
|
|
|
|
})
|
|
|
|
|
|
|
|
afterAll(() => {
|
|
|
|
jest.restoreAllMocks()
|
|
|
|
})
|
|
|
|
|
2021-05-07 00:25:29 +08:00
|
|
|
const loggerModule = createLoggerMock()
|
|
|
|
|
2021-02-04 07:10:17 +08:00
|
|
|
it("should log an error with the message and stack trace", () => {
|
|
|
|
const message = "You don't have access to that folder."
|
|
|
|
const error = new Error(message)
|
|
|
|
|
2021-06-26 01:15:12 +08:00
|
|
|
util.logError(loggerModule.logger, "ui", error)
|
2021-02-04 07:10:17 +08:00
|
|
|
|
2021-02-24 07:01:11 +08:00
|
|
|
expect(loggerModule.logger.error).toHaveBeenCalled()
|
|
|
|
expect(loggerModule.logger.error).toHaveBeenCalledWith(`ui: ${error.message} ${error.stack}`)
|
2021-02-04 07:10:17 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
it("should log an error, even if not an instance of error", () => {
|
2021-06-26 01:15:12 +08:00
|
|
|
util.logError(loggerModule.logger, "api", "oh no")
|
2021-02-04 07:10:17 +08:00
|
|
|
|
2021-02-24 07:01:11 +08:00
|
|
|
expect(loggerModule.logger.error).toHaveBeenCalled()
|
|
|
|
expect(loggerModule.logger.error).toHaveBeenCalledWith("api: oh no")
|
2021-02-04 07:10:17 +08:00
|
|
|
})
|
|
|
|
})
|
2020-02-05 03:27:46 +08:00
|
|
|
})
|