{"id":18480,"date":"2025-10-23T17:43:52","date_gmt":"2025-10-23T17:43:52","guid":{"rendered":"https:\/\/pokecon.jp\/job\/?p=18480"},"modified":"2025-10-23T17:43:52","modified_gmt":"2025-10-23T17:43:52","slug":"storybook-%e3%81%a8-vitest-%e3%81%a7-userevent-%e5%8f%96%e3%82%8a%e9%81%95%e3%81%88%e3%82%92%e3%81%aa%e3%81%8f%e3%81%99","status":"publish","type":"post","link":"https:\/\/pokecon.jp\/job\/18480\/","title":{"rendered":"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059"},"content":{"rendered":"\n<\/p>\n<div>\n<p data-line=\"0\" class=\"code-line\">\u3053\u3093\u306b\u3061\u306f Social PLUS \u306e\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30a8\u30f3\u30b8\u30cb\u30a2\u306e\u307e\u3063\u304f\u3059\u3067\u3059\u3002<\/p>\n<p data-line=\"2\" class=\"code-line\">\u5148\u65e5\u3001Storybook \u3092 v7 \u2192 v8 \u306b\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u3092\u3057\u3066\u3044\u305f\u969b\u306b\u3001Vitest \u306e\u30c6\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u306b Storybook \u7528\u306e\u30e2\u30b8\u30e5\u30fc\u30eb<code>@storybook\/testing-library<\/code> \u304c\u7d1b\u308c\u3066\u3044\u305f\u3053\u3068\u306b\u6c17\u304c\u3064\u304d\u307e\u3057\u305f\u3002<br \/>Storybook \u306e\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u306b\u969b\u3057\u3066\u3001<code>@storybook\/testing-library<\/code> \u3092 <code>@storybook\/test<\/code> \u306b\u7d71\u5408\u3059\u308b\u305f\u3081\u306b\u3001<code>@storybook\/testing-library<\/code> \u3092 <code>devDependencies<\/code> \u304b\u3089\u524a\u9664\u3057\u305f\u3053\u3068\u3067\u3001Lint\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u307e\u3057\u305f\u3002<\/p>\n<p data-line=\"5\" class=\"code-line\">Copilot \u3084 IDE \u306e\u88dc\u5b8c\u306e\u7cbe\u5ea6\u304c\u826f\u304f\u306a\u3063\u305f\u305f\u3081\u3001\u4f55\u3082\u8003\u3048\u305a\u306b\u30a4\u30f3\u30dd\u30fc\u30c8\u306e\u88dc\u5b8c\u3092\u3057\u3066\u3044\u308b\u3053\u3068\u304c\u591a\u3044\u3067\u3059\uff08\u81ea\u5206\u3060\u3051\u304b\u3082\u3057\u308c\u306a\u3044\u304c\uff09\u3002\u304a\u305d\u3089\u304f\u3001<code>@storybook\/testing-library<\/code> \u304c\u7d1b\u308c\u3066\u3044\u305f\u306e\u3082\u3001\u4f55\u3082\u8003\u3048\u305a\u306b\u30a4\u30f3\u30dd\u30fc\u30c8\u3092\u3057\u3066\u3044\u305f\u3053\u3068\u304c\u539f\u56e0\u304b\u3068\u601d\u308f\u308c\u307e\u3059\u3002<\/p>\n<p data-line=\"7\" class=\"code-line\">\u5f71\u97ff\u306e\u5c11\u306a\u3044\u4e9b\u7d30\u306a\u30df\u30b9\u3067\u3059\u304c\u3001\u4ed5\u7d44\u307f\u3067\u89e3\u6c7a\u3067\u304d\u308b\u306e\u3067\u3001\u5c0f\u30cd\u30bf\u3068\u3057\u3066\u7d39\u4ecb\u3067\u304d\u308c\u3070\u3068\u601d\u3063\u3066\u3044\u307e\u3059\uff01<\/p>\n<h2 id=\"%E5%AF%BE%E8%B1%A1\" data-line=\"10\" class=\"code-line\">\n \u5bfe\u8c61<\/h2>\n<p data-line=\"12\" class=\"code-line\">Vitest\uff08\u307e\u305f\u306f Jest\uff09 \u3084 Storybook \u3092\u5229\u7528\u3057\u3066\u958b\u767a\u3057\u3066\u3044\u308b\u4eba<\/p>\n<h2 id=\"%E5%89%8D%E6%8F%90\" data-line=\"14\" class=\"code-line\">\n \u524d\u63d0<\/h2>\n<p data-line=\"16\" class=\"code-line\">\u5f0a\u793e\u306e\u73fe\u5728\u306e\u6280\u8853\u30b9\u30bf\u30c3\u30af<\/p>\n<ul data-line=\"17\" class=\"code-line\">\n<li data-line=\"17\" class=\"code-line\">\n<code>Next.js<\/code> v15<\/li>\n<li data-line=\"18\" class=\"code-line\">\n<code>Vitest<\/code> v2<\/li>\n<li data-line=\"19\" class=\"code-line\">\n<code>@testing-library\/react<\/code> v16<\/li>\n<li data-line=\"20\" class=\"code-line\">\n<code>@testing-library\/user-event<\/code> v14<\/li>\n<li data-line=\"21\" class=\"code-line\">\n<code>Storybook<\/code> v8<\/li>\n<\/ul>\n<h2 id=\"%E3%81%AA%E3%81%9C%E5%8F%96%E3%82%8A%E9%81%95%E3%81%88%E3%81%8C%E8%B5%B7%E3%81%8D%E3%82%8B%E3%81%8B\" data-line=\"24\" class=\"code-line\">\n \u306a\u305c\u53d6\u308a\u9055\u3048\u304c\u8d77\u304d\u308b\u304b<\/h2>\n<p data-line=\"26\" class=\"code-line\">\u6700\u521d\u306b\u3082\u66f8\u304d\u307e\u3057\u305f\u304c\u3001Cursor \u3084 VS Code \u3067 Copilot \u306e\u30b5\u30b8\u30a7\u30b9\u30c8\u306f\u512a\u79c0\u306a\u3082\u306e\u306e\u3001\u5b8c\u74a7\u3067\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\n<p data-line=\"28\" class=\"code-line\">Vitest \u306e\u30c6\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb \u3067 <code>@storybook\/test<\/code> \u306e <code>userEvent<\/code> \u304c\u30b5\u30b8\u30a7\u30b9\u30c8\u3055\u308c\u308b\u3002<br \/><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/528bc40d43d4-20251022.png\" alt=\"\" class=\"md-img\" loading=\"lazy\"\/><\/p>\n<p data-line=\"32\" class=\"code-line\">\u307e\u305f\u3001Storybook \u3067\u3082\u540c\u69d8\u306b <code>@testing-library\/user-event<\/code> \u306e <code>userEvent<\/code> \u304c\u30b5\u30b8\u30a7\u30b9\u30c8\u3055\u308c\u308b<br \/><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/d8299b324359-20251022.png\" alt=\"\" class=\"md-img\" loading=\"lazy\"\/><\/p>\n<p data-line=\"35\" class=\"code-line\">\u672c\u5f53\u3067\u3042\u308c\u3070\u6587\u8108\u306b\u5fdc\u3058\u3066\u30b5\u30b8\u30a7\u30b9\u30c8\u3059\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u306e\u9806\u756a\u3092\u5909\u66f4\u3057\u3066\u304f\u308c\u305f\u3089\u3044\u3044\u306e\u3067\u3059\u304c\u3001\u73fe\u72b6\u3067\u306f\u305d\u3046\u306f\u3044\u304d\u307e\u305b\u3093\u3002<br \/>\u8aa4\u3063\u305f\u30b5\u30b8\u30a7\u30b9\u30c8\u3092\u4f55\u3082\u8003\u3048\u305a\u306b\u78ba\u5b9a\u3059\u308b\u3068\u3001\u7570\u306a\u308b\u6587\u8108\u306e\u30e2\u30b8\u30e5\u30fc\u30eb\u304c\u6df7\u5165\u3059\u308b\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002\u3067\u3059\u306e\u3067\u3001\u4eba\u9593\u304c\u5bfe\u7b56\u3092\u3059\u308b\u4ed6\u306a\u3044\u3067\u3059\u3002<\/p>\n<p data-line=\"38\" class=\"code-line\">\u6b21\u306e\u7ae0\u304b\u3089\u306f\u3001Storybook \u3084\u30c6\u30b9\u30c8\u3067\u3069\u306e\u3088\u3046\u306b\u5bfe\u7b56\u3057\u3066\u3044\u304f\u304b\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<h2 id=\"%E7%B5%90%E8%AB%96\" data-line=\"41\" class=\"code-line\">\n \u7d50\u8ad6<\/h2>\n<p data-line=\"43\" class=\"code-line\">\u65e9\u901f\u7d50\u8ad6\u3067\u3059\u3002<br \/>\u7d50\u8ad6\u3068\u3057\u3066\u306f\ud83d\udc47\u306e\u901a\u308a\u3067\u3059\u3002<\/p>\n<ul data-line=\"45\" class=\"code-line\">\n<li data-line=\"45\" class=\"code-line\">Storybook\u3067\u306f <code>\"plugin:storybook\/recommended\"<\/code> \u3092\u6709\u52b9\u306b\u3059\u308b<\/li>\n<li data-line=\"46\" class=\"code-line\">\uff08\u53ef\u80fd\u306a\u3089\uff09Storybook v9 \u3078\u4e0a\u3052\u3001<code>play<\/code> \u306e\u5f15\u6570 <code>userEvent<\/code> \u3092\u53d7\u3051\u53d6\u3063\u3066\u4f7f\u3046\uff08v8 \u3067\u3042\u308c\u3070\u3000<code>@storybook\/test<\/code> \u306e <code>userEvent<\/code> \u3092 import \u3059\u308b\uff09<\/li>\n<li data-line=\"47\" class=\"code-line\">\u30c6\u30b9\u30c8\u3067\u306f <code>userEvent<\/code> \u3092\u76f4\u63a5\u30a4\u30f3\u30dd\u30fc\u30c8\u305b\u305a\u3001<code>@testing-library\/react<\/code> \u306e <code>render<\/code> \u95a2\u6570\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3057\u3066 <code>userEvent.setup()<\/code> \u6e08\u307f\u306e <code>user<\/code> \u3092\u8fd4\u3059\u3088\u3046\u306b\u3059\u308b<\/li>\n<\/ul>\n<p data-line=\"49\" class=\"code-line\">\u30a4\u30e1\u30fc\u30b8\u304c\u3064\u304d\u306b\u304f\u3044\u3068\u601d\u3044\u307e\u3059\u306e\u3067\u3001\u5177\u4f53\u7684\u306b\u307f\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n<h2 id=\"storybook-%E3%81%A7%E3%81%AE%E5%AF%BE%E7%AD%96\" data-line=\"51\" class=\"code-line\">\n Storybook \u3067\u306e\u5bfe\u7b56<\/h2>\n<p data-line=\"53\" class=\"code-line\">Storybook \u3067\u306f <code>plugin:storybook\/recommended<\/code> \u3092 <code>extends<\/code> \u306b\u5165\u308c\u308b\u3060\u3051\u3067 Lint \u30a8\u30e9\u30fc\u304c\u51fa\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p data-line=\"55\" class=\"code-line\">\u53c2\u8003<br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__3fabd45711597\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__3fabd45711597\" data-content=\"https%3A%2F%2Fstorybook.js.org%2Fdocs%2Fconfigure%2Fintegration%2Feslint-plugin%23installation\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/storybook.js.org\/docs\/configure\/integration\/eslint-plugin#installation\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/storybook.js.org\/docs\/configure\/integration\/eslint-plugin#installation<\/a><\/p>\n<p data-line=\"58\" class=\"code-line\">.eslintrc.js<\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-js\"><code class=\"language-js code-line\" data-line=\"59\">module<span class=\"token punctuation\">.<\/span><span class=\"token property-access\">exports<\/span> <span class=\"token operator\">=<\/span> <span class=\"token punctuation\">{<\/span>\n  <span class=\"token keyword\">extends<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">[<\/span>\n    \n    <span class=\"token string\">'plugin:storybook\/recommended'<\/span><span class=\"token punctuation\">,<\/span>\n  <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>\n  <span class=\"token literal-property property\">rules<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span>\n    \n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\n<\/code><\/pre>\n<\/div>\n<p data-line=\"71\" class=\"code-line\"><code>plugin:storybook\/recommended<\/code> \u8a2d\u5b9a\u5f8c<\/p>\n<p data-line=\"73\" class=\"code-line\">Storybook \u3067 <code>userEvent<\/code> \u3092 <code>@testing-library\/user-event<\/code> \u304b\u3089\u30a4\u30f3\u30dd\u30fc\u30c8\u3057\u305f\u7b87\u6240\u3067\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306bESLint \u306e\u30a8\u30e9\u30fc\u304c\u5410\u304b\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<blockquote data-line=\"74\" class=\"code-line\">\n<p data-line=\"74\" class=\"code-line\">Do not use <code>@testing-library\/user-event<\/code> directly in the story. You should import the functions from <code>@storybook\/testing-library<\/code> instead.eslintstorybook\/use-storybook-testing-library<\/p>\n<\/blockquote>\n<p data-line=\"77\" class=\"code-line\"><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/e2187546e1e2-20251022.png\" alt=\"\" class=\"md-img\" loading=\"lazy\"\/><\/p>\n<p data-line=\"79\" class=\"code-line\">\u307e\u305f\u3001Storybook v9 \u4ee5\u4e0a\u3067\u3042\u308c\u3070\u3001<code>userEvent<\/code> \u3092 \u76f4\u63a5\u30a4\u30f3\u30dd\u30fc\u30c8\u305b\u305a\u3001<code>play<\/code> \u306e\u5f15\u6570\u304b\u3089\u53d7\u3051\u53d6\u308b\u3088\u3046\u306b\u3059\u308b\u306e\u304c\u516c\u5f0f\u306e\u66f8\u304d\u65b9\u306b\u306a\u3063\u3066\u3044\u308b\u306e\u3067\u3001\u516c\u5f0f\u306e\u66f8\u304d\u65b9\u306b\u5023\u3046\u3053\u3068\u3067\u5bfe\u7b56\u3067\u304d\u307e\u3059\u3002<\/p>\n<p data-line=\"81\" class=\"code-line\">\u53c2\u8003<br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__ee592aab61fff\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__ee592aab61fff\" data-content=\"https%3A%2F%2Fstorybook.js.org%2Fdocs%2Fwriting-stories%2Fplay-function%23writing-stories-with-the-play-function\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/storybook.js.org\/docs\/writing-stories\/play-function#writing-stories-with-the-play-function\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/storybook.js.org\/docs\/writing-stories\/play-function#writing-stories-with-the-play-function<\/a><\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-tsx\"><code class=\"language-tsx code-line\" data-line=\"84\">\n\n<span class=\"token keyword\">import<\/span> <span class=\"token keyword\">type<\/span> <span class=\"token punctuation\">{<\/span> <span class=\"token maybe-class-name\">Meta<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token maybe-class-name\">StoryObj<\/span> <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'@storybook\/react'<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">import<\/span> <span class=\"token imports\"><span class=\"token punctuation\">{<\/span> userEvent <span class=\"token punctuation\">}<\/span><\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'@testing-library\/user-event'<\/span><span class=\"token punctuation\">;<\/span> \\\\ \ud83d\ude45\ud83c\udffb\u200d\u2642\ufe0f <span class=\"token maybe-class-name\">Story<\/span> \u5074\u3067 testing<span class=\"token operator\">-<\/span>library \u306e userEvent \u3092 <span class=\"token keyword\">import<\/span> \u3057\u3066\u3044\u308b\n<\/code><\/pre>\n<\/div>\n<div class=\"code-block-container\">\n<pre class=\"language-tsx\"><code class=\"language-tsx code-line\" data-line=\"91\">\n\n<span class=\"token keyword\">import<\/span> <span class=\"token keyword\">type<\/span> <span class=\"token punctuation\">{<\/span> <span class=\"token maybe-class-name\">Meta<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token maybe-class-name\">StoryObj<\/span> <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'@storybook\/react'<\/span><span class=\"token punctuation\">;<\/span>\n\n<span class=\"token keyword\">export<\/span> <span class=\"token keyword\">const<\/span> <span class=\"token maybe-class-name\">FilledForm<\/span><span class=\"token operator\">:<\/span> <span class=\"token maybe-class-name\">Story<\/span> <span class=\"token operator\">=<\/span> <span class=\"token punctuation\">{<\/span>\n  \n  <span class=\"token function-variable function\">play<\/span><span class=\"token operator\">:<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span> canvas<span class=\"token punctuation\">,<\/span> userEvent <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token arrow operator\">=&gt;<\/span> <span class=\"token punctuation\">{<\/span>\n   \n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\n<\/code><\/pre>\n<\/div>\n<h2 id=\"%E3%83%86%E3%82%B9%E3%83%88%E3%81%A7%E3%81%AE%E5%AF%BE%E7%AD%96\" data-line=\"105\" class=\"code-line\">\n \u30c6\u30b9\u30c8\u3067\u306e\u5bfe\u7b56<\/h2>\n<p data-line=\"107\" class=\"code-line\">ESLint \u306e <code>no-restricted-imports<\/code> \u3092\u8a2d\u5b9a\u3059\u308b\u3053\u3068\u3067 Lint \u30a8\u30e9\u30fc\u304c\u51fa\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p data-line=\"109\" class=\"code-line\">\u53c2\u8003<br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__11adef80bef37\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__11adef80bef37\" data-content=\"https%3A%2F%2Feslint.org%2Fdocs%2Flatest%2Frules%2Fno-restricted-imports\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/eslint.org\/docs\/latest\/rules\/no-restricted-imports\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/eslint.org\/docs\/latest\/rules\/no-restricted-imports<\/a><\/p>\n<p data-line=\"112\" class=\"code-line\">.eslintrc.js<\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-js\"><code class=\"language-js code-line\" data-line=\"113\">module<span class=\"token punctuation\">.<\/span><span class=\"token property-access\">exports<\/span> <span class=\"token operator\">=<\/span> <span class=\"token punctuation\">{<\/span>\n  <span class=\"token literal-property property\">overrides<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">[<\/span>\n    \n    <span class=\"token punctuation\">{<\/span>\n      <span class=\"token literal-property property\">files<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">'*.spec.{ts,tsx}'<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>\n      <span class=\"token literal-property property\">rules<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">{<\/span>\n         \n        <span class=\"token string-property property\">'no-restricted-imports'<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">[<\/span>\n          <span class=\"token string\">'error'<\/span><span class=\"token punctuation\">,<\/span>\n          <span class=\"token punctuation\">{<\/span>\n            <span class=\"token literal-property property\">paths<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">[<\/span>\n              <span class=\"token punctuation\">{<\/span>\n                <span class=\"token literal-property property\">name<\/span><span class=\"token operator\">:<\/span> <span class=\"token string\">'@storybook\/test'<\/span><span class=\"token punctuation\">,<\/span>\n                <span class=\"token literal-property property\">importNames<\/span><span class=\"token operator\">:<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token string\">'userEvent'<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>\n                <span class=\"token literal-property property\">message<\/span><span class=\"token operator\">:<\/span>\n                  <span class=\"token string\">'@storybook\/test \u304b\u3089 userEvent \u3092 import \u3057\u306a\u3044\u3067\u304f\u3060\u3055\u3044\u3002'<\/span><span class=\"token punctuation\">,<\/span>\n              <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span>\n            <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>\n          <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span>\n        <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>\n      <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span>\n    <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">,<\/span>\n  <span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\n<\/code><\/pre>\n<\/div>\n<p data-line=\"140\" class=\"code-line\"><code>no-restricted-imports<\/code> \u8a2d\u5b9a\u5f8c<\/p>\n<p data-line=\"142\" class=\"code-line\">Vitest \u3067 <code>userEvent<\/code> \u3092 <code>@storybook\/test<\/code> \u304b\u3089\u30a4\u30f3\u30dd\u30fc\u30c8\u3057\u305f\u7b87\u6240\u3067\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306bESLint \u306e\u30a8\u30e9\u30fc\u304c\u5410\u304b\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<blockquote data-line=\"143\" class=\"code-line\">\n<p data-line=\"143\" class=\"code-line\">&#8216;userEvent&#8217; import from &#8216;@storybook\/test&#8217; is restricted. @storybook\/test \u304b\u3089 userEvent \u3092 import \u3057\u306a\u3044\u3067\u304f\u3060\u3055\u3044\u3002eslintno-restricted-imports<\/p>\n<\/blockquote>\n<p data-line=\"145\" class=\"code-line\"><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/fd488baf8c58-20251022.png\" alt=\"\" class=\"md-img\" loading=\"lazy\"\/><\/p>\n<p data-line=\"148\" class=\"code-line\">\u3053\u308c\u3067\u3082\u3044\u3044\u306e\u3067\u3059\u304c\u3001<\/p>\n<ul data-line=\"150\" class=\"code-line\">\n<li data-line=\"150\" class=\"code-line\">\n<code>@testing-library\/user-event<\/code> v14 \u304b\u3089 <code>userEvent.setup()<\/code> \u3092\u4f7f\u3063\u305f\u66f8\u304d\u65b9\u304c\u5c0e\u5165\u3055\u308c\u3001\u63a8\u5968\u3068\u306a\u3063\u305f<\/li>\n<li data-line=\"151\" class=\"code-line\">\u30c6\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u3067\u305d\u306e\u90fd\u5ea6  <code>userEvent.setup()<\/code> \u3059\u308b\u306e\u304c\u9762\u5012<\/li>\n<li data-line=\"152\" class=\"code-line\">\u30c6\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u3067\u305d\u306e\u90fd\u5ea6 <code>render(<component\/>, { wrapper: TestWrapper });<\/code>  \u306e\u3088\u3046\u306b <code>wrapper<\/code> \u3092\u6307\u5b9a\u3059\u308b\u306e\u304c\u9762\u5012<\/li>\n<\/ul>\n<p data-line=\"154\" class=\"code-line\">\u3053\u306e\u3088\u3046\u306a\u7406\u7531\u304b\u3089\u3001 <code>@testing-library\/react<\/code> \u306e <code>render<\/code> \u3092\u72ec\u81ea\u306b\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3057\u305f\u3082\u306e\u3092\u5f0a\u793e\u3067\u306f\u5229\u7528\u3057\u3066\u3044\u307e\u3059\u3002\u4f7f\u3044\u52dd\u624b\u3082\u3044\u3044\u306e\u3067\u304a\u3059\u3059\u3081\u3067\u3059\u3002\u6b21\u306e\u7ae0\u3067\u306f\u5177\u4f53\u7684\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306e\u4f8b\u3092\u89e3\u8aac\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<p data-line=\"156\" class=\"code-line\">\u53c2\u8003<br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__f008f41ff89d9\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__f008f41ff89d9\" data-content=\"https%3A%2F%2Ftesting-library.com%2Fdocs%2Freact-testing-library%2Fapi%2F%23render\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/testing-library.com\/docs\/react-testing-library\/api\/#render\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/testing-library.com\/docs\/react-testing-library\/api\/#render<\/a><br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__9c9e1efa76eb1\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__9c9e1efa76eb1\" data-content=\"https%3A%2F%2Ftesting-library.com%2Fdocs%2Fuser-event%2Fsetup\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/testing-library.com\/docs\/user-event\/setup\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/testing-library.com\/docs\/user-event\/setup<\/a><br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__5fef8666f2b5d\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__5fef8666f2b5d\" data-content=\"https%3A%2F%2Fqiita.com%2Fb-yuko%2Fitems%2F89fa4a85e5ea0a7de8d5\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/qiita.com\/b-yuko\/items\/89fa4a85e5ea0a7de8d5\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/qiita.com\/b-yuko\/items\/89fa4a85e5ea0a7de8d5<\/a><\/p>\n<h2 id=\"render-%E9%96%A2%E6%95%B0%E3%82%92%E3%82%AB%E3%82%B9%E3%82%BF%E3%83%9E%E3%82%A4%E3%82%BA\" data-line=\"161\" class=\"code-line\">\n render \u95a2\u6570\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/h2>\n<p data-line=\"163\" class=\"code-line\">\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306e\u4f8b\u3092\u53c2\u8003\u306b\u3057\u3066\u3001<code>@testing-library\/react<\/code> \u306e <code>render<\/code> \u95a2\u6570\u306e\u3088\u3046\u306b\u4f7f\u3048\u308b\u30ab\u30b9\u30bf\u30e0\u306e <code>render<\/code> \u95a2\u6570\u3092\u7528\u610f\u3057\u307e\u3057\u305f\u3002<br \/>\u3053\u3046\u3059\u308b\u3053\u3068\u3067\u3001\u30b3\u30fc\u30c9\u3092\u7701\u7565\u3067\u304d\u3001<code>userEvent<\/code> \u306e\u30a4\u30f3\u30dd\u30fc\u30c8\u306e\u88dc\u5b8c\u30df\u30b9\u3082\u69cb\u9020\u7684\u306b\u9632\u3052\u307e\u3059\u3002<\/p>\n<p data-line=\"166\" class=\"code-line\"><span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__fee2aa7b26a69\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__fee2aa7b26a69\" data-content=\"https%3A%2F%2Ftesting-library.com%2Fdocs%2Fuser-event%2Fintro%2F%23writing-tests-with-userevent\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/testing-library.com\/docs\/user-event\/intro\/#writing-tests-with-userevent\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/testing-library.com\/docs\/user-event\/intro\/#writing-tests-with-userevent<\/a><\/p>\n<p data-line=\"168\" class=\"code-line\">testHelper\/render.tsx<\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-tsx\"><code class=\"language-tsx code-line\" data-line=\"169\">\n<span class=\"token keyword\">export<\/span> <span class=\"token keyword\">const<\/span> render <span class=\"token operator\">=<\/span> <span class=\"token punctuation\">(<\/span>\n  ui<span class=\"token operator\">:<\/span> <span class=\"token maybe-class-name\">React<\/span><span class=\"token punctuation\">.<\/span><span class=\"token property-access\"><span class=\"token maybe-class-name\">ReactNode<\/span><\/span><span class=\"token punctuation\">,<\/span>\n  options<span class=\"token operator\">?<\/span><span class=\"token operator\">:<\/span> <span class=\"token maybe-class-name\">RenderOptions<\/span><span class=\"token punctuation\">,<\/span>\n<span class=\"token punctuation\">)<\/span><span class=\"token operator\">:<\/span> <span class=\"token maybe-class-name\">RenderResult<\/span> <span class=\"token operator\">&amp;<\/span> <span class=\"token punctuation\">{<\/span>\n  <span class=\"token keyword\">readonly<\/span> user<span class=\"token operator\">:<\/span> <span class=\"token maybe-class-name\">ReturnType<\/span><span class=\"token operator\"><span class=\"token keyword\">typeof<\/span> userEvent<span class=\"token punctuation\">.<\/span><span class=\"token property-access\">setup<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span> <span class=\"token arrow operator\">=&gt;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span>\n  <span class=\"token spread operator\">...<\/span><span class=\"token method function property-access\">originalRender<\/span><span class=\"token punctuation\">(<\/span>ui<span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">{<\/span>\n    wrapper<span class=\"token operator\">:<\/span> <span class=\"token maybe-class-name\">TestWrapper<\/span><span class=\"token punctuation\">,<\/span> \n    <span class=\"token spread operator\">...<\/span>options<span class=\"token punctuation\">,<\/span>\n  <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>\n  user<span class=\"token operator\">:<\/span> userEvent<span class=\"token punctuation\">.<\/span><span class=\"token method function property-access\">setup<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> \n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n<\/span><\/code><\/pre>\n<\/div>\n<p data-line=\"194\" class=\"code-line\">\u5229\u7528\u5074<\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-tsx\"><code class=\"language-tsx code-line\" data-line=\"195\">\n\n<span class=\"token keyword\">import<\/span> <span class=\"token imports\"><span class=\"token punctuation\">{<\/span> render <span class=\"token punctuation\">}<\/span><\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'@testing-library\/react'<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">import<\/span> <span class=\"token imports\">userEvent<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'@testing-library\/user-event'<\/span><span class=\"token punctuation\">;<\/span>\n\n<span class=\"token keyword\">import<\/span> <span class=\"token imports\"><span class=\"token punctuation\">{<\/span> <span class=\"token maybe-class-name\">TestWrapper<\/span> <span class=\"token punctuation\">}<\/span><\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'..\/..\/testHelper\/wrapper'<\/span><span class=\"token punctuation\">;<\/span>\n\n<span class=\"token function\">it<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">'\u30c0\u30df\u30fc\u306e\u30c6\u30b9\u30c8'<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token arrow operator\">=&gt;<\/span> <span class=\"token punctuation\">{<\/span>\n  <span class=\"token keyword\">const<\/span> user <span class=\"token operator\">=<\/span> userEvent<span class=\"token punctuation\">.<\/span><span class=\"token method function property-access\">setup<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n  <span class=\"token function\">render<\/span><span class=\"token punctuation\">(<\/span><span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\"><span class=\"token class-name\">Component<\/span><\/span> <span class=\"token punctuation\">\/&gt;<\/span><\/span><span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">{<\/span> wrapper<span class=\"token operator\">:<\/span> <span class=\"token maybe-class-name\">TestWrapper<\/span> <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n  <span class=\"token keyword\">await<\/span> user<span class=\"token punctuation\">.<\/span><span class=\"token method function property-access\">click<\/span><span class=\"token punctuation\">(<\/span><span class=\"token spread operator\">...<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n<\/span><\/code><\/pre>\n<\/div>\n<div class=\"code-block-container\">\n<pre class=\"language-tsx\"><code class=\"language-tsx code-line\" data-line=\"210\">\n\n\n<span class=\"token keyword\">import<\/span> <span class=\"token imports\"><span class=\"token punctuation\">{<\/span> render <span class=\"token punctuation\">}<\/span><\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'..\/..\/testHelper\/render'<\/span><span class=\"token punctuation\">;<\/span>\n\n<span class=\"token function\">it<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">'\u30c0\u30df\u30fc\u306e\u30c6\u30b9\u30c8'<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">async<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token arrow operator\">=&gt;<\/span> <span class=\"token punctuation\">{<\/span>\n  <span class=\"token keyword\">const<\/span> <span class=\"token punctuation\">{<\/span> user <span class=\"token punctuation\">}<\/span> <span class=\"token operator\">=<\/span> <span class=\"token function\">render<\/span><span class=\"token punctuation\">(<\/span><span class=\"token tag\"><span class=\"token tag\"><span class=\"token punctuation\"><span class=\"token class-name\">Component<\/span><\/span> <span class=\"token punctuation\">\/&gt;<\/span><\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n  <span class=\"token keyword\">await<\/span> user<span class=\"token punctuation\">.<\/span><span class=\"token method function property-access\">click<\/span><span class=\"token punctuation\">(<\/span><span class=\"token spread operator\">...<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n<\/span><\/code><\/pre>\n<\/div>\n<p data-line=\"223\" class=\"code-line\">\u30c6\u30b9\u30c8\u3054\u3068\u306b\u66f8\u304f\u304a\u6c7a\u307e\u308a\u306e\u30b3\u30fc\u30c9\u304c\u306a\u304f\u306a\u308a\u30b9\u30c3\u30ad\u30ea\u3057\u307e\u3057\u305f\uff01<\/p>\n<h2 id=\"%E3%81%8A%E3%82%8F%E3%82%8A%E3%81%AB\" data-line=\"225\" class=\"code-line\">\n \u304a\u308f\u308a\u306b<\/h2>\n<p data-line=\"227\" class=\"code-line\">\u6700\u5f8c\u307e\u3067\u304a\u8aad\u307f\u3044\u305f\u3060\u304d\u3001\u3042\u308a\u304c\u3068\u3046\u3054\u3056\u3044\u307e\u3057\u305f\uff01<br \/>\u6539\u5584\u7cfb\u306e\u5c0f\u30cd\u30bf\u3067\u3057\u305f\u304c\u3001\u3044\u304b\u304c\u3060\u3063\u305f\u3067\u3057\u3087\u3046\u304b\uff1f<br \/>\u30c6\u30b9\u30c8\u306e\u62bd\u8c61\u5316\u306f\u614e\u91cd\u306b\u884c\u3046\u65b9\u304c\u826f\u3044\u3068\u3044\u3046\u8a71\u3082\u3042\u308a\u307e\u3059\u304c\u3001<code>render<\/code> \u95a2\u6570\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306a\u3069\u306f\u3069\u306e\u30c6\u30b9\u30c8\u306b\u3082\u5171\u901a\u3059\u308b\u3082\u306e\u306a\u306e\u3067\u3001\u52b9\u679c\u304c\u3042\u3063\u3066\u304a\u3059\u3059\u3081\u3067\u3059\uff01<\/p>\n<p data-line=\"231\" class=\"code-line\">\u53c2\u8003<br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__1d4349789c6bb\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__1d4349789c6bb\" data-content=\"https%3A%2F%2Fkentcdodds.com%2Fblog%2Favoid-nesting-when-youre-testing%23apply-aha-avoid-hasty-abstractions\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/kentcdodds.com\/blog\/avoid-nesting-when-youre-testing#apply-aha-avoid-hasty-abstractions\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/kentcdodds.com\/blog\/avoid-nesting-when-youre-testing#apply-aha-avoid-hasty-abstractions<\/a><br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__d022e86706f56\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__d022e86706f56\" data-content=\"https%3A%2F%2Fstorybook.js.org%2Fdocs%2Freleases%2Fmigration-guide-from-older-version\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/storybook.js.org\/docs\/releases\/migration-guide-from-older-version\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/storybook.js.org\/docs\/releases\/migration-guide-from-older-version<\/a><br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__5f21f32480697\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__5f21f32480697\" data-content=\"https%3A%2F%2Ftesting-library.com%2Fdocs%2Fuser-event%2Fintro%2F\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/testing-library.com\/docs\/user-event\/intro\/\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/testing-library.com\/docs\/user-event\/intro\/<\/a><\/p>\n<p data-line=\"236\" class=\"code-line\">\u5f0a\u793e\u306e\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306e\u30c6\u30b9\u30c8\u65b9\u91dd\u306b\u3064\u3044\u3066\u306e\u53c2\u8003\u8a18\u4e8b\u3082\u304a\u3059\u3059\u3081\u306a\u306e\u3067\u3001\u305c\u3072\u3054\u4e00\u8aad\u304f\u3060\u3055\u3044\u3002<br style=\"display:none\"\/><br \/>\n<span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__6dc059c5860a2\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__6dc059c5860a2\" data-content=\"https%3A%2F%2Fzenn.dev%2Fsocialplus%2Farticles%2Fb09827d74ff148\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/zenn.dev\/socialplus\/articles\/b09827d74ff148\" style=\"display:none\" target=\"_blank\">https:\/\/zenn.dev\/socialplus\/articles\/b09827d74ff148<\/a><\/p>\n<\/div>\n\n<br \/><a href=\"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834\">\u5143\u306e\u8a18\u4e8b\u3092\u78ba\u8a8d\u3059\u308b <\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\u3053\u3093\u306b\u3061\u306f Social PLUS \u306e\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30a8\u30f3\u30b8\u30cb\u30a2\u306e\u307e\u3063\u304f\u3059\u3067\u3059\u3002 \u5148\u65e5\u3001Storybook \u3092 v7 \u2192 v8 \u306b\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u3092\u3057\u3066\u3044\u305f\u969b\u306b\u3001Vitest \u306e\u30c6\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u306b Storybook \u7528\u306e\u30e2\u30b8\u30e5 [&hellip;]","protected":false},"author":1,"featured_media":18481,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[4],"tags":[],"class_list":["post-18480","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-company-tec"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.6 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059 - \u30dd\u30b1\u30b3\u30f3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834\" \/>\n<meta property=\"og:locale\" content=\"ja_JP\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059 - \u30dd\u30b1\u30b3\u30f3\" \/>\n<meta property=\"og:description\" content=\"\u3053\u3093\u306b\u3061\u306f Social PLUS \u306e\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30a8\u30f3\u30b8\u30cb\u30a2\u306e\u307e\u3063\u304f\u3059\u3067\u3059\u3002 \u5148\u65e5\u3001Storybook \u3092 v7 \u2192 v8 \u306b\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u3092\u3057\u3066\u3044\u305f\u969b\u306b\u3001Vitest \u306e\u30c6\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u306b Storybook \u7528\u306e\u30e2\u30b8\u30e5 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834\" \/>\n<meta property=\"og:site_name\" content=\"\u30dd\u30b1\u30b3\u30f3\" \/>\n<meta property=\"article:published_time\" content=\"2025-10-23T17:43:52+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/1761241432_og-base-w1200-v2.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1200\" \/>\n\t<meta property=\"og:image:height\" content=\"630\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"info@pokecon.jp\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u57f7\u7b46\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"info@pokecon.jp\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u63a8\u5b9a\u8aad\u307f\u53d6\u308a\u6642\u9593\" \/>\n\t<meta name=\"twitter:data2\" content=\"2\u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/18480\\\/\"},\"author\":{\"name\":\"info@pokecon.jp\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\"},\"headline\":\"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059\",\"datePublished\":\"2025-10-23T17:43:52+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/18480\\\/\"},\"wordCount\":167,\"image\":{\"@id\":\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/1761241432_og-base-w1200-v2.png\",\"articleSection\":[\"\u4f01\u696d\u30c6\u30c3\u30af\"],\"inLanguage\":\"ja\"},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/18480\\\/\",\"url\":\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834\",\"name\":\"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059 - \u30dd\u30b1\u30b3\u30f3\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/1761241432_og-base-w1200-v2.png\",\"datePublished\":\"2025-10-23T17:43:52+00:00\",\"author\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\"},\"breadcrumb\":{\"@id\":\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834#breadcrumb\"},\"inLanguage\":\"ja\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"ja\",\"@id\":\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834#primaryimage\",\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/1761241432_og-base-w1200-v2.png\",\"contentUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/1761241432_og-base-w1200-v2.png\",\"width\":1200,\"height\":630},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/zenn.dev\\\/socialplus\\\/articles\\\/00894d6a16d834#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u30db\u30fc\u30e0\",\"item\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#website\",\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/\",\"name\":\"\u30dd\u30b1\u30b3\u30f3\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"ja\"},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\",\"name\":\"info@pokecon.jp\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"ja\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"caption\":\"info@pokecon.jp\"},\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/author\\\/infopokecon-jp\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059 - \u30dd\u30b1\u30b3\u30f3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834","og_locale":"ja_JP","og_type":"article","og_title":"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059 - \u30dd\u30b1\u30b3\u30f3","og_description":"\u3053\u3093\u306b\u3061\u306f Social PLUS \u306e\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30a8\u30f3\u30b8\u30cb\u30a2\u306e\u307e\u3063\u304f\u3059\u3067\u3059\u3002 \u5148\u65e5\u3001Storybook \u3092 v7 \u2192 v8 \u306b\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u3092\u3057\u3066\u3044\u305f\u969b\u306b\u3001Vitest \u306e\u30c6\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u306b Storybook \u7528\u306e\u30e2\u30b8\u30e5 [&hellip;]","og_url":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834","og_site_name":"\u30dd\u30b1\u30b3\u30f3","article_published_time":"2025-10-23T17:43:52+00:00","og_image":[{"width":1200,"height":630,"url":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/1761241432_og-base-w1200-v2.png","type":"image\/png"}],"author":"info@pokecon.jp","twitter_card":"summary_large_image","twitter_misc":{"\u57f7\u7b46\u8005":"info@pokecon.jp","\u63a8\u5b9a\u8aad\u307f\u53d6\u308a\u6642\u9593":"2\u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834#article","isPartOf":{"@id":"https:\/\/pokecon.jp\/job\/18480\/"},"author":{"name":"info@pokecon.jp","@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997"},"headline":"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059","datePublished":"2025-10-23T17:43:52+00:00","mainEntityOfPage":{"@id":"https:\/\/pokecon.jp\/job\/18480\/"},"wordCount":167,"image":{"@id":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834#primaryimage"},"thumbnailUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/1761241432_og-base-w1200-v2.png","articleSection":["\u4f01\u696d\u30c6\u30c3\u30af"],"inLanguage":"ja"},{"@type":"WebPage","@id":"https:\/\/pokecon.jp\/job\/18480\/","url":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834","name":"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059 - \u30dd\u30b1\u30b3\u30f3","isPartOf":{"@id":"https:\/\/pokecon.jp\/job\/#website"},"primaryImageOfPage":{"@id":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834#primaryimage"},"image":{"@id":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834#primaryimage"},"thumbnailUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/1761241432_og-base-w1200-v2.png","datePublished":"2025-10-23T17:43:52+00:00","author":{"@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997"},"breadcrumb":{"@id":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834#breadcrumb"},"inLanguage":"ja","potentialAction":[{"@type":"ReadAction","target":["https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834"]}]},{"@type":"ImageObject","inLanguage":"ja","@id":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834#primaryimage","url":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/1761241432_og-base-w1200-v2.png","contentUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/1761241432_og-base-w1200-v2.png","width":1200,"height":630},{"@type":"BreadcrumbList","@id":"https:\/\/zenn.dev\/socialplus\/articles\/00894d6a16d834#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u30db\u30fc\u30e0","item":"https:\/\/pokecon.jp\/job\/"},{"@type":"ListItem","position":2,"name":"Storybook \u3068 Vitest \u3067 userEvent \u53d6\u308a\u9055\u3048\u3092\u306a\u304f\u3059"}]},{"@type":"WebSite","@id":"https:\/\/pokecon.jp\/job\/#website","url":"https:\/\/pokecon.jp\/job\/","name":"\u30dd\u30b1\u30b3\u30f3","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/pokecon.jp\/job\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"ja"},{"@type":"Person","@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997","name":"info@pokecon.jp","image":{"@type":"ImageObject","inLanguage":"ja","@id":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","caption":"info@pokecon.jp"},"url":"https:\/\/pokecon.jp\/job\/author\/infopokecon-jp\/"}]}},"_links":{"self":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/18480","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/comments?post=18480"}],"version-history":[{"count":1,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/18480\/revisions"}],"predecessor-version":[{"id":18482,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/18480\/revisions\/18482"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/media\/18481"}],"wp:attachment":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/media?parent=18480"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/categories?post=18480"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/tags?post=18480"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}