{"id":3073,"date":"2021-12-04T09:59:34","date_gmt":"2021-12-04T00:59:34","guid":{"rendered":"https:\/\/suzutukiblog.com\/?p=3073"},"modified":"2022-01-23T05:59:14","modified_gmt":"2022-01-22T20:59:14","slug":"rails-tutorial13-2","status":"publish","type":"post","link":"https:\/\/suzutukiblog.com\/index.php\/2021\/12\/04\/rails-tutorial13-2\/","title":{"rendered":"Rails-tutorial\u306e\u307e\u3068\u3081(13.2.1 \u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u63cf\u753b \u4e3b\u306b\u6f14\u7fd2)"},"content":{"rendered":"<p><a href=\"https:\/\/suzutukiblog.com\/index.php\/2021\/04\/22\/rails-tutorial-13\/\">\u305d\u306e13\u304b\u3089\u7d9a\u304f<\/a><\/p>\n<h3>13.2.1 \u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u63cf\u753b<\/h3>\n<p>\u30e6\u30fc\u30b6\u30fc\u306e\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762 (show.html.erb) \u3067\u305d\u306e\u30e6\u30fc\u30b6\u30fc\u306e<br \/>\n\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u8868\u793a\u3055\u305b\u305f\u308a\u3001\u3053\u308c\u307e\u3067\u306b\u6295\u7a3f\u3057\u305f\u7dcf\u6570\u3082\u8868\u793a\u3055\u305b\u305f\u308a\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<p>Micropost\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u3068\u30d3\u30e5\u30fc\u3092\u4f5c\u6210\u3059\u308b\u305f\u3081\u306b\u3001\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u3092\u751f\u6210\u3057\u307e\u3057\u3087\u3046\u3002\u306a\u304a\u3001\u4eca\u56de\u4f7f\u3046\u306e\u306f\u30d3\u30e5\u30fc\u3060\u3051\u3067\u3001Microposts\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u306f 13.3\u304b\u3089\u4f7f\u3063\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<pre><strong>rails db:migrate:reset\r\nrails db:seed<\/strong>\r\n<strong>rails generate controller Microposts<\/strong><\/pre>\n<p>_micropost.html.erb\u30d1\u30fc\u30b7\u30e3\u30eb\u3092\u4f7f\u3063\u3066\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u30b3\u30ec\u30af\u30b7\u30e7\u30f3\u3092<br \/>\n\u8868\u793a\u3057\u3088\u3046\u3068\u3059\u308b\u3068\u3001\u6b21\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p>&lt;ol class=&#8221;microposts&#8221;&gt;<br \/>\n&lt;%= render @microposts %&gt;<br \/>\n&lt;\/ol&gt;<\/p>\n<p>\u9806\u5e8f\u7121\u3057\u30ea\u30b9\u30c8\u306eul\u30bf\u30b0\u3067\u306f\u306a\u304f\u3001\u9806\u5e8f\u4ed8\u304d\u30ea\u30b9\u30c8\u306eol\u30bf\u30b0\u3092\u4f7f\u3063\u3066\u3044\u308b\u70b9\u306b\u6ce8\u76ee\u3057\u3066\u304f\u3060\u3055\u3044\u3002<br \/>\n\u3053\u308c\u306f\u3001\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u304c\u7279\u5b9a\u306e\u9806\u5e8f (\u65b0\u3057\u3044\u2192\u53e4\u3044)<br \/>\n\u306b\u4f9d\u5b58\u3057\u3066\u3044\u308b\u305f\u3081\u3067\u3059\u3002<\/p>\n<p>\u6b21\u306b\u3001\u5bfe\u5fdc\u3059\u308b\u30d1\u30fc\u30b7\u30e3\u30eb\u3092\u793a\u3057\u307e\u3059\u3002<br \/>\n1\u3064\u306e\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u8868\u793a\u3059\u308b\u30d1\u30fc\u30b7\u30e3\u30eb<br \/>\n<strong>app\/views\/microposts\/_micropost.html.erb<\/strong><\/p>\n<pre><strong>&lt;li id=\"micropost-&lt;%= micropost.id %&gt;\"&gt;<\/strong>\r\n<strong> &lt;%= link_to gravatar_for(micropost.user, size: 50), micropost.user %&gt;<\/strong>\r\n<strong> &lt;span class=\"user\"&gt;&lt;%= link_to micropost.user.name, micropost.user %&gt;&lt;\/span&gt;<\/strong>\r\n<strong> &lt;span class=\"content\"&gt;&lt;%= micropost.content %&gt;&lt;\/span&gt;<\/strong>\r\n<strong> &lt;span class=\"timestamp\"&gt;<\/strong>\r\n<strong>  Posted &lt;%= time_ago_in_words(micropost.created_at) %&gt; ago.<\/strong>\r\n<strong> &lt;\/span&gt;<\/strong>\r\n<strong>&lt;\/li&gt;<\/strong><\/pre>\n<p>time_ago_in_words\u3068\u3044\u3046\u2191\u30d8\u30eb\u30d1\u30fc\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3063\u3066\u3044\u307e\u3059\u3002<br \/>\n\u30e1\u30bd\u30c3\u30c9\u540d\u306e\u8868\u3059\u3068\u304a\u308a\u3067\u3059\u304c\u3001\u300c3\u5206\u524d\u306b\u6295\u7a3f\u300d\u3068\u3044\u3063\u305f\u6587\u5b57\u5217\u3092\u51fa\u529b\u3057\u307e\u3059\u3002<\/p>\n<p>\u5404\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306b\u5bfe\u3057\u3066CSS\u306eid\u3092\u5272\u308a\u632f\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p><strong>&lt;li id=&#8221;micropost-&lt;%= micropost.id %&gt;&#8221;&gt;<\/strong><\/p>\n<p>\u3053\u308c\u306f\u4e00\u822c\u7684\u306b\u826f\u3044\u3068\u3055\u308c\u308b\u6163\u7fd2\u3067\u3001\u4f8b\u3048\u3070\u5c06\u6765\u3001JavaScript\u3092\u4f7f\u3063\u3066<br \/>\n\u5404\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u64cd\u4f5c\u3057\u305f\u304f\u306a\u3063\u305f\u3068\u304d\u306a\u3069\u306b\u5f79\u7acb\u3061\u307e\u3059\u3002<\/p>\n<p>\u4e00\u5ea6\u306b\u3059\u3079\u3066\u306e\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u304c\u8868\u793a\u3055\u308c\u3066\u3057\u307e\u3046\u6f5c\u5728\u7684\u554f\u984c\u306b\u5bfe\u51e6\u3057\u307e\u3059\u300210\u3067\u306f\u30da\u30fc\u30b8\u30cd\u30fc\u30b7\u30e7\u30f3\u3092\u4f7f\u3044\u307e\u3057\u305f\u304c\u3001\u4eca\u56de\u3082\u540c\u3058\u65b9\u6cd5\u3067\u3053\u306e\u554f\u984c\u3092\u89e3\u6c7a\u3057\u307e\u3059\u3002<br \/>\n\u524d\u56de\u540c\u69d8\u3001will_paginate\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3046\u3068\u6b21\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p><strong>&lt;%= will_paginate @microposts %&gt;<\/strong><\/p>\n<p>\u4ee5\u524d\u306f\u6b21\u306e\u3088\u3046\u306b\u5358\u7d14\u306a\u30b3\u30fc\u30c9\u3067\u3057\u305f\u3002<\/p>\n<p><strong>&lt;%= will_paginate %&gt;<\/strong><\/p>\n<p>\u5b9f\u306f\u3001\u4e0a\u306e\u30b3\u30fc\u30c9\u306f\u5f15\u6570\u306a\u3057\u3067\u52d5\u4f5c\u3057\u3066\u3044\u307e\u3057\u305f\u3002<br \/>\n\u3053\u308c\u306fwill_paginate\u304c\u3001Users\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u306e\u30b3\u30f3\u30c6\u30ad\u30b9\u30c8\u306b<br \/>\n\u304a\u3044\u3066\u3001@users\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u5909\u6570\u304c\u5b58\u5728\u3057\u3066\u3044\u308b\u3053\u3068\u3092\u524d\u63d0\u3068\u3057\u3066\u3044\u308b\u305f\u3081\u3067\u3059<\/p>\n<p>\u4eca\u56de\u306e\u5834\u5408\u306fUsers\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u306e\u30b3\u30f3\u30c6\u30ad\u30b9\u30c8\u304b\u3089\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u30da\u30fc\u30b8\u30cd\u30fc\u30b7\u30e7\u30f3\u3057\u305f\u3044\u305f\u3081 (\u3064\u307e\u308a\u30b3\u30f3\u30c6\u30ad\u30b9\u30c8\u304c\u7570\u306a\u308b\u305f\u3081)\u3001<br \/>\n\u660e\u793a\u7684\u306b@microposts\u5909\u6570\u3092will_paginate\u306b\u6e21\u3059\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u3057\u305f\u304c\u3063\u3066\u3001\u305d\u306e\u3088\u3046\u306a\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u5909\u6570\u3092Users\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u306e<br \/>\nshow\u30a2\u30af\u30b7\u30e7\u30f3\u3067\u5b9a\u7fa9\u3057\u306a\u3051\u308c\u3070\u306a\u308a\u307e\u305b\u3093<br \/>\n@microposts\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u5909\u6570\u3092show\u30a2\u30af\u30b7\u30e7\u30f3\u306b\u8ffd\u52a0\u3059\u308b<\/p>\n<p><strong>app\/controllers\/users_controller.rb<\/strong><\/p>\n<pre><strong><span class=\"k\">class<\/span> <span class=\"nc\">UsersController<\/span> <span class=\"o\">&lt;<\/span> <span class=\"no\">ApplicationController<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"k\">def<\/span> <span class=\"nf\">show<\/span>\r\n    <span class=\"vi\">@user<\/span> <span class=\"o\">=<\/span> <span class=\"no\">User<\/span><span class=\"o\">.<\/span><span class=\"n\">find<\/span><span class=\"p\">(<\/span><span class=\"n\">params<\/span><span class=\"o\">[<\/span><span class=\"ss\">:id<\/span><span class=\"o\">]<\/span><span class=\"p\">)<\/span>\r\n<span class=\"hll\">    <span class=\"vi\">@microposts<\/span> <span class=\"o\">=<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.<\/span><span class=\"n\">microposts<\/span><span class=\"o\">.<\/span><span class=\"n\">paginate<\/span><span class=\"p\">(<\/span><span class=\"ss\">page<\/span><span class=\"p\">:<\/span> <span class=\"n\">params<\/span><span class=\"o\">[<\/span><span class=\"ss\">:page<\/span><span class=\"o\">]<\/span><span class=\"p\">)<\/span>\r\n<\/span>  <span class=\"k\">end<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"o\">.<\/span>\r\n  <span class=\"o\">.<\/span>\r\n<span class=\"k\">end<\/span><\/strong><\/pre>\n<p><span style=\"font-size: 1rem;\">\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u6295\u7a3f\u6570\u3092\u8868\u793a\u3059\u308b\u3053\u3068\u3067\u3059\u304c\u3001\u3053\u308c\u306fcount\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3046\u3053\u3068\u3067\u89e3\u6c7a\u3067\u304d\u307e\u3059\u3002<\/span><\/p>\n<p><strong>user.microposts.count<\/strong><\/p>\n<p>paginate\u3068\u540c\u69d8\u306b\u3001\u95a2\u9023\u4ed8\u3051\u3092\u3068\u304a\u3057\u3066count\u30e1\u30bd\u30c3\u30c9\u3092\u547c\u3073\u51fa\u3059\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br \/>\n\u5927\u4e8b\u306a\u3053\u3068\u306f\u3001count\u30e1\u30bd\u30c3\u30c9\u3067\u306f\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u4e0a\u306e<br \/>\n\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u5168\u90e8\u8aad\u307f\u3060\u3057\u3066\u304b\u3089\u7d50\u679c\u306e\u914d\u5217\u306b\u5bfe\u3057\u3066length\u3092\u547c\u3076\u3001\u3068\u3044\u3063\u305f\u7121\u99c4\u306a\u51e6\u7406\u306f\u3057\u3066\u3044\u306a\u3044\u3068\u3044\u3046\u70b9\u3067\u3059\u3002<br \/>\n\u305d\u3093\u306a\u3053\u3068\u3092\u3057\u305f\u3089\u3001<br \/>\n\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u6570\u304c\u5897\u52a0\u3059\u308b\u306b\u3064\u308c\u3066\u52b9\u7387\u304c\u4f4e\u4e0b\u3057\u3066\u3057\u307e\u3044\u307e\u3059\u3002<br \/>\n\u305d\u3046\u3067\u306f\u306a\u304f\u3001(\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u5185\u3067\u306e\u8a08\u7b97\u306f\u9ad8\u5ea6\u306b\u6700\u9069\u5316\u3055\u308c\u3066\u3044\u308b\u306e\u3067)\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u4ee3\u308f\u308a\u306b\u8a08\u7b97\u3057\u3066\u3082\u3089\u3044\u3001<br \/>\n\u7279\u5b9a\u306euser_id\u306b\u7d10\u4ed8\u3044\u305f<br \/>\n\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u6570\u3092\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u554f\u3044\u5408\u308f\u305b\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u3059\u3079\u3066\u306e\u8981\u7d20\u304c\u63c3\u3063\u305f\u306e\u3067\u3001\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762\u306b\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092<br \/>\n\u8868\u793a\u3055\u305b\u3066\u307f\u307e\u3057\u3087\u3046(\u3053\u306e\u3068\u304d\u3001if @user.microposts.any?\u3092\u4f7f\u3063\u3066\u3001\u30e6\u30fc\u30b6\u30fc\u306e\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u304c1\u3064\u3082\u306a\u3044\u5834\u5408\u306b\u306f\u7a7a\u306e\u30ea\u30b9\u30c8\u3092<br \/>\n\u8868\u793a\u3055\u305b\u3066\u3044\u306a\u3044\u70b9\u306b\u3082\u6ce8\u76ee\u3057\u3066\u304f\u3060\u3055\u3044\u3002)<\/p>\n<p>\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u30e6\u30fc\u30b6\u30fc\u306eshow\u30da\u30fc\u30b8 (\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762) \u306b\u8ffd\u52a0\u3059\u308b<br \/>\n<strong>app\/views\/users\/show.html.erb<\/strong><\/p>\n<pre><strong><span class=\"cp\">&lt;%<\/span> <span class=\"n\">provide<\/span><span class=\"p\">(<\/span><span class=\"ss\">:title<\/span><span class=\"p\">,<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.<\/span><span class=\"n\">name<\/span><span class=\"p\">)<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"row\"<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">&lt;<\/span><span class=\"nt\">aside<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"col-md-4\"<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;<\/span><span class=\"nt\">section<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"user_info\"<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"p\">&lt;<\/span><span class=\"nt\">h1<\/span><span class=\"p\">&gt;<\/span>\r\n        <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">gravatar_for<\/span> <span class=\"vi\">@user<\/span> <span class=\"cp\">%&gt;<\/span>\r\n        <span class=\"cp\">&lt;%=<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.<\/span><span class=\"n\">name<\/span> <span class=\"cp\">%&gt;<\/span>\r\n      <span class=\"p\">&lt;\/<\/span><span class=\"nt\">h1<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;\/<\/span><span class=\"nt\">section<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">&lt;\/<\/span><span class=\"nt\">aside<\/span><span class=\"p\">&gt;<\/span>\r\n<span class=\"hll\">  <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"col-md-8\"<\/span><span class=\"p\">&gt;<\/span>\r\n<\/span><span class=\"hll\">    <span class=\"cp\">&lt;%<\/span> <span class=\"k\">if<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.<\/span><span class=\"n\">microposts<\/span><span class=\"o\">.<\/span><span class=\"n\">any?<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<\/span><span class=\"hll\">      <span class=\"p\">&lt;<\/span><span class=\"nt\">h3<\/span><span class=\"p\">&gt;<\/span>Microposts (<span class=\"cp\">&lt;%=<\/span> <span class=\"vi\">@user<\/span><span class=\"o\">.<\/span><span class=\"n\">microposts<\/span><span class=\"o\">.<\/span><span class=\"n\">count<\/span> <span class=\"cp\">%&gt;<\/span>)<span class=\"p\">&lt;\/<\/span><span class=\"nt\">h3<\/span><span class=\"p\">&gt;<\/span>\r\n<\/span><span class=\"hll\">      <span class=\"p\">&lt;<\/span><span class=\"nt\">ol<\/span> <span class=\"na\">class<\/span><span class=\"o\">=<\/span><span class=\"s\">\"microposts\"<\/span><span class=\"p\">&gt;<\/span>\r\n<\/span><span class=\"hll\">        <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">render<\/span> <span class=\"vi\">@microposts<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<\/span><span class=\"hll\">      <span class=\"p\">&lt;\/<\/span><span class=\"nt\">ol<\/span><span class=\"p\">&gt;<\/span>\r\n<\/span><span class=\"hll\">      <span class=\"cp\">&lt;%=<\/span> <span class=\"n\">will_paginate<\/span> <span class=\"vi\">@microposts<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<\/span><span class=\"hll\">    <span class=\"cp\">&lt;%<\/span> <span class=\"k\">end<\/span> <span class=\"cp\">%&gt;<\/span>\r\n<\/span><span class=\"hll\">  <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n<\/span><span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span><\/strong><\/pre>\n<h3>\u6f14\u7fd2<\/h3>\n<p>\u4eca\u56de\u30d8\u30eb\u30d1\u30fc\u30e1\u30bd\u30c3\u30c9\u3068\u3057\u3066\u4f7f\u3063\u305ftime_ago_in_words\u30e1\u30bd\u30c3\u30c9\u306f\u3001<br \/>\nRails\u30b3\u30f3\u30bd\u30fc\u30eb\u306ehelper\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u304b\u3089\u547c\u3073\u51fa\u3059\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br \/>\n\u3053\u306ehelper\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306etime_ago_in_words\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3063\u3066\u3001<br \/>\n3.weeks.ago\u30846.months.ago\u3092\u5b9f\u884c\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<pre><strong>helper.time_ago_in_words(3.weeks.ago)<\/strong>\r\n<strong>=&gt; \"21 days\"<\/strong>\r\n<strong>&gt;&gt; helper.time_ago_in_words(6.months.ago)<\/strong>\r\n<strong>=&gt; \"6 months\"<\/strong><\/pre>\n<p>2:helper.time_ago_in_words(1.year.ago)\u3068\u5b9f\u884c\u3059\u308b\u3068\u3001\u3069\u3046\u3044\u3063\u305f\u7d50\u679c\u304c\u8fd4\u3063\u3066\u304f\u308b\u3067\u3057\u3087\u3046\u304b?<\/p>\n<pre><strong>helper.time_ago_in_words(1.year.ago)<\/strong>\r\n<strong>=&gt; \"about 1 year\"<\/strong><\/pre>\n<p>3:microposts\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306e\u30af\u30e9\u30b9\u306f\u4f55\u3067\u3057\u3087\u3046\u304b? \u30d2\u30f3\u30c8: \u30ea\u30b9\u30c8 13.23\u5185\u306e\u30b3\u30fc\u30c9\u306b\u3042\u308b\u3088\u3046\u306b\u3001\u307e\u305a\u306fpaginate\u30e1\u30bd\u30c3\u30c9 (\u5f15\u6570\u306fpage: nil) \u3067\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u53d6\u5f97\u3057\u3001\u305d\u306e\u5f8cclass\u30e1\u30bd\u30c3\u30c9\u3092\u547c\u3073\u51fa\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<pre><strong>user = User.find(1)<\/strong>\r\n<strong>User Load (0.2ms) SELECT \"users\".* FROM \"users\" WHERE \"users\".\"id\" = ? LIMIT ? [[\"id\", 1], [\"LIMIT\", 1]]<\/strong>\r\n<strong>=&gt; #&lt;User id: 1, name: \"Example User\", email: \"example@railstutorial.org\", created_at: \"2020-04-10 02:03:10\", updated_at: \"2020-04-10 02:03:10\", password_digest: \"$2a$10$cwFqu4HHjAMUEhZpbM294.4JUOfjV08XlIzGu37zTSD...\", remember_digest: nil, admin: true, activation_digest: \"$2a$10$mRd3DEhj6awejp8QoTEbouySA73h7GJW4h5MQYUJ3ax...\", activated: true, activated_at: \"2020-04-10 02:03:09\", reset_digest: nil, reset_sent_at: nil&gt;<\/strong>\r\n<strong>&gt;&gt; microposts = user.microposts.paginate(page:nil)<\/strong>\r\n<strong>Micropost Load (0.2ms) SELECT \"microposts\".* FROM \"microposts\" WHERE \"microposts\".\"user_id\" = ? ORDER BY \"microposts\".\"created_at\" DESC LIMIT ? OFFSET ? [[\"user_id\", 1], [\"LIMIT\", 11], [\"OFFSET\", 0]]<\/strong>\r\n<strong>=&gt; #&lt;ActiveRecord::AssociationRelation []&gt;<\/strong>\r\n<strong>&gt;&gt; microposts.class<\/strong>\r\n<strong>=&gt; Micropost::ActiveRecord_AssociationRelation<\/strong><\/pre>\n<h3><span class=\"number\">13.2.2\u00a0<\/span>\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u30b5\u30f3\u30d7\u30eb<\/h3>\n<p>\u3059\u3079\u3066\u306e\u30e6\u30fc\u30b6\u30fc\u306b\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u8ffd\u52a0\u3057\u3088\u3046\u3068\u3059\u308b\u3068\u6642\u9593\u304c\u639b\u304b\u308a\u904e\u304e\u308b\u306e\u3067\u3001take\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3063\u3066\u6700\u521d\u306e6\u4eba\u3060\u3051\u306b\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n<pre><strong>User.order(:created_at).take(6)<\/strong><\/pre>\n<p>\u3053\u306e\u3068\u304d\u3001order\u30e1\u30bd\u30c3\u30c9\u3092\u7d4c\u7531\u3059\u308b\u3053\u3068\u3067\u3001<br \/>\n\u4f5c\u6210\u3055\u308c\u305f\u30e6\u30fc\u30b6\u30fc\u306e\u6700\u521d\u306e6\u4eba\u3092\u660e\u793a\u7684\u306b\u547c\u3073\u51fa\u3059\u3088\u3046\u306b\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u3053\u306e6\u4eba\u306b\u3064\u3044\u3066\u306f\u30011\u30da\u30fc\u30b8\u306e\u8868\u793a\u9650\u754c\u6570(30)\u3092\u8d8a\u3048\u3055\u305b\u308b\u305f\u3081\u306b\u3001<br \/>\n\u305d\u308c\u305e\u308c50\u500b\u5206\u306e\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u8ffd\u52a0\u3059\u308b\u3088\u3046\u306b\u3057\u3066\u3044\u307e\u3059\u3002<br \/>\n\u307e\u305f\u3001\u5404\u6295\u7a3f\u5185\u5bb9\u306b\u3064\u3044\u3066\u3067\u3059\u304c\u3001Faker gem<br \/>\n\u306bLorem.sentence\u3068\u3044\u3046\u4fbf\u5229\u306a\u30e1\u30bd\u30c3\u30c9\u304c\u3042\u308b\u306e\u3067\u3001\u3053\u308c\u3092\u4f7f\u3044\u307e\u3059\u3002<\/p>\n<p>\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\u306b\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u8ffd\u52a0\u3059\u308b<br \/>\n<strong>db\/seeds.rb<\/strong><\/p>\n<pre><strong>users = User.order(:created_at).take(6)<\/strong>\r\n<strong>50.times do<\/strong>\r\n<strong>content = Faker::Lorem.sentence(5)<\/strong>\r\n<strong>users.each { |user| user.microposts.create!<\/strong>\r\n<strong>(content: content) }<\/strong>\r\n<strong>end<\/strong><\/pre>\n<pre><strong>rails db:migrate:reset\r\nrails db:seed<\/strong><\/pre>\n<p>\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u7528\u306eCSS (\u672c\u7ae0\u3067\u5229\u7528\u3059\u308bCSS\u306e\u3059\u3079\u3066)<br \/>\n<strong>app\/assets\/stylesheets\/custom.scss<\/strong><\/p>\n<pre><span class=\"nc\">.<\/span>\r\n<span class=\"nc\">.<\/span>\r\n<strong><span class=\"o\">\/*<\/span> <span class=\"nt\">microposts<\/span> <span class=\"o\">*\/<\/span>\r\n\r\n<span class=\"nc\">.microposts<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nt\">list-style<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">none<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"nt\">padding<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">0<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"nt\">li<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">padding<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">10px<\/span> <span class=\"nt\">0<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">border-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">1px<\/span> <span class=\"nt\">solid<\/span> <span class=\"nn\">#e8e8e8<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"nc\">.user<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">margin-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">5em<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">padding-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">0<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"nc\">.content<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">display<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">block<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">margin-left<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">60px<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">img<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nt\">display<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">block<\/span><span class=\"o\">;<\/span>\r\n      <span class=\"nt\">padding<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">5px<\/span> <span class=\"nt\">0<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"nc\">.timestamp<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">color<\/span><span class=\"nd\">:<\/span> <span class=\"err\">$<\/span><span class=\"nt\">gray-light<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">display<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">block<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">margin-left<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">60px<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"nc\">.gravatar<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">float<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">left<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">margin-right<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">10px<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">margin-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">5px<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nt\">aside<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nt\">textarea<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">height<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">100px<\/span><span class=\"o\">;<\/span>\r\n    <span class=\"nt\">margin-bottom<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">5px<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nt\">span<\/span><span class=\"nc\">.picture<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nt\">margin-top<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">10px<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"nt\">input<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nt\">border<\/span><span class=\"nd\">:<\/span> <span class=\"nt\">0<\/span><span class=\"o\">;<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span><\/strong><\/pre>\n<h2>\u6f14\u7fd2<\/h2>\n<h3>1:(1..10).to_a.take(6)\u3068\u3044\u3046\u30b3\u30fc\u30c9\u306e\u5b9f\u884c\u7d50\u679c\u3092\u63a8\u6e2c\u3067\u304d\u307e\u3059\u304b?<br \/>\n\u63a8\u6e2c\u3057\u305f\u5024\u304c\u5408\u3063\u3066\u3044\u308b\u304b\u3069\u3046\u304b\u3001\u30b3\u30f3\u30bd\u30fc\u30eb\u3092\u4f7f\u3063\u3066\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/h3>\n<pre><strong>(1..10).to_a.take(6)<\/strong>\r\n<strong>=&gt; [1, 2, 3, 4, 5, 6]<\/strong><\/pre>\n<h3>2:\u5148\u307b\u3069\u306e\u6f14\u7fd2\u306b\u3042\u3063\u305fto_a\u30e1\u30bd\u30c3\u30c9\u306e\u90e8\u5206\u306f\u672c\u5f53\u306b\u5fc5\u8981\u3067\u3057\u3087\u3046\u304b? \u78ba\u304b\u3081\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/h3>\n<pre><strong>(1..10).take(6)<\/strong>\r\n<strong>=&gt; [1, 2, 3, 4, 5, 6]<\/strong><\/pre>\n<h3>3:Faker\u306e\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8 (\u82f1\u8a9e) \u3092\u773a\u3081\u306a\u304c\u3089\u753b\u9762\u306b\u51fa\u529b\u3059\u308b\u65b9\u6cd5\u3092\u5b66\u3073\u3001\u5b9f\u969b\u306b\u5927\u5b66\u540d\u3084\u96fb\u8a71\u756a\u53f7\u3092\u753b\u9762\u306b\u51fa\u529b\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/h3>\n<pre><strong>Faker::Hipster.words<\/strong>\r\n<strong>=&gt; [\"whatever\", \"schlitz\", \"kickstarter\"]<\/strong>\r\n<strong>&gt;&gt; Faker::ChuckNorris.fact<\/strong>\r\n<strong>=&gt; \"Quantum cryptography does not work on Chuck Norris. When something is being observed by Chuck it stays in the same state until he's finished.\"<\/strong><\/pre>\n<h3>13.2.3 \u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762\u306e\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u30c6\u30b9\u30c8\u3059\u308b<\/h3>\n<p>\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762\u3067\u8868\u793a\u3055\u308c\u308b\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306b\u5bfe\u3057\u3066\u3001<br \/>\n\u7d71\u5408\u30c6\u30b9\u30c8\u3092\u66f8\u3044\u3066\u3044\u304d\u307e\u3059\u3002\u307e\u305a\u306f\u3001\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762\u7528\u306e\u7d71\u5408\u30c6\u30b9\u30c8\u3092\u751f\u6210\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<pre><strong>rails generate integration_test users_profile<\/strong><\/pre>\n<p>\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762\u306b\u304a\u3051\u308b\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u30c6\u30b9\u30c8\u3059\u308b\u305f\u3081\u306b\u306f\u3001<br \/>\n\u30e6\u30fc\u30b6\u30fc\u306b\u7d10\u4ed8\u3044\u305f\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u30c6\u30b9\u30c8\u7528\u30c7\u30fc\u30bf\u304c\u5fc5\u8981\u306b\u306a\u308a\u307e\u3059\u3002<br \/>\nRails\u306e\u6163\u7fd2\u306b\u5f93\u3063\u3066\u3001\u95a2\u9023\u4ed8\u3051\u3055\u308c\u305f\u30c6\u30b9\u30c8\u30c7\u30fc\u30bf\u3092fixture\u30d5\u30a1\u30a4\u30eb\u306b\u8ffd\u52a0\u3059\u308b\u3068\u3001\u6b21\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<pre><strong>orange:<\/strong>\r\n<strong>content: \"I just ate an orange!\"<\/strong>\r\n<strong>created_at: &lt;%= 10.minutes.ago %&gt;<\/strong>\r\n<strong>user: michael<\/strong><\/pre>\n<p>user\u306bmichael\u3068\u3044\u3046\u5024\u3092\u6e21\u3059\u3068\u3001<br \/>\nRails\u306ffixture\u30d5\u30a1\u30a4\u30eb\u5185\u306e\u5bfe\u5fdc\u3059\u308b\u30e6\u30fc\u30b6\u30fc\u3092\u63a2\u3057\u51fa\u3057\u3066\u3001<br \/>\n(\u3082\u3057\u898b\u3064\u304b\u308c\u3070) \u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306b\u95a2\u9023\u4ed8\u3051\u3066\u304f\u308c\u307e\u3059\u3002<\/p>\n<p>\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u30da\u30fc\u30b8\u30cd\u30fc\u30b7\u30e7\u30f3\u3092\u30c6\u30b9\u30c8\u3059\u308b\u305f\u3081\u306b\u306f\u3001<br \/>\n\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u7528\u306efixture\u306b\u3044\u304f\u3064\u304b\u30c6\u30b9\u30c8\u30c7\u30fc\u30bf\u3092\u8ffd\u52a0\u3059\u308b\u5fc5\u8981\u304c<br \/>\n\u3042\u308a\u307e\u3059\u304c\u3001\u3053\u308c\u306f\u30ea\u30b9\u30c8 10.47\u3067\u30e6\u30fc\u30b6\u30fc\u3092\u8ffd\u52a0\u3057\u305f\u3068\u304d\u3068\u540c\u69d8\u306b\u3001\u57cb\u3081\u8fbc\u307fRuby\u3092\u4f7f\u3046\u3068\u7c21\u5358\u3067\u3059\u3002<\/p>\n<pre><strong>&lt;% 30.times do |n| %&gt;<\/strong>\r\n<strong>micropost_&lt;%= n %&gt;:<\/strong>\r\n<strong>content: &lt;%= Faker::Lorem.sentence(5) %&gt;<\/strong>\r\n<strong>created_at: &lt;%= 42.days.ago %&gt;<\/strong>\r\n<strong>user: michael<\/strong>\r\n<strong>&lt;% end %&gt;<\/strong><\/pre>\n<p>\u30e6\u30fc\u30b6\u30fc\u3068\u95a2\u9023\u4ed8\u3051\u3055\u308c\u305f\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306efixture<br \/>\n<strong>test\/fixtures\/microposts.yml<\/strong><\/p>\n<pre><strong><span class=\"l l-Scalar l-Scalar-Plain\">orange<\/span><span class=\"p p-Indicator\">:<\/span>\r\n  <span class=\"l l-Scalar l-Scalar-Plain\">content<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"s\">\"I<\/span> <span class=\"s\">just<\/span> <span class=\"s\">ate<\/span> <span class=\"s\">an<\/span> <span class=\"s\">orange!\"<\/span>\r\n  <span class=\"l l-Scalar l-Scalar-Plain\">created_at<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">&lt;%= 10.minutes.ago %&gt;<\/span>\r\n<span class=\"hll\">  <span class=\"l l-Scalar l-Scalar-Plain\">user<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">michael<\/span>\r\n<\/span>\r\n<span class=\"l l-Scalar l-Scalar-Plain\">tau_manifesto<\/span><span class=\"p p-Indicator\">:<\/span>\r\n  <span class=\"l l-Scalar l-Scalar-Plain\">content<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"s\">\"Check<\/span> <span class=\"s\">out<\/span> <span class=\"s\">the<\/span> <span class=\"s\">@tauday<\/span> <span class=\"s\">site<\/span> <span class=\"s\">by<\/span> <span class=\"s\">@mhartl:<\/span> <span class=\"s\">http:\/\/tauday.com\"<\/span>\r\n  <span class=\"l l-Scalar l-Scalar-Plain\">created_at<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">&lt;%= 3.years.ago %&gt;<\/span>\r\n<span class=\"hll\">  <span class=\"l l-Scalar l-Scalar-Plain\">user<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">michael<\/span>\r\n<\/span>\r\n<span class=\"l l-Scalar l-Scalar-Plain\">cat_video<\/span><span class=\"p p-Indicator\">:<\/span>\r\n  <span class=\"l l-Scalar l-Scalar-Plain\">content<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"s\">\"Sad<\/span> <span class=\"s\">cats<\/span> <span class=\"s\">are<\/span> <span class=\"s\">sad:<\/span> <span class=\"s\">http:\/\/youtu.be\/PKffm2uI4dk\"<\/span>\r\n  <span class=\"l l-Scalar l-Scalar-Plain\">created_at<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">&lt;%= 2.hours.ago %&gt;<\/span>\r\n<span class=\"hll\">  <span class=\"l l-Scalar l-Scalar-Plain\">user<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">michael<\/span>\r\n<\/span>\r\n<span class=\"l l-Scalar l-Scalar-Plain\">most_recent<\/span><span class=\"p p-Indicator\">:<\/span>\r\n  <span class=\"l l-Scalar l-Scalar-Plain\">content<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"s\">\"Writing<\/span> <span class=\"s\">a<\/span> <span class=\"s\">short<\/span> <span class=\"s\">test\"<\/span>\r\n  <span class=\"l l-Scalar l-Scalar-Plain\">created_at<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">&lt;%= Time.zone.now %&gt;<\/span>\r\n<span class=\"hll\">  <span class=\"l l-Scalar l-Scalar-Plain\">user<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">michael<\/span>\r\n<\/span>\r\n<span class=\"hll\"><span class=\"l l-Scalar l-Scalar-Plain\">&lt;% 30.times do |n| %&gt;<\/span>\r\n<\/span><span class=\"hll\"><span class=\"l l-Scalar l-Scalar-Plain\">micropost_&lt;%= n %&gt;<\/span><span class=\"p p-Indicator\">:<\/span>\r\n<\/span><span class=\"hll\">  <span class=\"l l-Scalar l-Scalar-Plain\">content<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">&lt;%= Faker::Lorem.sentence(5) %&gt;<\/span>\r\n<\/span><span class=\"hll\">  <span class=\"l l-Scalar l-Scalar-Plain\">created_at<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">&lt;%= 42.days.ago %&gt;<\/span>\r\n<\/span><span class=\"hll\">  <span class=\"l l-Scalar l-Scalar-Plain\">user<\/span><span class=\"p p-Indicator\">:<\/span> <span class=\"l l-Scalar l-Scalar-Plain\">michael<\/span>\r\n<\/span><span class=\"hll\"><span class=\"l l-Scalar l-Scalar-Plain\">&lt;% end %&gt;<\/span><\/span><\/strong><\/pre>\n<p>User\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762\u306b\u5bfe\u3059\u308b\u30c6\u30b9\u30c8green<\/p>\n<p><strong>test\/integration\/users_profile_test.rb<\/strong><\/p>\n<pre><strong>require 'test_helper'<\/strong>\r\n\r\n<strong>class UsersProfileTest &lt; ActionDispatch::IntegrationTest<\/strong>\r\n<strong>include ApplicationHelper<\/strong>\r\n\r\n<strong>def setup<\/strong>\r\n<strong>  @user = users(:michael)<\/strong>\r\n<strong>end<\/strong>\r\n\r\n<strong>test \"profile display\" do<\/strong>\r\n<strong> get user_path(@user)<\/strong>\r\n<strong> assert_template 'users\/show'<\/strong>\r\n<strong> assert_select 'title', full_title(@user.name)<\/strong>\r\n<strong> assert_select 'h1', text: @user.name<\/strong>\r\n<strong> assert_select 'h1&gt;img.gravatar'<\/strong>\r\n<strong> assert_match @user.microposts.count.to_s, response.body<\/strong>\r\n<strong> assert_select 'div.pagination'<\/strong>\r\n<strong>  @user.microposts.paginate(page: 1).each do |micropost|<\/strong>\r\n<strong>   assert_match micropost.content, response.body<\/strong>\r\n<strong>  end<\/strong>\r\n<strong> end<\/strong>\r\n<strong>end<\/strong><\/pre>\n<p>response.body\u306b\u306f\u305d\u306e\u30da\u30fc\u30b8\u306e\u5b8c\u5168\u306aHTML\u304c\u542b\u307e\u308c\u3066\u3044\u307e\u3059<br \/>\n(HTML\u306ebody\u30bf\u30b0\u3060\u3051\u3067\u306f\u3042\u308a\u307e\u305b\u3093)\u3002\u3064\u307e\u308a\u3001\u305d\u306e\u30da\u30fc\u30b8\u306e\u3069\u3053\u304b\u3057\u3089\u306b<br \/>\n\u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u6295\u7a3f\u6570\u304c\u5b58\u5728\u3059\u308b\u306e\u3067\u3042\u308c\u3070\u3001<br \/>\n\u6b21\u306e\u3088\u3046\u306b\u63a2\u3057\u51fa\u3057\u3066\u30de\u30c3\u30c1\u3067\u304d\u308b\u306f\u305a\u3067\u3059\u3002<\/p>\n<pre><strong>assert_match @user.microposts.count.to_s, response.body<\/strong><\/pre>\n<h3>\u3053\u308c\u306fassert_select\u3088\u308a\u3082\u305a\u3063\u3068\u62bd\u8c61\u7684\u306a\u30e1\u30bd\u30c3\u30c9\u3067\u3059\u3002<br \/>\n\u7279\u306b\u3001assert_select\u3067\u306f\u3069\u306eHTML\u30bf\u30b0\u3092\u63a2\u3059\u306e\u304b\u4f1d\u3048\u308b\u5fc5\u8981\u304c<br \/>\n\u3042\u308a\u307e\u3059\u304c\u3001assert_match\u30e1\u30bd\u30c3\u30c9\u3067\u306f\u305d\u306e\u5fc5\u8981\u304c\u306a\u3044\u70b9\u304c\u9055\u3044\u307e\u3059\u3002<\/h3>\n<p>assert_select\u306e\u5f15\u6570\u3067\u306f\u3001<br \/>\n\u30cd\u30b9\u30c8\u3057\u305f\u6587\u6cd5\u3092\u4f7f\u3063\u3066\u3044\u308b\u70b9\u306b\u3082\u6ce8\u76ee\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre><strong>assert_select 'h1&gt;img.gravatar'<\/strong><\/pre>\n<p>h1\u30bf\u30b0 (\u30c8\u30c3\u30d7\u30ec\u30d9\u30eb\u306e\u898b\u51fa\u3057) \u306e\u5185\u5074\u306b\u3042\u308b\u3001<br \/>\ngravatar\u30af\u30e9\u30b9\u4ed8\u304d\u306eimg\u30bf\u30b0\u304c\u3042\u308b\u304b\u3069\u3046\u304b\u3092\u30c1\u30a7\u30c3\u30af\u3067\u304d\u307e\u3059\u3002<\/p>\n<div class=\"heading\"><span class=\"description\"><span class=\"smallcaps\"><strong>green<\/strong><\/span><\/span><\/div>\n<div class=\"code\">\n<div class=\"highlight\">\n<pre>rails test<\/pre>\n<\/div>\n<\/div>\n<h3>\u6f14\u7fd2<\/h3>\n<p>1:2\u3064\u306e&#8217;h1&#8217;\u306e\u30c6\u30b9\u30c8\u304c\u6b63\u3057\u3044\u304b\u78ba\u304b\u3081\u308b\u305f\u3081\u3001<br \/>\n\u8a72\u5f53\u3059\u308b\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u5074\u306e\u30b3\u30fc\u30c9\u3092\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002green\u304b\u3089red\u306b\u5909\u308f\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre><strong>Expected at least 1 element matching \"h1\", found 0..<\/strong>\r\n<strong>Expected 0 to be &gt;= 1.<\/strong>\r\n<strong>RED\u306b\u306a\u308b<\/strong><\/pre>\n<p>2:\u30c6\u30b9\u30c8\u3092\u5909\u66f4\u3057\u3066\u3001will_paginate\u304c\uff11\u5ea6\u306e\u307f\u8868\u793a\u3055\u308c\u3066\u3044\u308b\u3053\u3068\u3092<br \/>\n\u30c6\u30b9\u30c8\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u30d2\u30f3\u30c8: \u8868 5.2\u3092\u53c2\u8003\u306b\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre><strong>assert_select 'div.pagination', count:1<\/strong><\/pre>\n<p><a href=\"https:\/\/suzutukiblog.com\/index.php\/2021\/04\/25\/rails-tutorial13-3\/\">13.3\u306b\u7d9a\u304f<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u305d\u306e13\u304b\u3089\u7d9a\u304f 13.2.1 \u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u306e\u63cf\u753b \u30e6\u30fc\u30b6\u30fc\u306e\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u753b\u9762 (show.html.erb) \u3067\u305d\u306e\u30e6\u30fc\u30b6\u30fc\u306e \u30de\u30a4\u30af\u30ed\u30dd\u30b9\u30c8\u3092\u8868\u793a\u3055\u305b\u305f\u308a\u3001\u3053\u308c\u307e\u3067\u306b\u6295\u7a3f\u3057\u305f\u7dcf\u6570\u3082\u8868\u793a\u3055\u305b\u305f\u308a\u3057\u3066\u3044\u304d\u307e\u3059\u3002 Mic [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"footnotes":""},"categories":[27,13],"tags":[],"class_list":["post-3073","post","type-post","status-publish","format-standard","hentry","category-programming-note","category-rails"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/posts\/3073","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/comments?post=3073"}],"version-history":[{"count":8,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/posts\/3073\/revisions"}],"predecessor-version":[{"id":4587,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/posts\/3073\/revisions\/4587"}],"wp:attachment":[{"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/media?parent=3073"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/categories?post=3073"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/suzutukiblog.com\/index.php\/wp-json\/wp\/v2\/tags?post=3073"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}