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>
127 lines (118 loc) • 15.4 kB
JavaScript
;
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 _testUtils = require("react-dom/test-utils");
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; }
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":["describe","beforeEach","jest","useFakeTimers","afterEach","useRealTimers","it","wrapper","mount","child","find","at","simulate","expect","props","popupVisible","toBe","Element","prototype","getBoundingClientRect","fn","width","height","top","left","bottom","right","x","y","toJSON","document","body","innerHTML","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":";;;;AAKA;;AACA;;AACA;;AACA;;;;;;;;AAEAA,QAAQ,CAAC,SAAD,EAAY,YAAM;EACxBC,UAAU,CAAC,YAAM;IACfC,IAAI,CAACC,aAAL;EACD,CAFS,CAAV;EAIAC,SAAS,CAAC,YAAM;IACdF,IAAI,CAACG,aAAL;EACD,CAFQ,CAAT;EAIAC,EAAE,CAAC,SAAD,EAAY,YAAM;IAClB,IAAMC,OAAO,GAAG,IAAAC,aAAA,EACd,oBAAC,YAAD;MACE,SAAS,MADX;MAEE,SAAS,EAAC,KAFZ;MAGE,eAAe,EAAE,CAHnB;MAIE,eAAe,EAAE,CAJnB;MAKE,KAAK,EAAE;QAAK,EAAE,EAAC;MAAR;IALT,GAOE;MAAK,EAAE,EAAC;IAAR,cAPF,CADc,CAAhB;IAWA,IAAMC,KAAK,GAAGF,OAAO,CAACG,IAAR,CAAa,WAAb,EAA0BC,EAA1B,CAA6B,CAA7B,CAAd;IACAF,KAAK,CAACG,QAAN,CAAe,YAAf;IACAC,MAAM,CAACN,OAAO,CAACG,IAAR,CAAa,SAAb,EAAwBC,EAAxB,CAA2B,CAA3B,EAA8BG,KAA9B,GAAsCC,YAAvC,CAAN,CAA2DC,IAA3D,CAAgE,IAAhE;IACAP,KAAK,CAACG,QAAN,CAAe,YAAf;IACAC,MAAM,CAACN,OAAO,CAACG,IAAR,CAAa,SAAb,EAAwBC,EAAxB,CAA2B,CAA3B,EAA8BG,KAA9B,GAAsCC,YAAvC,CAAN,CAA2DC,IAA3D,CAAgE,KAAhE;EACD,CAjBC,CAAF;AAkBD,CA3BO,CAAR;AA6BAhB,QAAQ,CAAC,mCAAD,EAAsC,YAAM;EAClDC,UAAU,CAAC,YAAM;IACfC,IAAI,CAACC,aAAL;IAMAc,OAAO,CAACC,SAAR,CAAkBC,qBAAlB,GAA0CjB,IAAI,CAACkB,EAAL,CAAQ,YAAM;MACtD,OAAO;QACLC,KAAK,EAAE,GADF;QAELC,MAAM,EAAE,GAFH;QAGLC,GAAG,EAAE,CAAC,EAHD;QAILC,IAAI,EAAE,CAJD;QAKLC,MAAM,EAAE,CALH;QAMLC,KAAK,EAAE,CANF;QAOLC,CAAC,EAAE,CAPE;QAQLC,CAAC,EAAE,CAAC,EARC;QASLC,MAAM,EAAE,kBAAM,CAAE;MATX,CAAP;IAWD,CAZyC,CAA1C;EAaD,CApBS,CAAV;EAsBAvB,EAAE,CAAC,iBAAD,EAAoB,YAAM;IAC1BwB,QAAQ,CAACC,IAAT,CAAcC,SAAd,GAA0B,sBAA1B;IACA,IAAMzB,OAAO,GAAG,IAAAC,aAAA,EACd,oBAAC,YAAD;MACE,IAAI,MADN;MAEE,OAAO,MAFT;MAGE,SAAS,EAAC,KAHZ;MAIE,eAAe,EAAE,CAJnB;MAKE,eAAe,EAAE,CALnB;MAME,KAAK,EAAC;IANR,GAQE;MAAK,EAAE,EAAC;IAAR,cARF,CADc,EAWd;MAAEyB,QAAQ,EAAEH,QAAQ,CAACI,cAAT,CAAwB,SAAxB;IAAZ,CAXc,CAAhB;IAaAJ,QAAQ,CAACC,IAAT,CAAcI,SAAd,GAA0B,CAA1B;IACA,IAAM1B,KAAK,GAAGF,OAAO,CAACG,IAAR,CAAa,WAAb,EAA0BC,EAA1B,CAA6B,CAA7B,CAAd;IACA,IAAAyB,cAAA,EAAI,YAAM;MACR3B,KAAK,CAACG,QAAN,CAAe,YAAf;MAEAV,IAAI,CAACmC,YAAL;MAIA9B,OAAO,CAAC+B,MAAR;IACD,CARD;IAUAzB,MAAM,CAACN,OAAO,CAACG,IAAR,CAAa,YAAb,EAA2BC,EAA3B,CAA8B,CAA9B,EAAiCG,KAAjC,GAAyCyB,cAA1C,CAAN,CAAgEvB,IAAhE,CACE,QADF;EAGD,CA9BC,CAAF;AA+BD,CAtDO,CAAR;AAwDAhB,QAAQ,CAAC,sCAAD,EAAyC,YAAM;EACrDC,UAAU,CAAC,YAAM;IACfC,IAAI,CAACC,aAAL;IAMAc,OAAO,CAACC,SAAR,CAAkBC,qBAAlB,GAA0CjB,IAAI,CAACkB,EAAL,CAAQ,YAAM;MACtD,OAAO;QACLC,KAAK,EAAE,GADF;QAELC,MAAM,EAAE,GAFH;QAGLC,GAAG,EAAE,IAHA;QAILC,IAAI,EAAE,CAJD;QAKLC,MAAM,EAAE,CALH;QAMLC,KAAK,EAAE,CANF;QAOLC,CAAC,EAAE,CAPE;QAQLC,CAAC,EAAE,IARE;QASLC,MAAM,EAAE,kBAAM,CAAE;MATX,CAAP;IAWD,CAZyC,CAA1C;EAaD,CApBS,CAAV;EAsBAvB,EAAE,CAAC,iBAAD,EAAoB,YAAM;IAC1BwB,QAAQ,CAACC,IAAT,CAAcC,SAAd,GAA0B,sBAA1B;IACA,IAAMzB,OAAO,GAAG,IAAAC,aAAA,EACd,oBAAC,YAAD;MACE,IAAI,MADN;MAEE,OAAO,MAFT;MAGE,SAAS,EAAC,QAHZ;MAIE,eAAe,EAAE,CAJnB;MAKE,eAAe,EAAE,CALnB;MAME,KAAK,EAAC;IANR,GAQE;MAAK,EAAE,EAAC;IAAR,cARF,CADc,EAWd;MAAEyB,QAAQ,EAAEH,QAAQ,CAACI,cAAT,CAAwB,SAAxB;IAAZ,CAXc,CAAhB;IAaAJ,QAAQ,CAACC,IAAT,CAAcI,SAAd,GAA0B,CAA1B;IACA,IAAM1B,KAAK,GAAGF,OAAO,CAACG,IAAR,CAAa,WAAb,EAA0BC,EAA1B,CAA6B,CAA7B,CAAd;IACA,IAAAyB,cAAA,EAAI,YAAM;MACR3B,KAAK,CAACG,QAAN,CAAe,YAAf;MAEAV,IAAI,CAACmC,YAAL;MAIA9B,OAAO,CAAC+B,MAAR;IACD,CARD;IAUAzB,MAAM,CAACN,OAAO,CAACG,IAAR,CAAa,YAAb,EAA2BC,EAA3B,CAA8B,CAA9B,EAAiCG,KAAjC,GAAyCyB,cAA1C,CAAN,CAAgEvB,IAAhE,CAAqE,KAArE;EACD,CA5BC,CAAF;AA6BD,CApDO,CAAR"}