mirror of
https://github.com/prymitive/karma
synced 2026-05-09 03:36:44 +00:00
As reported via #77 countdown timer might be updated more often than 1s since we don't protect against multiple setInterval() calls, add a check
89 lines
2.5 KiB
JavaScript
89 lines
2.5 KiB
JavaScript
import React from "react";
|
|
|
|
import { mount } from "enzyme";
|
|
|
|
import toDiffableHtml from "diffable-html";
|
|
|
|
import * as Sentry from "@sentry/browser";
|
|
|
|
import { ErrorBoundary } from "./ErrorBoundary";
|
|
|
|
beforeEach(() => {
|
|
jest.useFakeTimers();
|
|
});
|
|
|
|
afterEach(() => {
|
|
jest.clearAllTimers();
|
|
});
|
|
|
|
const FailingComponent = () => {
|
|
throw new Error("Error thrown from problem child");
|
|
};
|
|
|
|
const MountedFailingComponent = () => {
|
|
return mount(
|
|
<ErrorBoundary>
|
|
<FailingComponent />
|
|
</ErrorBoundary>
|
|
);
|
|
};
|
|
|
|
describe("<ErrorBoundary />", () => {
|
|
it("matches snapshot", () => {
|
|
const tree = MountedFailingComponent();
|
|
expect(toDiffableHtml(tree.html())).toMatchSnapshot();
|
|
});
|
|
|
|
it("componentDidCatch should catch an error from FailingComponent", () => {
|
|
jest.spyOn(ErrorBoundary.prototype, "componentDidCatch");
|
|
MountedFailingComponent();
|
|
expect(ErrorBoundary.prototype.componentDidCatch).toHaveBeenCalled();
|
|
});
|
|
|
|
it("componentDidCatch should report to sentry", () => {
|
|
const sentrySpy = jest.spyOn(Sentry, "captureException");
|
|
MountedFailingComponent();
|
|
expect(sentrySpy).toHaveBeenCalled();
|
|
});
|
|
|
|
it("componentDidCatch passes scope to sentry", () => {
|
|
const sentrySpy = jest.spyOn(Sentry, "configureScope");
|
|
Sentry.init({ dsn: "https://foobar@localhost/123456" });
|
|
|
|
const tree = mount(
|
|
<ErrorBoundary>
|
|
<div />
|
|
</ErrorBoundary>
|
|
);
|
|
const instance = tree.instance();
|
|
instance.componentDidCatch("foo", { foo: "bar" });
|
|
expect(sentrySpy).toHaveBeenCalled();
|
|
});
|
|
|
|
it("calls window.location.reload after 60s", () => {
|
|
const consoleSpy = jest
|
|
.spyOn(console, "error")
|
|
.mockImplementation(() => {});
|
|
const reloadSpy = jest.spyOn(global.window.location, "reload");
|
|
MountedFailingComponent();
|
|
jest.runTimersToTime(1000 * 61);
|
|
expect(reloadSpy).toHaveBeenCalled();
|
|
expect(consoleSpy).toHaveBeenCalled();
|
|
});
|
|
|
|
it("reloadSeconds is 40 after 20s with multiple exceptions", () => {
|
|
jest.spyOn(console, "error").mockImplementation(() => {});
|
|
const tree = MountedFailingComponent();
|
|
const instance = tree.instance();
|
|
|
|
instance.componentDidCatch("foo", { foo: "bar" });
|
|
jest.runTimersToTime(1000 * 10);
|
|
instance.componentDidCatch("foo", { foo: "bar" });
|
|
jest.runTimersToTime(1000 * 5);
|
|
instance.componentDidCatch("foo", { foo: "bar" });
|
|
jest.runTimersToTime(1000 * 5);
|
|
instance.componentDidCatch("foo", { foo: "bar" });
|
|
expect(tree.instance().state.reloadSeconds).toBe(40);
|
|
});
|
|
});
|