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 • 13.8 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","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","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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"}