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>
73 lines • 12.3 kB
JavaScript
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 React, { useState } from "react";
import { mount } from "enzyme";
import TestRenderer from "react-test-renderer";
import Radio from "..";
var RadioMounter = function RadioMounter() {
var _useState = useState(false),
_useState2 = _slicedToArray(_useState, 2),
checked = _useState2[0],
setChecked = _useState2[1];
return React.createElement(Radio, {
checked: checked,
onChange: function onChange(bool) {
return setChecked(bool);
}
});
};
describe("Radio", function () {
it("Radio 是否正确渲染", function () {
var wrapper = TestRenderer.create(React.createElement(Radio, null, "children"));
expect(wrapper).toMatchSnapshot();
});
it("Radio 是否能内部驱动", function () {
var onChange = jest.fn();
var wrapper = mount(React.createElement(Radio, {
onChange: onChange
}));
wrapper.find("label").at(0).simulate("click");
expect(wrapper.find("label").at(0).props().className.includes("checked")).toEqual(true);
expect(onChange).toHaveBeenCalledWith(true);
});
it("Radio 是否能受外部控制", function () {
var onChange = jest.fn();
var wrapper0 = mount(React.createElement(Radio, {
checked: false,
onChange: onChange
}));
var wrapper1 = mount(React.createElement(RadioMounter, null));
wrapper0.find("label").at(0).simulate("click");
expect(onChange).toHaveBeenCalledWith(true);
expect(wrapper0.find("label").at(0).props().className.includes("checked")).toEqual(false);
wrapper1.find("label").at(0).simulate("click");
expect(wrapper1.find("label").at(0).props().className.includes("checked")).toEqual(true);
wrapper1.find("label").at(0).simulate("click");
expect(wrapper1.find("label").at(0).props().className.includes("checked")).toEqual(true);
});
it("Radio 是否能响应 onClick", function () {
var onClick = jest.fn();
var wrapper = mount(React.createElement(Radio, {
onClick: onClick
}));
wrapper.find("label").at(0).simulate("click");
expect(onClick).toHaveBeenCalled();
});
it("Radio 是否能响应 enter", function () {
var onChange = jest.fn();
var wrapper = mount(React.createElement(Radio, {
onChange: onChange
}));
wrapper.find("label").at(0).simulate("keydown", {
key: "enter",
keyCode: 13
});
expect(wrapper.find("label").at(0).props().className.includes("checked")).toEqual(true);
expect(onChange).toHaveBeenCalledWith(true);
});
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useState","mount","TestRenderer","Radio","RadioMounter","_useState","_useState2","_slicedToArray","checked","setChecked","createElement","onChange","bool","describe","it","wrapper","create","expect","toMatchSnapshot","jest","fn","find","at","simulate","props","className","includes","toEqual","toHaveBeenCalledWith","wrapper0","wrapper1","onClick","toHaveBeenCalled","key","keyCode"],"sources":["../../../components/radio/__tests__/radio.test.tsx"],"sourcesContent":["import React, { useState } from \"react\"\nimport { mount } from \"enzyme\"\nimport TestRenderer from \"react-test-renderer\"\nimport Radio from \"..\"\n\nconst RadioMounter = () => {\n  const [checked, setChecked] = useState(false)\n  return <Radio checked={checked} onChange={(bool) => setChecked(bool)} />\n}\n\ndescribe(\"Radio\", () => {\n  it(\"Radio 是否正确渲染\", () => {\n    const wrapper = TestRenderer.create(<Radio>children</Radio>)\n    expect(wrapper).toMatchSnapshot()\n  })\n\n  it(\"Radio 是否能内部驱动\", () => {\n    const onChange = jest.fn()\n    const wrapper = mount(<Radio onChange={onChange} />)\n    wrapper.find(\"label\").at(0).simulate(\"click\")\n    expect(\n      wrapper.find(\"label\").at(0).props().className.includes(\"checked\")\n    ).toEqual(true)\n    expect(onChange).toHaveBeenCalledWith(true)\n  })\n\n  it(\"Radio 是否能受外部控制\", () => {\n    const onChange = jest.fn()\n    const wrapper0 = mount(<Radio checked={false} onChange={onChange} />)\n    const wrapper1 = mount(<RadioMounter />)\n    /**\n     * 1. 确定 onChange 还是会传回应该变化的值；\n     * 2. 但是由于 Radio 完全受外部控制，所以要确定内部状态不会改变。\n     */\n    wrapper0.find(\"label\").at(0).simulate(\"click\")\n    expect(onChange).toHaveBeenCalledWith(true)\n    expect(\n      wrapper0.find(\"label\").at(0).props().className.includes(\"checked\")\n    ).toEqual(false)\n\n    wrapper1.find(\"label\").at(0).simulate(\"click\")\n    expect(\n      wrapper1.find(\"label\").at(0).props().className.includes(\"checked\")\n    ).toEqual(true)\n    wrapper1.find(\"label\").at(0).simulate(\"click\")\n    expect(\n      wrapper1.find(\"label\").at(0).props().className.includes(\"checked\")\n    ).toEqual(true)\n  })\n\n  it(\"Radio 是否能响应 onClick\", () => {\n    const onClick = jest.fn()\n    const wrapper = mount(<Radio onClick={onClick} />)\n    wrapper.find(\"label\").at(0).simulate(\"click\")\n    expect(onClick).toHaveBeenCalled()\n  })\n\n  it(\"Radio 是否能响应 enter\", () => {\n    const onChange = jest.fn()\n    const wrapper = mount(<Radio onChange={onChange} />)\n    wrapper\n      .find(\"label\")\n      .at(0)\n      .simulate(\"keydown\", { key: \"enter\", keyCode: 13 })\n    expect(\n      wrapper.find(\"label\").at(0).props().className.includes(\"checked\")\n    ).toEqual(true)\n    expect(onChange).toHaveBeenCalledWith(true)\n  })\n})\n"],"mappings":"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","ignoreList":[]}