Farmbot-Web-App/frontend/farm_designer/farm_events/__tests__/edit_farm_event_test.tsx

58 lines
1.8 KiB
TypeScript

jest.mock("../../../history", () => ({
history: { push: jest.fn() }
}));
import * as React from "react";
import { mount } from "enzyme";
import { RawEditFarmEvent as EditFarmEvent } from "../edit_farm_event";
import { AddEditFarmEventProps } from "../../interfaces";
import {
fakeFarmEvent, fakeSequence
} from "../../../__test_support__/fake_state/resources";
import {
buildResourceIndex
} from "../../../__test_support__/resource_index_builder";
import { fakeTimeSettings } from "../../../__test_support__/fake_time_settings";
describe("<EditFarmEvent />", () => {
function fakeProps(): AddEditFarmEventProps {
const sequence = fakeSequence();
sequence.body.id = 1;
const farmEvent = fakeFarmEvent("Sequence", sequence.body.id);
return {
deviceTimezone: "",
dispatch: jest.fn(),
regimensById: {},
sequencesById: { "1": sequence },
farmEventsById: { "1": farmEvent },
executableOptions: [],
repeatOptions: [],
handleTime: jest.fn(),
farmEvents: [],
getFarmEvent: () => farmEvent,
findFarmEventByUuid: () => farmEvent,
findExecutable: () => sequence,
timeSettings: fakeTimeSettings(),
autoSyncEnabled: false,
shouldDisplay: () => false,
resources: buildResourceIndex([]).index,
};
}
it("renders", () => {
const wrapper = mount(<EditFarmEvent {...fakeProps()} />);
["Edit Event", "Sequence or Regimen", "fake", "Save"]
.map(string => expect(wrapper.text()).toContain(string));
const deleteBtn = wrapper.find("button").last();
expect(deleteBtn.text()).toEqual("Delete");
expect(deleteBtn.props().hidden).toBeFalsy();
});
it("redirects", () => {
const p = fakeProps();
p.getFarmEvent = jest.fn();
const wrapper = mount(<EditFarmEvent {...p} />);
expect(wrapper.text()).toContain("Loading");
});
});