X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/515f96c411358b45a978b6b7c93da860b09ee7d0..6af02d6e6596f45ac761daa04a53b2466e86ea98:/services/workbench2/src/components/search-input/search-input.test.tsx
diff --git a/services/workbench2/src/components/search-input/search-input.test.tsx b/services/workbench2/src/components/search-input/search-input.test.tsx
index de36ae3858..ba0f43d8b5 100644
--- a/services/workbench2/src/components/search-input/search-input.test.tsx
+++ b/services/workbench2/src/components/search-input/search-input.test.tsx
@@ -11,12 +11,10 @@ configure({ adapter: new Adapter() });
describe("", () => {
- // jest.useFakeTimers() applies to all setTimeout functions
- jest.useFakeTimers();
-
let onSearch: () => void;
beforeEach(() => {
+ jest.useFakeTimers();
onSearch = jest.fn();
});
@@ -46,7 +44,7 @@ describe("", () => {
const searchInput = mount();
searchInput.find("input").simulate("change", { target: { value: "current value" } });
searchInput.find("form").simulate("submit");
- jest.runTimersToTime(1000);
+ jest.advanceTimersByTime(1000);
expect(onSearch).toHaveBeenCalledTimes(1);
expect(onSearch).toBeCalledWith("current value");
});
@@ -58,45 +56,39 @@ describe("", () => {
const searchInput = mount();
searchInput.find("input").simulate("change", { target: { value: "current value" } });
expect(onSearch).not.toBeCalled();
- setTimeout(() => {
- expect(onSearch).toBeCalledWith("current value");
- }, DEFAULT_SEARCH_DEBOUNCE);
+ jest.advanceTimersByTime(DEFAULT_SEARCH_DEBOUNCE);
+ expect(onSearch).toBeCalledWith("current value");
});
it("calls onSearch after the time specified in props has passed", () => {
const searchInput = mount();
searchInput.find("input").simulate("change", { target: { value: "current value" } });
+ jest.advanceTimersByTime(1000);
expect(onSearch).not.toBeCalled();
- setTimeout(() => {
- expect(onSearch).toBeCalledWith("current value");
- }, 1000);
+ jest.advanceTimersByTime(1000);
+ expect(onSearch).toBeCalledWith("current value");
});
it("calls onSearch only once after no change happened during the specified time", () => {
const searchInput = mount();
searchInput.find("input").simulate("change", { target: { value: "current value" } });
- setTimeout(() => {
- searchInput.find("input").simulate("change", { target: { value: "changed value" } });
- }, 500);
- setTimeout(() => {
- expect(onSearch).toHaveBeenCalledTimes(1);
- }, 1000);
+ jest.advanceTimersByTime(500);
+ searchInput.find("input").simulate("change", { target: { value: "changed value" } });
+ jest.advanceTimersByTime(1000);
+ expect(onSearch).toHaveBeenCalledTimes(1);
});
it("calls onSearch again after the specified time has passed since previous call", () => {
const searchInput = mount();
searchInput.find("input").simulate("change", { target: { value: "current value" } });
- setTimeout(() => {
- searchInput.find("input").simulate("change", { target: { value: "intermediate value" } });
- }, 500);
- setTimeout(() => {
- expect(onSearch).toBeCalledWith("intermediate value");
- }, 1000);
+ jest.advanceTimersByTime(500);
+ searchInput.find("input").simulate("change", { target: { value: "intermediate value" } });
+ jest.advanceTimersByTime(1000);
+ expect(onSearch).toBeCalledWith("intermediate value");
searchInput.find("input").simulate("change", { target: { value: "latest value" } });
- setTimeout(() => {
- expect(onSearch).toBeCalledWith("latest value");
- expect(onSearch).toHaveBeenCalledTimes(2);
- }, 1000);
+ jest.advanceTimersByTime(1000);
+ expect(onSearch).toBeCalledWith("latest value");
+ expect(onSearch).toHaveBeenCalledTimes(2);
});
@@ -107,23 +99,20 @@ describe("", () => {
const searchInput = mount();
// component should clear value upon creation
- setTimeout(() => {
- expect(onSearch).toBeCalledWith("");
- expect(onSearch).toHaveBeenCalledTimes(1);
- }, 1000);
+ jest.advanceTimersByTime(1000);
+ expect(onSearch).toBeCalledWith("");
+ expect(onSearch).toHaveBeenCalledTimes(1);
// component should not clear on same selfClearProp
searchInput.setProps({ selfClearProp: 'abc' });
- setTimeout(() => {
- expect(onSearch).toHaveBeenCalledTimes(1);
- }, 1000);
+ jest.advanceTimersByTime(1000);
+ expect(onSearch).toHaveBeenCalledTimes(1);
// component should clear on selfClearProp change
searchInput.setProps({ selfClearProp: '111' });
- setTimeout(() => {
- expect(onSearch).toBeCalledWith("");
- expect(onSearch).toHaveBeenCalledTimes(2);
- }, 1000);
+ jest.advanceTimersByTime(1000);
+ expect(onSearch).toBeCalledWith("");
+ expect(onSearch).toHaveBeenCalledTimes(2);
});
});
});