Source code
Revision control
Copy as Markdown
Other Tools
/* Any copyright is dedicated to the Public Domain.
"use strict";
// Import libs
const { shallow } = require("enzyme");
const { createFactory } = require("react");
const {
setupStore,
const {
PAGE_TYPES,
} = require("resource://devtools/client/application/src/constants.js");
const SidebarItem = createFactory(
require("resource://devtools/client/application/src/components/routing/SidebarItem.js")
);
/**
* Test for SidebarItem.js component
*/
describe("SidebarItem", () => {
function buildStoreWithSelectedPage(selectedPage) {
return setupStore({
ui: {
selectedPage,
},
});
}
it("renders the expected snapshot when the manifest page is selected", () => {
const store = buildStoreWithSelectedPage(PAGE_TYPES.MANIFEST);
const wrapper = shallow(
SidebarItem({
store,
page: "manifest",
isSelected: true,
})
).dive();
expect(wrapper).toMatchSnapshot();
});
it("renders the expected snapshot when the service-workers page is selected", () => {
const store = buildStoreWithSelectedPage(PAGE_TYPES.SERVICE_WORKERS);
const wrapper = shallow(
SidebarItem({
store,
isSelected: true,
page: "service-workers",
})
).dive();
expect(wrapper).toMatchSnapshot();
});
it("renders the expected snapshot when the manifest page is not selected", () => {
const store = buildStoreWithSelectedPage(PAGE_TYPES.MANIFEST);
const wrapper = shallow(
SidebarItem({
store,
isSelected: false,
page: "manifest",
})
).dive();
expect(wrapper).toMatchSnapshot();
});
it("renders the expected snapshot when the service-workers page is not selected", () => {
const store = buildStoreWithSelectedPage(PAGE_TYPES.SERVICE_WORKERS);
const wrapper = shallow(
SidebarItem({
store,
isSelected: false,
page: "service-workers",
})
).dive();
expect(wrapper).toMatchSnapshot();
});
});