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>

85 lines 15.5 kB
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _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(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } import * as React from "react"; import TestRenderer from "react-test-renderer"; import { mount } from "enzyme"; import Checkbox from ".."; var Group = Checkbox.Group; var GroupMounter = function GroupMounter() { var _React$useState = React.useState([]), _React$useState2 = _slicedToArray(_React$useState, 2), value = _React$useState2[0], setValue = _React$useState2[1]; return React.createElement(Group, { value: value, onChange: setValue }, React.createElement(Checkbox, null, "children0"), React.createElement(Checkbox, null, "children1")); }; describe("Checkbox", function () { it("Group 是否正确渲染", function () { var wrapper = TestRenderer.create(React.createElement(Group, null, React.createElement(Checkbox, null, "children0"), React.createElement(Checkbox, null, "children1"))); expect(wrapper).toMatchSnapshot(); }); it("Group 是否能内部驱动", function () { var onChange = jest.fn(); var wrapper0 = mount(React.createElement(Group, { onChange: onChange }, React.createElement(Checkbox, null, "children0"), React.createElement(Checkbox, null, "children1"))); var wrapper1 = mount(React.createElement(Group, { defaultValue: ["children0"], onChange: onChange }, React.createElement(Checkbox, null, "children0"), React.createElement(Checkbox, null, "children1"))); wrapper0.find("label").at(0).simulate("click"); expect(onChange).toHaveBeenCalledWith(["children0"]); wrapper0.find("label").at(1).simulate("click"); expect(onChange).toHaveBeenCalledWith(["children0", "children1"]); wrapper1.find("label").at(0).simulate("click"); expect(onChange).toHaveBeenCalledWith([]); wrapper1.find("label").at(1).simulate("click"); expect(onChange).toHaveBeenCalledWith(["children1"]); }); it("Group 是否能外部控制", function () { var wrapper = mount(React.createElement(GroupMounter, null)); wrapper.find("label").at(0).simulate("click"); expect(wrapper.find("div").at(0).props()["data-value"]).toEqual(["children0"]); }); it("Group 是否正确处理 value State", function () { var wrapper1 = mount(React.createElement(Group, { defaultValue: ["children0"] }, React.createElement(Checkbox, { disabled: true }, "children0"), React.createElement(Checkbox, { value: 27 }, "children1"), React.createElement(Checkbox, { checked: true }, "children2"), React.createElement(Checkbox, { checked: true, value: 3 }, "children3"))); expect(wrapper1.find("div").at(0).props()["data-value"]).toEqual(["children0"]); wrapper1.find("label").at(3).simulate("click"); expect(wrapper1.find("div").at(0).props()["data-value"]).toEqual(["children0", 3]); var wrapper2 = mount(React.createElement(Group, { defaultValue: [123], value: [27] }, React.createElement(Checkbox, { disabled: true, value: 123 }, "children0"), React.createElement(Checkbox, { value: 27 }, "children1"), React.createElement(Checkbox, { checked: true }, "children2"), React.createElement(Checkbox, { checked: true, value: 3 }, "children3"))); expect(wrapper2.find("div").at(0).props()["data-value"]).toEqual([27]); wrapper2.find("label").at(3).simulate("click"); expect(wrapper2.find("div").at(0).props()["data-value"]).toEqual([27]); }); }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","TestRenderer","mount","Checkbox","Group","GroupMounter","_React$useState","useState","_React$useState2","_slicedToArray","value","setValue","createElement","onChange","describe","it","wrapper","create","expect","toMatchSnapshot","jest","fn","wrapper0","wrapper1","defaultValue","find","at","simulate","toHaveBeenCalledWith","props","toEqual","disabled","checked","wrapper2"],"sources":["../../../components/checkbox/__tests__/group.test.tsx"],"sourcesContent":["import * as React from \"react\"\nimport TestRenderer from \"react-test-renderer\"\nimport { mount } from \"enzyme\"\nimport Checkbox from \"..\"\n\nconst { Group } = Checkbox\n\nconst GroupMounter = () => {\n  const [value, setValue] = React.useState([])\n  return (\n    <Group value={value} onChange={setValue}>\n      <Checkbox>children0</Checkbox>\n      <Checkbox>children1</Checkbox>\n    </Group>\n  )\n}\n\ndescribe(\"Checkbox\", () => {\n  it(\"Group 是否正确渲染\", () => {\n    const wrapper = TestRenderer.create(\n      <Group>\n        <Checkbox>children0</Checkbox>\n        <Checkbox>children1</Checkbox>\n      </Group>\n    )\n    expect(wrapper).toMatchSnapshot()\n  })\n\n  it(\"Group 是否能内部驱动\", () => {\n    const onChange = jest.fn()\n    const wrapper0 = mount(\n      <Group onChange={onChange}>\n        <Checkbox>children0</Checkbox>\n        <Checkbox>children1</Checkbox>\n      </Group>\n    )\n    const wrapper1 = mount(\n      <Group defaultValue={[\"children0\"]} onChange={onChange}>\n        <Checkbox>children0</Checkbox>\n        <Checkbox>children1</Checkbox>\n      </Group>\n    )\n    wrapper0.find(\"label\").at(0).simulate(\"click\")\n    expect(onChange).toHaveBeenCalledWith([\"children0\"])\n    wrapper0.find(\"label\").at(1).simulate(\"click\")\n    expect(onChange).toHaveBeenCalledWith([\"children0\", \"children1\"])\n\n    wrapper1.find(\"label\").at(0).simulate(\"click\")\n    expect(onChange).toHaveBeenCalledWith([])\n    wrapper1.find(\"label\").at(1).simulate(\"click\")\n    expect(onChange).toHaveBeenCalledWith([\"children1\"])\n  })\n\n  it(\"Group 是否能外部控制\", () => {\n    const wrapper = mount(<GroupMounter />)\n    wrapper.find(\"label\").at(0).simulate(\"click\")\n    expect(wrapper.find(\"div\").at(0).props()[\"data-value\"]).toEqual([\n      \"children0\",\n    ])\n  })\n\n  it(\"Group 是否正确处理 value State\", () => {\n    // 确保优先判断 Prop defaultValue，如果存在默认值，则 Group 状态为此默认值\n    const wrapper1 = mount(\n      <Group defaultValue={[\"children0\"]}>\n        <Checkbox disabled>children0</Checkbox>\n        <Checkbox value={27}>children1</Checkbox>\n        <Checkbox checked>children2</Checkbox>\n        <Checkbox checked value={3}>\n          children3\n        </Checkbox>\n      </Group>\n    )\n    expect(wrapper1.find(\"div\").at(0).props()[\"data-value\"]).toEqual([\n      \"children0\",\n    ])\n    wrapper1.find(\"label\").at(3).simulate(\"click\")\n    expect(wrapper1.find(\"div\").at(0).props()[\"data-value\"]).toEqual([\n      \"children0\",\n      3,\n    ])\n\n    // 确保最优先判断 Prop value，如果存在 Prop value，则 Group 完全交由外部控制，内部状态无效。\n    const wrapper2 = mount(\n      <Group defaultValue={[123]} value={[27]}>\n        <Checkbox disabled value={123}>\n          children0\n        </Checkbox>\n        <Checkbox value={27}>children1</Checkbox>\n        <Checkbox checked>children2</Checkbox>\n        <Checkbox checked value={3}>\n          children3\n        </Checkbox>\n      </Group>\n    )\n    expect(wrapper2.find(\"div\").at(0).props()[\"data-value\"]).toEqual([27])\n    wrapper2.find(\"label\").at(3).simulate(\"click\")\n    expect(wrapper2.find(\"div\").at(0).props()[\"data-value\"]).toEqual([27])\n  })\n})\n"],"mappings":"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","ignoreList":[]}