1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from "react";
6 import { mount, configure } from "enzyme";
7 import { SearchBarView, DEFAULT_SEARCH_DEBOUNCE } from "./search-bar-view";
9 import * as Adapter from 'enzyme-adapter-react-16';
12 configure({ adapter: new Adapter() });
14 describe("<SearchBarView />", () => {
18 let onSearch: () => void;
24 describe("on submit", () => {
25 it("calls onSearch with current value", () => {
26 const searchBar = mount(<SearchBarView onSearch={onSearch} value="current value" {...mockSearchProps()} />);
27 searchBar.find("input").simulate("change", { target: { value: "current value" } });
28 searchBar.find("form").simulate("submit");
29 expect(onSearch).toBeCalledWith("current value");
32 it("calls onSearch with new value passed via props", () => {
33 const searchBar = mount(<SearchBarView onSearch={onSearch} value="current value" {...mockSearchProps()} />);
34 searchBar.find("input").simulate("change", { target: { value: "new value" } });
35 searchBar.setProps({ value: "new value" });
36 searchBar.find("form").simulate("submit");
37 expect(onSearch).toBeCalledWith("new value");
40 it("cancels timeout set on input value change", () => {
41 const searchBar = mount(<SearchBarView onSearch={onSearch} debounce={1000} value="current value" {...mockSearchProps()} />);
42 searchBar.find("input").simulate("change", { target: { value: "current value" } });
43 searchBar.find("form").simulate("submit");
44 jest.runTimersToTime(1000);
45 expect(onSearch).toHaveBeenCalledTimes(1);
46 expect(onSearch).toBeCalledWith("current value");
51 describe("on input value change", () => {
52 it("calls onSearch after default timeout", () => {
53 const searchBar = mount(<SearchBarView onSearch={onSearch} value="current value" {...mockSearchProps()} />);
54 searchBar.find("input").simulate("change", { target: { value: "current value" } });
55 expect(onSearch).not.toBeCalled();
56 jest.runTimersToTime(DEFAULT_SEARCH_DEBOUNCE);
57 expect(onSearch).toBeCalledWith("current value");
60 it("calls onSearch after the time specified in props has passed", () => {
61 const searchBar = mount(<SearchBarView onSearch={onSearch} value="current value" debounce={2000} {...mockSearchProps()} />);
62 searchBar.find("input").simulate("change", { target: { value: "current value" } });
63 jest.runTimersToTime(1000);
64 expect(onSearch).not.toBeCalled();
65 jest.runTimersToTime(1000);
66 expect(onSearch).toBeCalledWith("current value");
69 it("calls onSearch only once after no change happened during the specified time", () => {
70 const searchBar = mount(<SearchBarView onSearch={onSearch} value="current value" debounce={1000} {...mockSearchProps()} />);
71 searchBar.find("input").simulate("change", { target: { value: "current value" } });
72 jest.runTimersToTime(500);
73 searchBar.find("input").simulate("change", { target: { value: "changed value" } });
74 jest.runTimersToTime(1000);
75 expect(onSearch).toHaveBeenCalledTimes(1);
78 it("calls onSearch again after the specified time has passed since previous call", () => {
79 const searchBar = mount(<SearchBarView onSearch={onSearch} value="latest value" debounce={1000} {...mockSearchProps()} />);
80 searchBar.find("input").simulate("change", { target: { value: "current value" } });
81 jest.runTimersToTime(500);
82 searchBar.find("input").simulate("change", { target: { value: "intermediate value" } });
83 jest.runTimersToTime(1000);
84 expect(onSearch).toBeCalledWith("intermediate value");
85 searchBar.find("input").simulate("change", { target: { value: "latest value" } });
86 jest.runTimersToTime(1000);
87 expect(onSearch).toBeCalledWith("latest value");
88 expect(onSearch).toHaveBeenCalledTimes(2);
94 const mockSearchProps = () => ({
100 closeView: jest.fn(),
101 saveQuery: jest.fn(),
102 loadQueries: () => ['test']