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>
113 lines • 14.4 kB
JavaScript
import * as React from "react";
import { act } from "react-dom/test-utils";
import { mount } from "enzyme";
import Tooltip from "..";
describe("Tooltip", function () {
beforeEach(function () {
jest.useFakeTimers();
});
afterEach(function () {
jest.useRealTimers();
});
it("是否能内部驱动", function () {
var wrapper = mount(React.createElement(Tooltip, {
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 = mount(React.createElement(Tooltip, {
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);
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 = mount(React.createElement(Tooltip, {
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);
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","act","mount","Tooltip","describe","beforeEach","jest","useFakeTimers","afterEach","useRealTimers","it","wrapper","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","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":[]}