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>

119 lines (118 loc) 17.5 kB
"use strict"; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } var React = _interopRequireWildcard(require("react")); var _testUtils = require("react-dom/test-utils"); var _enzyme = require("enzyme"); var _ = _interopRequireDefault(require("..")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; } function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } describe("Tooltip", function () { beforeEach(function () { jest.useFakeTimers(); }); afterEach(function () { jest.useRealTimers(); }); it("是否能内部驱动", function () { var wrapper = (0, _enzyme.mount)(React.createElement(_["default"], { alignEdge: true, placement: "top", mouseEnterDelay: 0, mouseLeaveDelay: 0, popup: React.createElement("div", { id: "popup" }, "popup") }, React.createElement("div", { id: "children" }, "children"))); var child = wrapper.find("#children").at(0); child.simulate("mouseenter"); expect(wrapper.find("Trigger").at(0).props().popupVisible).toBe(true); child.simulate("mouseleave"); expect(wrapper.find("Trigger").at(0).props().popupVisible).toBe(false); }); }); describe("Tooltip 测试 handlePopupAlign - Top", function () { beforeEach(function () { jest.useFakeTimers(); Element.prototype.getBoundingClientRect = jest.fn(function () { return { width: 120, height: 120, top: -10, left: 0, bottom: 0, right: 0, x: 0, y: -10, toJSON: function toJSON() {} }; }); }); it("是否处理 PopupAlign", function () { document.body.innerHTML = '<div id="mounter" />'; var wrapper = (0, _enzyme.mount)(React.createElement(_["default"], { test: true, visible: true, placement: "top", mouseEnterDelay: 0, mouseLeaveDelay: 0, popup: "popup" }, React.createElement("div", { id: "children" }, "children")), { attachTo: document.getElementById("mounter") }); document.body.scrollTop = 0; var child = wrapper.find("#children").at(0); (0, _testUtils.act)(function () { child.simulate("mouseenter"); jest.runAllTimers(); wrapper.update(); }); expect(wrapper.find("PopTrigger").at(0).props().popupPlacement).toBe("bottom"); }); }); describe("Tooltip 测试 handlePopupAlign - Bottom", function () { beforeEach(function () { jest.useFakeTimers(); Element.prototype.getBoundingClientRect = jest.fn(function () { return { width: 120, height: 120, top: 1000, left: 0, bottom: 0, right: 0, x: 0, y: 1000, toJSON: function toJSON() {} }; }); }); it("是否处理 PopupAlign", function () { document.body.innerHTML = '<div id="mounter" />'; var wrapper = (0, _enzyme.mount)(React.createElement(_["default"], { test: true, visible: true, placement: "bottom", mouseEnterDelay: 0, mouseLeaveDelay: 0, popup: "popup" }, React.createElement("div", { id: "children" }, "children")), { attachTo: document.getElementById("mounter") }); document.body.scrollTop = 0; var child = wrapper.find("#children").at(0); (0, _testUtils.act)(function () { child.simulate("mouseenter"); jest.runAllTimers(); wrapper.update(); }); expect(wrapper.find("PopTrigger").at(0).props().popupPlacement).toBe("top"); }); }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_testUtils","_enzyme","_","_interopRequireDefault","e","__esModule","_getRequireWildcardCache","WeakMap","r","t","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","describe","beforeEach","jest","useFakeTimers","afterEach","useRealTimers","it","wrapper","mount","createElement","alignEdge","placement","mouseEnterDelay","mouseLeaveDelay","popup","id","child","find","at","simulate","expect","props","popupVisible","toBe","Element","prototype","getBoundingClientRect","fn","width","height","top","left","bottom","right","x","y","toJSON","document","body","innerHTML","test","visible","attachTo","getElementById","scrollTop","act","runAllTimers","update","popupPlacement"],"sources":["../../../components/tooltip/__tests__/index.test.tsx"],"sourcesContent":["/* eslint-disable */\n/**\n * Tooltip 是基于 PopTrigger 进行封装的。\n * 除非与 Tooltip 相关，否则测试用例都应在 PopTrigger 下。\n */\nimport * as React from \"react\"\nimport { act } from \"react-dom/test-utils\"\nimport { mount } from \"enzyme\"\nimport Tooltip from \"..\"\n\ndescribe(\"Tooltip\", () => {\n  beforeEach(() => {\n    jest.useFakeTimers()\n  })\n\n  afterEach(() => {\n    jest.useRealTimers()\n  })\n\n  it(\"是否能内部驱动\", () => {\n    const wrapper = mount(\n      <Tooltip\n        alignEdge\n        placement=\"top\"\n        mouseEnterDelay={0}\n        mouseLeaveDelay={0}\n        popup={<div id=\"popup\">popup</div>}\n      >\n        <div id=\"children\">children</div>\n      </Tooltip>\n    )\n    const child = wrapper.find(\"#children\").at(0)\n    child.simulate(\"mouseenter\")\n    expect(wrapper.find(\"Trigger\").at(0).props().popupVisible).toBe(true)\n    child.simulate(\"mouseleave\")\n    expect(wrapper.find(\"Trigger\").at(0).props().popupVisible).toBe(false)\n  })\n})\n\ndescribe(\"Tooltip 测试 handlePopupAlign - Top\", () => {\n  beforeEach(() => {\n    jest.useFakeTimers()\n\n    /**\n     * https://stackoverflow.com/a/40006663\n     * 通过 mock `getBoundingClientRect`，之后运行的所有 `getBoundingClientRect` 都会返回这同一个值。\n     */\n    Element.prototype.getBoundingClientRect = jest.fn(() => {\n      return {\n        width: 120,\n        height: 120,\n        top: -10,\n        left: 0,\n        bottom: 0,\n        right: 0,\n        x: 0,\n        y: -10,\n        toJSON: () => {},\n      }\n    })\n  })\n\n  it(\"是否处理 PopupAlign\", () => {\n    document.body.innerHTML = '<div id=\"mounter\" />'\n    const wrapper = mount(\n      <Tooltip\n        test\n        visible\n        placement=\"top\"\n        mouseEnterDelay={0}\n        mouseLeaveDelay={0}\n        popup=\"popup\"\n      >\n        <div id=\"children\">children</div>\n      </Tooltip>,\n      { attachTo: document.getElementById(\"mounter\") }\n    )\n    document.body.scrollTop = 0\n    const child = wrapper.find(\"#children\").at(0)\n    act(() => {\n      child.simulate(\"mouseenter\")\n      // jest runAllTimers 是为了触发 Tooltip 内的 setTimeout 0\n      jest.runAllTimers()\n      // 必须执行 wrapper.update 否则拿到的 prop 还是旧的\n      // https://github.com/enzymejs/enzyme#react-hooks-support\n      // 血的教训\n      wrapper.update()\n    })\n\n    expect(wrapper.find(\"PopTrigger\").at(0).props().popupPlacement).toBe(\n      \"bottom\"\n    )\n  })\n})\n\ndescribe(\"Tooltip 测试 handlePopupAlign - Bottom\", () => {\n  beforeEach(() => {\n    jest.useFakeTimers()\n\n    /**\n     * https://stackoverflow.com/a/40006663\n     * 通过 mock `getBoundingClientRect`，之后运行的所有 `getBoundingClientRect` 都会返回这同一个值。\n     */\n    Element.prototype.getBoundingClientRect = jest.fn(() => {\n      return {\n        width: 120,\n        height: 120,\n        top: 1000,\n        left: 0,\n        bottom: 0,\n        right: 0,\n        x: 0,\n        y: 1000,\n        toJSON: () => {},\n      }\n    })\n  })\n\n  it(\"是否处理 PopupAlign\", () => {\n    document.body.innerHTML = '<div id=\"mounter\" />'\n    const wrapper = mount(\n      <Tooltip\n        test\n        visible\n        placement=\"bottom\"\n        mouseEnterDelay={0}\n        mouseLeaveDelay={0}\n        popup=\"popup\"\n      >\n        <div id=\"children\">children</div>\n      </Tooltip>,\n      { attachTo: document.getElementById(\"mounter\") }\n    )\n    document.body.scrollTop = 0\n    const child = wrapper.find(\"#children\").at(0)\n    act(() => {\n      child.simulate(\"mouseenter\")\n      // jest runAllTimers 是为了触发 Tooltip 内的 setTimeout 0\n      jest.runAllTimers()\n      // 必须执行 wrapper.update 否则拿到的 prop 还是旧的\n      // https://github.com/enzymejs/enzyme#react-hooks-support\n      // 血的教训\n      wrapper.update()\n    })\n\n    expect(wrapper.find(\"PopTrigger\").at(0).props().popupPlacement).toBe(\"top\")\n  })\n})\n"],"mappings":"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","ignoreList":[]}