2021-02-23 19:30:48 +00:00
|
|
|
import { field, Level } from "@coder/logger"
|
2021-02-11 22:02:49 +00:00
|
|
|
import { JSDOM } from "jsdom"
|
|
|
|
|
|
|
|
describe("register", () => {
|
2021-02-22 22:50:26 +00:00
|
|
|
const { window } = new JSDOM()
|
|
|
|
global.window = (window as unknown) as Window & typeof globalThis
|
|
|
|
global.document = window.document
|
|
|
|
global.navigator = window.navigator
|
|
|
|
global.location = window.location
|
|
|
|
|
2021-02-23 19:30:48 +00:00
|
|
|
const mockRegisterFn = jest.fn()
|
|
|
|
const loggerModule = {
|
|
|
|
field,
|
|
|
|
level: Level.Info,
|
|
|
|
logger: {
|
|
|
|
debug: jest.fn(),
|
|
|
|
error: jest.fn(),
|
|
|
|
info: jest.fn(),
|
|
|
|
trace: jest.fn(),
|
|
|
|
warn: jest.fn(),
|
|
|
|
},
|
|
|
|
}
|
2021-02-22 22:50:26 +00:00
|
|
|
|
|
|
|
beforeAll(() => {
|
|
|
|
Object.defineProperty(global.navigator, "serviceWorker", {
|
|
|
|
value: {
|
|
|
|
register: mockRegisterFn,
|
|
|
|
},
|
2021-02-11 22:23:07 +00:00
|
|
|
})
|
2021-02-22 22:50:26 +00:00
|
|
|
})
|
2021-02-11 23:51:48 +00:00
|
|
|
|
2021-02-22 22:50:26 +00:00
|
|
|
beforeEach(() => {
|
2021-02-23 19:30:48 +00:00
|
|
|
jest.mock("@coder/logger", () => loggerModule)
|
2021-02-22 22:50:26 +00:00
|
|
|
})
|
2021-02-11 23:51:48 +00:00
|
|
|
|
2021-02-22 22:50:26 +00:00
|
|
|
afterEach(() => {
|
2021-02-23 19:30:48 +00:00
|
|
|
mockRegisterFn.mockClear()
|
2021-02-22 22:50:26 +00:00
|
|
|
jest.resetModules()
|
2021-02-11 23:51:48 +00:00
|
|
|
})
|
|
|
|
|
2021-02-22 22:50:26 +00:00
|
|
|
afterAll(() => {
|
|
|
|
jest.restoreAllMocks()
|
|
|
|
})
|
2021-02-11 23:51:48 +00:00
|
|
|
|
2021-02-22 22:50:26 +00:00
|
|
|
it("should register a ServiceWorker", () => {
|
|
|
|
// Load service worker like you would in the browser
|
|
|
|
require("../src/browser/register")
|
|
|
|
// Load service worker like you would in the browser
|
2021-02-23 19:30:48 +00:00
|
|
|
expect(mockRegisterFn).toHaveBeenCalled()
|
|
|
|
expect(mockRegisterFn).toHaveBeenCalledTimes(1)
|
2021-02-22 22:50:26 +00:00
|
|
|
})
|
2021-02-11 23:51:48 +00:00
|
|
|
|
2021-02-22 22:50:26 +00:00
|
|
|
it("should log an error if something doesn't work", () => {
|
|
|
|
const message = "Can't find browser"
|
|
|
|
const error = new Error(message)
|
2021-02-11 23:51:48 +00:00
|
|
|
|
2021-02-22 22:50:26 +00:00
|
|
|
mockRegisterFn.mockImplementation(() => {
|
|
|
|
throw error
|
2021-02-11 23:51:48 +00:00
|
|
|
})
|
|
|
|
|
2021-02-22 22:50:26 +00:00
|
|
|
// Load service worker like you would in the browser
|
|
|
|
require("../src/browser/register")
|
2021-02-11 23:51:48 +00:00
|
|
|
|
2021-02-23 19:30:48 +00:00
|
|
|
expect(mockRegisterFn).toHaveBeenCalled()
|
|
|
|
expect(loggerModule.logger.error).toHaveBeenCalled()
|
2021-02-11 22:02:49 +00:00
|
|
|
})
|
|
|
|
})
|