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>

133 lines (112 loc) 17.8 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 _reactTestRenderer = _interopRequireDefault(require("react-test-renderer")); var sinon = _interopRequireWildcard(require("sinon")); 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; } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } window.ResizeObserver = window.ResizeObserver || jest.fn().mockImplementation(function () { return { disconnect: jest.fn(), observe: jest.fn(), unobserve: jest.fn() }; }); var Column = _["default"].Column; var filters = [{ text: "朋友圈广告", value: "1" }, { text: "公众号广告", value: "2" }]; var FilterMounter = function FilterMounter() { var _useState = (0, _react.useState)(null), _useState2 = _slicedToArray(_useState, 2), filteredValue = _useState2[0], set = _useState2[1]; return _react["default"].createElement(_["default"], { dataSource: [{ filter: "filter" }] }, _react["default"].createElement(Column, { title: "\u7B5B\u9009", dataIndex: "filter", filters: filters, filteredValue: filteredValue, onFilter: function onFilter(argFilteredValue) { return set(argFilteredValue); } })); }; describe("筛选功能", function () { beforeEach(function () { jest.useFakeTimers(); }); afterEach(function () { jest.useRealTimers(); }); it("onFilter 不能与 onSort 共用", function () { var stub = sinon.stub(console, "error"); (0, _enzyme.render)(_react["default"].createElement(_["default"], null, _react["default"].createElement(_["default"].Column, { title: "title", onFilter: function onFilter() {}, onSort: function onSort() {} }))); expect(stub.calledOnce).toEqual(true); stub.restore(); }); it("是否正确渲染", function () { var onFilter = jest.fn(); var wrapper = _reactTestRenderer["default"].create(_react["default"].createElement(_["default"], { dataSource: [{ filter: "filter" }] }, _react["default"].createElement(Column, { title: "\u7B5B\u9009", dataIndex: "filter", filters: filters, onFilter: onFilter }))); expect(wrapper).toMatchSnapshot(); }); it("是否能够内部驱动", function () { var onFilter = jest.fn(); var wrapper = (0, _enzyme.mount)(_react["default"].createElement(_["default"], { dataSource: [{ filter: "filter" }] }, _react["default"].createElement(Column, { title: "\u7B5B\u9009", dataIndex: "filter", filters: filters, onFilter: onFilter }))); var th = wrapper.find("[role='columnheader']").at(0); th.simulate("click"); var dropdownWrapper = (0, _enzyme.mount)(wrapper.find("Trigger").instance().getComponent()); dropdownWrapper.find("label").at(1).simulate("click"); expect(onFilter).toHaveBeenCalledWith(["1"]); dropdownWrapper.find("label").at(2).simulate("click"); expect(onFilter).toHaveBeenCalledWith(["2"]); dropdownWrapper.find("label").at(0).simulate("click"); }); it("是否能够外部控制", function () { var wrapper = (0, _enzyme.mount)(_react["default"].createElement(FilterMounter, null)); var th = wrapper.find("[role='columnheader']").at(0); th.simulate("click"); var dropdownWrapper = (0, _enzyme.mount)(wrapper.find("Trigger").instance().getComponent()); dropdownWrapper.find("label").at(0).simulate("click"); expect(wrapper.find(".adui-table-filter").at(0).props()["data-value"]).toEqual(["all"]); }); }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["window","ResizeObserver","jest","fn","mockImplementation","disconnect","observe","unobserve","Column","Table","filters","text","value","FilterMounter","useState","filteredValue","set","filter","argFilteredValue","describe","beforeEach","useFakeTimers","afterEach","useRealTimers","it","stub","sinon","console","render","expect","calledOnce","toEqual","restore","onFilter","wrapper","TestRenderer","create","toMatchSnapshot","mount","th","find","at","simulate","dropdownWrapper","instance","getComponent","toHaveBeenCalledWith","props"],"sources":["../../../components/table/__tests__/filter.test.tsx"],"sourcesContent":["import React, { useState } from \"react\"\nimport { render, mount } from \"enzyme\"\nimport TestRenderer from \"react-test-renderer\"\nimport * as sinon from \"sinon\"\nimport Table from \"..\"\n\nwindow.ResizeObserver =\n  window.ResizeObserver ||\n  jest.fn().mockImplementation(() => ({\n    disconnect: jest.fn(),\n    observe: jest.fn(),\n    unobserve: jest.fn(),\n  }))\n\nconst { Column } = Table\n\nconst filters = [\n  {\n    text: \"朋友圈广告\",\n    value: \"1\",\n  },\n  {\n    text: \"公众号广告\",\n    value: \"2\",\n  },\n]\n\nconst FilterMounter = () => {\n  const [filteredValue, set] = useState<any>(null)\n\n  return (\n    <Table\n      dataSource={[\n        {\n          filter: \"filter\",\n        },\n      ]}\n    >\n      <Column\n        title=\"筛选\"\n        dataIndex=\"filter\"\n        filters={filters}\n        filteredValue={filteredValue}\n        onFilter={(argFilteredValue) => set(argFilteredValue)}\n      />\n    </Table>\n  )\n}\n\ndescribe(\"筛选功能\", () => {\n  beforeEach(() => {\n    jest.useFakeTimers()\n  })\n\n  afterEach(() => {\n    jest.useRealTimers()\n  })\n\n  // it(\"onFilter Prop 是否能验证 function\", () => {\n  //   const stub = sinon.stub(console, 'error')\n  //   const wrapper = render(\n  //     <Table>\n  //       <Table.Column\n  //         title=\"title\"\n  //         onFilter=\"string\"\n  //       />\n  //     </Table>\n  //   )\n  //   expect(stub.callCount).toBe(1)\n  //   (console as IConsole).error.restore()\n  // })\n\n  it(\"onFilter 不能与 onSort 共用\", () => {\n    const stub = sinon.stub(console, \"error\")\n    render(\n      <Table>\n        <Table.Column title=\"title\" onFilter={() => {}} onSort={() => {}} />\n      </Table>\n    )\n    expect(stub.calledOnce).toEqual(true)\n    stub.restore()\n  })\n\n  it(\"是否正确渲染\", () => {\n    const onFilter = jest.fn()\n    const wrapper = TestRenderer.create(\n      <Table\n        dataSource={[\n          {\n            filter: \"filter\",\n          },\n        ]}\n      >\n        <Column\n          title=\"筛选\"\n          dataIndex=\"filter\"\n          filters={filters}\n          onFilter={onFilter}\n        />\n      </Table>\n    )\n    expect(wrapper).toMatchSnapshot()\n  })\n\n  it(\"是否能够内部驱动\", () => {\n    const onFilter = jest.fn()\n    const wrapper = mount(\n      <Table\n        dataSource={[\n          {\n            filter: \"filter\",\n          },\n        ]}\n      >\n        <Column\n          title=\"筛选\"\n          dataIndex=\"filter\"\n          filters={filters}\n          onFilter={onFilter}\n        />\n      </Table>\n    )\n    const th = wrapper.find(\"[role='columnheader']\").at(0)\n    th.simulate(\"click\")\n    const dropdownWrapper = mount(\n      wrapper.find(\"Trigger\").instance().getComponent()\n    )\n    dropdownWrapper.find(\"label\").at(1).simulate(\"click\")\n    // expect(\n    //   wrapper\n    //     .find(\".adui-table-filter\")\n    //     .at(0)\n    //     .props()[\"data-value\"]\n    // ).toEqual([\"1\"])\n    expect(onFilter).toHaveBeenCalledWith([\"1\"])\n    dropdownWrapper.find(\"label\").at(2).simulate(\"click\")\n    // expect(\n    //   wrapper\n    //     .find(\".adui-table-filter\")\n    //     .at(0)\n    //     .props()[\"data-value\"]\n    // ).toEqual([\"2\"])\n    expect(onFilter).toHaveBeenCalledWith([\"2\"])\n    /**\n     * 不知道为什么进不到这个逻辑里，导致 TableFilter 的 Statements 不能 100%\n     * if (filteredValue === \"all\") {\n     *      onFilter([])\n     * }\n     */\n    dropdownWrapper.find(\"label\").at(0).simulate(\"click\")\n    // jest.runAllTimers()\n  })\n\n  it(\"是否能够外部控制\", () => {\n    const wrapper = mount(<FilterMounter />)\n    const th = wrapper.find(\"[role='columnheader']\").at(0)\n    th.simulate(\"click\")\n    const dropdownWrapper = mount(\n      wrapper.find(\"Trigger\").instance().getComponent()\n    )\n    dropdownWrapper.find(\"label\").at(0).simulate(\"click\")\n    expect(\n      wrapper.find(\".adui-table-filter\").at(0).props()[\"data-value\"]\n    ).toEqual([\"all\"])\n    // dropdownWrapper\n    //   .find(\"label\")\n    //   .at(2)\n    //   .simulate(\"click\")\n    // expect(\n    //   wrapper\n    //     .find(\".adui-table-filter\")\n    //     .at(0)\n    //     .props()[\"data-value\"]\n    // ).toEqual([\"2\"])\n  })\n})\n"],"mappings":"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"}