Fix helpers not working in e2e tests

It errors that jest is not defined so put it behind a function instead
of immediately creating the mock (this is probably a better pattern
anyway).

The constant tests had to be reworked a little. Since the logger mock is
hoisted it runs before createLoggerMock is imported. I moved it into a
beforeAll which means the require call also needed to be moved
there (since we need to mock the logger before requiring the constants
or it'll pull the non-mocked logger).

This means getPackageJson needs to be a let and assigned afterward. To
avoid having to define a type for getPackageJson I just added a let var
set to the type of the imported constants file and modified the other
areas to use the same paradigm.

I also replaced some hardcoded strings with the mocked package.json
object.
This commit is contained in:
Asher 2021-05-06 11:25:29 -05:00
parent ad4a70c684
commit e8443e2602
No known key found for this signature in database
GPG Key ID: D63C1EF81242354A
4 changed files with 40 additions and 44 deletions

View File

@ -1,29 +1,22 @@
import { loggerModule } from "../utils/helpers" import { createLoggerMock } from "../utils/helpers"
// jest.mock is hoisted above the imports so we must use `require` here.
jest.mock("@coder/logger", () => require("../utils/helpers").loggerModule)
describe("constants", () => { describe("constants", () => {
beforeAll(() => { let constants: typeof import("../../src/node/constants")
jest.clearAllMocks()
jest.resetModules()
})
describe("with package.json defined", () => { describe("with package.json defined", () => {
const { getPackageJson } = require("../../src/node/constants") const loggerModule = createLoggerMock()
let mockPackageJson = { const mockPackageJson = {
name: "mock-code-server", name: "mock-code-server",
description: "Run VS Code on a remote server.", description: "Run VS Code on a remote server.",
repository: "https://github.com/cdr/code-server", repository: "https://github.com/cdr/code-server",
version: "1.0.0", version: "1.0.0",
commit: "f6b2be2838f4afb217c2fd8f03eafedd8d55ef9b", commit: "f6b2be2838f4afb217c2fd8f03eafedd8d55ef9b",
} }
let version = ""
let commit = ""
beforeEach(() => { beforeAll(() => {
jest.mock("@coder/logger", () => loggerModule)
jest.mock("../../package.json", () => mockPackageJson, { virtual: true }) jest.mock("../../package.json", () => mockPackageJson, { virtual: true })
commit = require("../../src/node/constants").commit constants = require("../../src/node/constants")
version = require("../../src/node/constants").version
}) })
afterAll(() => { afterAll(() => {
@ -32,18 +25,18 @@ describe("constants", () => {
}) })
it("should provide the commit", () => { it("should provide the commit", () => {
expect(commit).toBe("f6b2be2838f4afb217c2fd8f03eafedd8d55ef9b") expect(constants.commit).toBe(mockPackageJson.commit)
}) })
it("should return the package.json version", () => { it("should return the package.json version", () => {
expect(version).toBe(mockPackageJson.version) expect(constants.version).toBe(mockPackageJson.version)
}) })
describe("getPackageJson", () => { describe("getPackageJson", () => {
it("should log a warning if package.json not found", () => { it("should log a warning if package.json not found", () => {
const expectedErrorMessage = "Cannot find module './package.json' from 'src/node/constants.ts'" const expectedErrorMessage = "Cannot find module './package.json' from 'src/node/constants.ts'"
getPackageJson("./package.json") constants.getPackageJson("./package.json")
expect(loggerModule.logger.warn).toHaveBeenCalled() expect(loggerModule.logger.warn).toHaveBeenCalled()
expect(loggerModule.logger.warn).toHaveBeenCalledWith(expectedErrorMessage) expect(loggerModule.logger.warn).toHaveBeenCalledWith(expectedErrorMessage)
@ -52,38 +45,32 @@ describe("constants", () => {
it("should find the package.json", () => { it("should find the package.json", () => {
// the function calls require from src/node/constants // the function calls require from src/node/constants
// so to get the root package.json we need to use ../../ // so to get the root package.json we need to use ../../
const packageJson = getPackageJson("../../package.json") const packageJson = constants.getPackageJson("../../package.json")
expect(Object.keys(packageJson).length).toBeGreaterThan(0) expect(packageJson).toStrictEqual(mockPackageJson)
expect(packageJson.name).toBe("mock-code-server")
expect(packageJson.description).toBe("Run VS Code on a remote server.")
expect(packageJson.repository).toBe("https://github.com/cdr/code-server")
}) })
}) })
}) })
describe("with incomplete package.json", () => { describe("with incomplete package.json", () => {
let mockPackageJson = { const mockPackageJson = {
name: "mock-code-server", name: "mock-code-server",
} }
let version = ""
let commit = ""
beforeEach(() => { beforeAll(() => {
jest.mock("../../package.json", () => mockPackageJson, { virtual: true }) jest.mock("../../package.json", () => mockPackageJson, { virtual: true })
version = require("../../src/node/constants").version constants = require("../../src/node/constants")
commit = require("../../src/node/constants").commit
}) })
afterEach(() => { afterAll(() => {
jest.clearAllMocks() jest.clearAllMocks()
jest.resetModules() jest.resetModules()
}) })
it("version should return 'development'", () => { it("version should return 'development'", () => {
expect(version).toBe("development") expect(constants.version).toBe("development")
}) })
it("commit should return 'development'", () => { it("commit should return 'development'", () => {
expect(commit).toBe("development") expect(constants.commit).toBe("development")
}) })
}) })
}) })

View File

@ -1,6 +1,6 @@
import { JSDOM } from "jsdom" import { JSDOM } from "jsdom"
import { registerServiceWorker } from "../../src/browser/register" import { registerServiceWorker } from "../../src/browser/register"
import { loggerModule } from "../utils/helpers" import { createLoggerMock } from "../utils/helpers"
import { LocationLike } from "./util.test" import { LocationLike } from "./util.test"
describe("register", () => { describe("register", () => {
@ -21,6 +21,7 @@ describe("register", () => {
}) })
}) })
const loggerModule = createLoggerMock()
beforeEach(() => { beforeEach(() => {
jest.clearAllMocks() jest.clearAllMocks()
jest.mock("@coder/logger", () => loggerModule) jest.mock("@coder/logger", () => loggerModule)
@ -75,6 +76,7 @@ describe("register", () => {
}) })
describe("when navigator and serviceWorker are NOT defined", () => { describe("when navigator and serviceWorker are NOT defined", () => {
const loggerModule = createLoggerMock()
beforeEach(() => { beforeEach(() => {
jest.clearAllMocks() jest.clearAllMocks()
jest.mock("@coder/logger", () => loggerModule) jest.mock("@coder/logger", () => loggerModule)

View File

@ -11,7 +11,7 @@ import {
trimSlashes, trimSlashes,
normalize, normalize,
} from "../../src/common/util" } from "../../src/common/util"
import { loggerModule } from "../utils/helpers" import { createLoggerMock } from "../utils/helpers"
const dom = new JSDOM() const dom = new JSDOM()
global.document = dom.window.document global.document = dom.window.document
@ -229,6 +229,8 @@ describe("util", () => {
jest.restoreAllMocks() jest.restoreAllMocks()
}) })
const loggerModule = createLoggerMock()
it("should log an error with the message and stack trace", () => { it("should log an error with the message and stack trace", () => {
const message = "You don't have access to that folder." const message = "You don't have access to that folder."
const error = new Error(message) const error = new Error(message)

View File

@ -2,16 +2,21 @@ import * as fs from "fs"
import * as os from "os" import * as os from "os"
import * as path from "path" import * as path from "path"
export const loggerModule = { /**
field: jest.fn(), * Return a mock of @coder/logger.
level: 2, */
logger: { export function createLoggerMock() {
debug: jest.fn(), return {
error: jest.fn(), field: jest.fn(),
info: jest.fn(), level: 2,
trace: jest.fn(), logger: {
warn: jest.fn(), debug: jest.fn(),
}, error: jest.fn(),
info: jest.fn(),
trace: jest.fn(),
warn: jest.fn(),
},
}
} }
/** /**