{"id":3952,"date":"2022-12-06T14:31:39","date_gmt":"2022-12-06T05:31:39","guid":{"rendered":"https:\/\/weseek.co.jp\/tech\/?p=3952"},"modified":"2023-04-17T10:35:36","modified_gmt":"2023-04-17T01:35:36","slug":"cypress-%e3%81%a7-xhr-%e3%82%a8%e3%83%a9%e3%83%bc%e3%81%ab%e3%81%aa%e3%81%a3%e3%81%a6%e3%81%97%e3%81%be%e3%81%86%e5%a0%b4%e5%90%88%e3%81%ae%e5%af%be%e8%b1%a1%e6%96%b9%e6%b3%95","status":"publish","type":"post","link":"https:\/\/weseek.co.jp\/tech\/3952\/","title":{"rendered":"Cypress \u3067 XHR \u30a8\u30e9\u30fc\u306b\u306a\u3063\u3066\u3057\u307e\u3046\u5834\u5408\u306e\u5bfe\u8c61\u65b9\u6cd5"},"content":{"rendered":"<p>\u3053\u3093\u306b\u3061\u306f\u3001WESEEK \u3067\u30a8\u30f3\u30b8\u30cb\u30a2\u3092\u3057\u3066\u3044\u308b<a href=\"https:\/\/github.com\/miya\">\u5bae\u6ca2<\/a>\u3067\u3059\u3002\u666e\u6bb5\u306f\u30aa\u30fc\u30d7\u30f3\u30bd\u30fc\u30b9\u306a wiki \u3067\u3042\u308b <a href=\"https:\/\/github.com\/weseek\/growi\">GROWI<\/a> \u3092\u958b\u767a\u3057\u3066\u3044\u307e\u3059\u3002\u4eca\u56de\u306f\u305d\u3093\u306a GROWI \u306e\u30d3\u30b8\u30e5\u30a2\u30eb\u30ea\u30b0\u30ec\u30c3\u30b7\u30e7\u30f3\u30c6\u30b9\u30c8\u3067\u5229\u7528\u3057\u3066\u3044\u308b <a href=\"https:\/\/www.cypress.io\/\">Cypress<\/a> \u3067\u767a\u751f\u3057\u305f XHR \u30a8\u30e9\u30fc\u306e\u5bfe\u51e6\u65b9\u6cd5\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<p><!--more--><\/p>\n\n<h2>\u30a8\u30e9\u30fc\u5185\u5bb9<\/h2>\n<p>\u4eca\u56de\u7d39\u4ecb\u3059\u308b\u30a8\u30e9\u30fc\u5185\u5bb9\u306f\u4ee5\u4e0b\u306e\u8d64\u4e38\u3067\u56f2\u3063\u305f\u90e8\u5206\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8\u306f\u5b9f\u969b\u306e GROWI \u306e\u30ed\u30b0\u30a4\u30f3\u753b\u9762\u3067\u3059\u3002<\/p>\n<p><img src=\"https:\/\/weseek.co.jp\/tech\/wp-content\/uploads\/2022\/12\/638ca08dcf9c1a424215cf77.png\" alt=\"\" width=\"1400\" class=\"aligncenter size-full wp-image-3953\" srcset=\"https:\/\/weseek.co.jp\/tech\/wp-content\/uploads\/2022\/12\/638ca08dcf9c1a424215cf77.png 1400w, https:\/\/weseek.co.jp\/tech\/wp-content\/uploads\/2022\/12\/638ca08dcf9c1a424215cf77-300x219.png 300w, https:\/\/weseek.co.jp\/tech\/wp-content\/uploads\/2022\/12\/638ca08dcf9c1a424215cf77-1024x749.png 1024w, https:\/\/weseek.co.jp\/tech\/wp-content\/uploads\/2022\/12\/638ca08dcf9c1a424215cf77-768x562.png 768w, https:\/\/weseek.co.jp\/tech\/wp-content\/uploads\/2022\/12\/638ca08dcf9c1a424215cf77-293x214.png 293w, https:\/\/weseek.co.jp\/tech\/wp-content\/uploads\/2022\/12\/638ca08dcf9c1a424215cf77-282x206.png 282w\" sizes=\"(max-width: 1400px) 100vw, 1400px\" \/><\/p>\n<p>\u5b9f\u969b\u306b\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u305f Cypress \u306e\u30b3\u30fc\u30c9\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002\u5177\u4f53\u7684\u306f\u3001<code>\/login<\/code> \u306b\u9077\u79fb\u3057\u3066\u3001\u3042\u3089\u304b\u3058\u3081\u767b\u9332\u3055\u308c\u3066\u3044\u308b\u30e6\u30fc\u30b6\u30fc\u30cd\u30fc\u30e0\u3068\u30d1\u30b9\u30ef\u30fc\u30c9\u3092\u5165\u529b\u3001 \u30ed\u30b0\u30a4\u30f3\u30dc\u30bf\u30f3\u3092\u62bc\u3057\u3066\u30ed\u30b0\u30a4\u30f3\u3092\u3059\u308b\u3068\u3044\u3046 Cypress \u306e<a href=\"https:\/\/docs.cypress.io\/api\/cypress-api\/custom-commands\">\u30ab\u30b9\u30bf\u30e0\u30b3\u30de\u30f3\u30c9<\/a>\u3067\u3059\u3002 \u4f7f\u3046\u5834\u5408\u306f <code>cy.login(username, password)<\/code> \u3053\u306e\u3088\u3046\u306a\u611f\u3058\u3067\u66f8\u304d\u307e\u3059\u3002<\/p>\n<pre><code class=\"language-Javascript\">Cypress.Commands.add(&#039;login&#039;, (username, password) =&gt; {\n  cy.session(username, () =&gt; {\n    cy.visit(&#039;\/login&#039;);\n    cy.get(&#039;.usernameForLogin&#039;).type(username);\n    cy.get(&#039;.passwordForLogin&#039;).type(password);\n    cy.get(&#039;.btnSubmitForLogin&#039;).click();\n  });\n});<\/code><\/pre>\n<h2>\u30a8\u30e9\u30fc\u539f\u56e0<\/h2>\n<p>\u30ed\u30b0\u30a4\u30f3\u30dc\u30bf\u30f3\u3092\u62bc\u4e0b\u3057\u305f\u969b\u306b\u8d70\u308b <code>\/api\/v3\/login<\/code> \u306e\u30ec\u30b9\u30dd\u30f3\u30b9\u3092\u5f85\u305f\u305a\u306b\u30ed\u30b0\u30a4\u30f3\u304c\u5fc5\u8981\u306a\u30da\u30fc\u30b8\u306b\u9077\u79fb\u3057\u3088\u3046\u3068\u3059\u308b\u3053\u3068\u3067\u3001\u30d6\u30e9\u30a6\u30b6\u306b\u30e6\u30fc\u30b6\u30fc\u306e\u30bb\u30c3\u30b7\u30e7\u30f3\u30c7\u30fc\u30bf\u304c\u6b63\u5e38\u306b\u4fdd\u5b58\u3055\u308c\u306a\u304b\u3063\u305f\u3053\u3068\u304c\u539f\u56e0\u3068\u898b\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u8a66\u3057\u306b\u3001\u30ed\u30b0\u30a4\u30f3\u30dc\u30bf\u30f3\u306e\u62bc\u4e0b(<code>cy.get(&#039;.btnSubmitForLogin&#039;).click()<\/code>) \u306e\u5f8c\u306b\u3001<code>cy.wait(10000)<\/code> \u3092\u5165\u308c\u305f\u3068\u3053\u308d XHR \u30a8\u30e9\u30fc\u304c\u51fa\u305a\u6b63\u5e38\u306b\u30ed\u30b0\u30a4\u30f3\u51e6\u7406\u3092\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3057\u305f\u3002<\/p>\n<p>\u4ee5\u4e0a\u306e\u3053\u3068\u304b\u3089 <code>\/api\/v3\/login<\/code> \u306e\u30ec\u30b9\u30dd\u30f3\u30b9\u3092\u5f85\u3066\u3070\u826f\u3055\u305d\u3046\u3068\u3044\u3046\u3053\u3068\u304c\u5206\u304b\u3063\u305f\u306e\u3067\u3001\u305d\u306e\u3088\u3046\u306a\u30b3\u30fc\u30c9\u306b\u76f4\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<h2>\u5bfe\u51e6\u65b9\u6cd5<\/h2>\n<p>Cypress \u306b\u306f <a href=\"https:\/\/docs.cypress.io\/api\/commands\/intercept\">intercept<\/a> \u3068\u3044\u3046 API \u304c\u3042\u308a\u307e\u3059\u3002\u3053\u308c\u306f\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u5185\u3067\u8d70\u308b HTTP \u30ea\u30af\u30a8\u30b9\u30c8\u306b\u5bfe\u3057\u3066\u30b9\u30d1\u30a4\u3084\u30b9\u30bf\u30d6\u3092\u304c\u3067\u304d\u308b API \u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u4eca\u56de\u306f\u30b9\u30d1\u30a4\u306e\u307f\u3067\u3044\u3044\u306e\u3067\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3092\u53c2\u8003\u306b\u3059\u308b\u3068\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30b3\u30fc\u30c9\u306b\u306a\u308a\u307e\u3059\u3002\u7b2c\u4e00\u5f15\u6570\u306b\u30e1\u30bd\u30c3\u30c9\u540d\u3001\u7b2c\u4e8c\u5f15\u6570\u306b URL \u304c\u5165\u308a\u307e\u3059\u3002<code>as<\/code> \u3092\u4f7f\u3046\u3068\u30a8\u30a4\u30ea\u30a2\u30b9\u3092\u4f5c\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u4f5c\u6210\u3057\u305f\u30a8\u30a4\u30ea\u30a2\u30b9\u3092 <code>cy.wait<\/code>\u306b\u5165\u308c\u308b\u3068 <code>\/api\/v3\/login<\/code> \u306e\u5b8c\u4e86\u3092\u5f85\u3064\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n<pre><code class=\"language-javascript\">cy.intercept(&#039;POST&#039;, &#039;\/api\/v3\/login&#039;).as(&#039;login&#039;);\n\/\/ Do something\ncy.wait(&#039;@login&#039;);<\/code><\/pre>\n<p>\u4ee5\u4e0a\u306e\u30b3\u30fc\u30c9\u3092\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u3066\u3044\u305f\u30ab\u30b9\u30bf\u30e0\u30b3\u30de\u30f3\u30c9\u306b\u5165\u308c\u305f\u7d50\u679c\u6b63\u5e38\u306b\u52d5\u4f5c\u3057\u307e\u3057\u305f\u3002<\/p>\n<pre><code class=\"language-Javascript\">Cypress.Commands.add(&#039;login&#039;, (username, password) =&gt; {\n  cy.session(username, () =&gt; {\n    cy.visit(&#039;\/login&#039;);\n    cy.get(&#039;.usernameForLogin&#039;).type(username);\n    cy.get(&#039;.passwordForLogin&#039;).type(password);\n\n    cy.intercept(&#039;POST&#039;, &#039;\/_api\/v3\/login&#039;).as(&#039;login&#039;);\n    cy.get(&#039;.btnSubmitForLogin&#039;).click();\n    cy.wait(&#039;@login&#039;)\n  });\n});<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u3053\u3093\u306b\u3061\u306f\u3001WESEEK \u3067\u30a8\u30f3\u30b8\u30cb\u30a2\u3092\u3057\u3066\u3044\u308b\u5bae\u6ca2\u3067\u3059\u3002\u666e\u6bb5\u306f\u30aa\u30fc\u30d7\u30f3\u30bd\u30fc\u30b9\u306a wiki \u3067\u3042\u308b GROWI \u3092\u958b\u767a\u3057\u3066\u3044\u307e\u3059\u3002\u4eca\u56de\u306f\u305d\u3093\u306a GROWI \u306e\u30d3\u30b8\u30e5\u30a2\u30eb\u30ea\u30b0\u30ec\u30c3\u30b7\u30e7\u30f3\u30c6\u30b9\u30c8\u3067\u5229\u7528\u3057\u3066\u3044\u308b Cypress <\/p>\n","protected":false},"author":11,"featured_media":3954,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[153],"tags":[],"_links":{"self":[{"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/posts\/3952"}],"collection":[{"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/users\/11"}],"replies":[{"embeddable":true,"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/comments?post=3952"}],"version-history":[{"count":3,"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/posts\/3952\/revisions"}],"predecessor-version":[{"id":4231,"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/posts\/3952\/revisions\/4231"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/media\/3954"}],"wp:attachment":[{"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/media?parent=3952"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/categories?post=3952"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/weseek.co.jp\/tech\/wp-json\/wp\/v2\/tags?post=3952"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}