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 • 10.9 kB
JavaScript
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","expect","toMatchSnapshot","width","dropdownWrapper","find","instance","getComponent","props","visible","toBe","at","simulate","state","value","onSelect","fn"],"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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"}