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>

71 lines (63 loc) 12.6 kB
"use strict"; function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } var React = _interopRequireWildcard(require("react")); var _enzyme = require("enzyme"); var _ = _interopRequireDefault(require("..")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } var Option = _["default"].Option; describe("Select", function () { beforeEach(function () { jest.useFakeTimers(); }); afterEach(function () { jest.useRealTimers(); }); it("Select 是否正确渲染", function () { var wrapper = (0, _enzyme.mount)(React.createElement(_["default"], null)); expect(wrapper).toMatchSnapshot(); }); it("Select 是否能内部驱动", function () { var wrapper = (0, _enzyme.mount)(React.createElement(_["default"], { 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 = (0, _enzyme.mount)(wrapper.find("Trigger").instance().getComponent()); expect(dropdownWrapper.props().visible).toBe(true); dropdownWrapper.find(".adui-select-item-option").at(0).simulate("click"); dropdownWrapper = (0, _enzyme.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 = (0, _enzyme.mount)(React.createElement(_["default"], { 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 = (0, _enzyme.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 = (0, _enzyme.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":["Option","Select","describe","beforeEach","jest","useFakeTimers","afterEach","useRealTimers","it","wrapper","mount","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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"}