mirror of
https://github.com/prymitive/karma
synced 2026-05-11 03:46:48 +00:00
feat(tests): add GroupMenu tests
This commit is contained in:
6
ui/__mocks__/copy-to-clipboard.js
Normal file
6
ui/__mocks__/copy-to-clipboard.js
Normal file
@@ -0,0 +1,6 @@
|
||||
// mock copy-to-clipboard since it throws errors in tests
|
||||
// and we don't really need to copy anything, only ensure we're calling it
|
||||
|
||||
const copy = jest.fn();
|
||||
|
||||
export default copy;
|
||||
@@ -150,4 +150,4 @@ const GroupMenu = observer(
|
||||
}
|
||||
);
|
||||
|
||||
export { GroupMenu };
|
||||
export { GroupMenu, MenuContent };
|
||||
|
||||
@@ -0,0 +1,81 @@
|
||||
import React from "react";
|
||||
|
||||
import { mount } from "enzyme";
|
||||
|
||||
import copy from "copy-to-clipboard";
|
||||
|
||||
import { MockAlertGroup } from "__mocks__/Alerts.js";
|
||||
import { SilenceFormStore } from "Stores/SilenceFormStore";
|
||||
import { GroupMenu, MenuContent } from "./GroupMenu";
|
||||
|
||||
let silenceFormStore;
|
||||
|
||||
beforeEach(() => {
|
||||
silenceFormStore = new SilenceFormStore();
|
||||
});
|
||||
|
||||
const MockAfterClick = jest.fn();
|
||||
|
||||
const MountedGroupMenu = group => {
|
||||
return mount(<GroupMenu group={group} silenceFormStore={silenceFormStore} />);
|
||||
};
|
||||
|
||||
describe("<GroupMenu />", () => {
|
||||
it("is collapsed by default", () => {
|
||||
const group = MockAlertGroup({ alertname: "Fake Alert" }, [], [], {});
|
||||
const tree = MountedGroupMenu(group);
|
||||
expect(tree.instance().collapse.value).toBe(true);
|
||||
});
|
||||
|
||||
it("clicking toggle sets collapse value to 'false'", () => {
|
||||
const group = MockAlertGroup({ alertname: "Fake Alert" }, [], [], {});
|
||||
const tree = MountedGroupMenu(group);
|
||||
const toggle = tree.find("a.cursor-pointer");
|
||||
toggle.simulate("click");
|
||||
expect(tree.instance().collapse.value).toBe(false);
|
||||
});
|
||||
|
||||
it("handleClickOutside() call sets collapse value to 'true'", () => {
|
||||
const group = MockAlertGroup({ alertname: "Fake Alert" }, [], [], {});
|
||||
const tree = MountedGroupMenu(group);
|
||||
|
||||
const toggle = tree.find("a.cursor-pointer");
|
||||
toggle.simulate("click");
|
||||
expect(tree.instance().collapse.value).toBe(false);
|
||||
|
||||
tree.instance().handleClickOutside();
|
||||
|
||||
expect(tree.instance().collapse.value).toBe(true);
|
||||
});
|
||||
});
|
||||
|
||||
const MountedMenuContent = group => {
|
||||
return mount(
|
||||
<MenuContent
|
||||
popperPlacement="top"
|
||||
popperRef={null}
|
||||
popperStyle={{}}
|
||||
group={group}
|
||||
afterClick={MockAfterClick}
|
||||
silenceFormStore={silenceFormStore}
|
||||
/>
|
||||
);
|
||||
};
|
||||
|
||||
describe("<MenuContent />", () => {
|
||||
it("clicking on 'Copy' icon copies the link to clickboard", () => {
|
||||
const group = MockAlertGroup({ alertname: "Fake Alert" }, [], [], {});
|
||||
const tree = MountedMenuContent(group);
|
||||
const button = tree.find(".dropdown-item").at(0);
|
||||
button.simulate("click");
|
||||
expect(copy).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
|
||||
it("clicking on 'Silence' icon opens the silence form modal", () => {
|
||||
const group = MockAlertGroup({ alertname: "Fake Alert" }, [], [], {});
|
||||
const tree = MountedMenuContent(group);
|
||||
const button = tree.find(".dropdown-item").at(1);
|
||||
button.simulate("click");
|
||||
expect(silenceFormStore.toggle.visible).toBe(true);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user