UNPKG

adui

Version:

<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>

58 lines 11.4 kB
import * as React from "react"; import { mount } from "enzyme"; import Select from ".."; var Option = Select.Option; describe("Select", function () { beforeEach(function () { jest.useFakeTimers(); }); afterEach(function () { jest.useRealTimers(); }); it("Select 是否正确渲染", function () { var wrapper = mount(React.createElement(Select, null)); expect(wrapper).toMatchSnapshot(); }); it("Select 是否能内部驱动", function () { var wrapper = mount(React.createElement(Select, { defaultOpen: true, defaultValue: 2, style: { width: "120px" } }, React.createElement(Option, { value: 1 }, "\u670B\u53CB\u5708"), React.createElement(Option, { value: 2 }, "\u516C\u4F17\u53F7"))); var dropdownWrapper = mount(wrapper.find("Trigger").instance().getComponent()); expect(dropdownWrapper.props().visible).toBe(true); dropdownWrapper.find(".adui-select-item-option").at(0).simulate("click"); dropdownWrapper = mount(wrapper.find("Trigger").instance().getComponent()); expect(wrapper.state().value).toBe(1); expect(dropdownWrapper.props().visible).toBe(false); }); it("Select 是否受外部控制", function () { var onSelect = jest.fn(); var wrapper = mount(React.createElement(Select, { open: true, value: 2, style: { width: "120px" }, onSelect: onSelect }, React.createElement(Option, { value: 1 }, "\u670B\u53CB\u5708"), React.createElement(Option, { value: 2 }, "\u516C\u4F17\u53F7"))); var dropdownWrapper = mount(wrapper.find("Trigger").instance().getComponent()); expect(wrapper.state().value).toBe(2); expect(dropdownWrapper.props().visible).toBe(true); dropdownWrapper.find(".adui-select-item-option").at(0).simulate("click"); dropdownWrapper = mount(wrapper.find("Trigger").instance().getComponent()); expect(wrapper.state().value).toBe(2); expect(dropdownWrapper.props().visible).toBe(true); }); }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","mount","Select","Option","describe","beforeEach","jest","useFakeTimers","afterEach","useRealTimers","it","wrapper","createElement","expect","toMatchSnapshot","defaultOpen","defaultValue","style","width","value","dropdownWrapper","find","instance","getComponent","props","visible","toBe","at","simulate","state","onSelect","fn","open"],"sources":["../../../components/select/__tests__/index.test.tsx"],"sourcesContent":["/* eslint-disable */\n// @ts-nocheck\nimport * as React from \"react\"\nimport { mount } from \"enzyme\"\nimport Select from \"..\"\nimport { act } from \"react-dom/test-utils\"\n\nconst { Option } = Select\n\nexport interface IElementProto {\n  [key: string]: any\n}\n\ndescribe(\"Select\", () => {\n  beforeEach(() => {\n    jest.useFakeTimers()\n\n    /**\n     * https://stackoverflow.com/a/40006663\n     * 通过 mock `getPopupDOMNode`，之后运行的所有 `getPopupDOMNode` 都会返回这同一个值。\n     */\n    // Element.prototype.getPopupDOMNode = jest.fn(() => {\n    // return \"asd\"\n    // })\n  })\n\n  afterEach(() => {\n    jest.useRealTimers()\n  })\n\n  it(\"Select 是否正确渲染\", () => {\n    const wrapper = mount(<Select />)\n    expect(wrapper).toMatchSnapshot()\n  })\n\n  it(\"Select 是否能内部驱动\", () => {\n    const wrapper = mount(\n      <Select defaultOpen defaultValue={2} style={{ width: \"120px\" }}>\n        <Option value={1}>朋友圈</Option>\n        <Option value={2}>公众号</Option>\n      </Select>\n    )\n    let dropdownWrapper = mount(\n      wrapper.find(\"Trigger\").instance().getComponent()\n    )\n    expect(dropdownWrapper.props().visible).toBe(true)\n    dropdownWrapper.find(\".adui-select-item-option\").at(0).simulate(\"click\")\n    // 需要重新获取\n    dropdownWrapper = mount(wrapper.find(\"Trigger\").instance().getComponent())\n    expect(wrapper.state().value).toBe(1)\n    expect(dropdownWrapper.props().visible).toBe(false)\n  })\n\n  it(\"Select 是否受外部控制\", () => {\n    const onSelect = jest.fn()\n    const wrapper = mount(\n      <Select open value={2} style={{ width: \"120px\" }} onSelect={onSelect}>\n        <Option value={1}>朋友圈</Option>\n        <Option value={2}>公众号</Option>\n      </Select>\n    )\n    let dropdownWrapper = mount(\n      wrapper.find(\"Trigger\").instance().getComponent()\n    )\n    expect(wrapper.state().value).toBe(2)\n    expect(dropdownWrapper.props().visible).toBe(true)\n    dropdownWrapper.find(\".adui-select-item-option\").at(0).simulate(\"click\")\n    // 需要重新获取\n    dropdownWrapper = mount(wrapper.find(\"Trigger\").instance().getComponent())\n    expect(wrapper.state().value).toBe(2)\n    expect(dropdownWrapper.props().visible).toBe(true)\n  })\n\n  // it(\"封装的搜索是否可用\", () => {\n  //   document.body.innerHTML = '<div id=\"mounter\" />'\n  //   const onSelect = jest.fn()\n  //   const wrapper = mount(\n  //     <Select\n  //       open\n  //       value={null}\n  //       style={{ width: \"120px\" }}\n  //       onSelect={onSelect}\n  //       searchable\n  //     >\n  //       <Option value={1}>pengyouquan</Option>\n  //       <Option value={2}>gongzhonghao</Option>\n  //     </Select>,\n  //     { attachTo: document.getElementById(\"mounter\") }\n  //   )\n  //   let dropdownWrapper = mount(\n  //     wrapper\n  //       .find(\"Trigger\")\n  //       .instance()\n  //       .getComponent()\n  //   )\n  //   const input = dropdownWrapper.find(\"input\")\n  //   act(() => {\n  //     input.simulate(\"mousedown\")\n  //     input.simulate(\"mouseup\")\n  //     input.simulate(\"keydown\", { key: \"z\", keyCode: 90 })\n  //     input.simulate(\"change\", { target: { value: \"z\" } })\n  //     /**\n  //      * runAllTimers 测试 Select.preventVisibleChange\n  //      */\n  //     jest.runAllTimers()\n  //     wrapper.update()\n  //     // 需要重新获取\n  //     dropdownWrapper = mount(\n  //       wrapper\n  //         .find(\"Trigger\")\n  //         .instance()\n  //         .getComponent()\n  //     )\n  //     console.log(dropdownWrapper.find(\"input\").at(0).props(), \"yijie\")\n  //     expect(\n  //       dropdownWrapper\n  //         .find(\".adui-select-item-option\")\n  //         .at(0)\n  //         .text()\n  //     ).toBe(\"gongzhonghao\")\n  //     dropdownWrapper\n  //       .find(\".adui-select-item-option\")\n  //       .at(0)\n  //       .simulate(\"click\")\n  //   })\n  // })\n})\n"],"mappings":"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","ignoreList":[]}