{"id":15722,"date":"2024-01-16T03:34:29","date_gmt":"2024-01-16T00:04:29","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/"},"modified":"2024-01-16T03:34:29","modified_gmt":"2024-01-16T00:04:29","slug":"%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/","title":{"rendered":"\u062a\u0633\u062a \u0633\u0631\u062a\u0627\u0633\u0631\u06cc \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0627 \u0627\u062a\u0648\u0645\u0627\u0633\u06cc\u0648\u0646 \u062a\u0633\u062a CypressEnd-to-End \u0628\u062e\u0634 \u0645\u0647\u0645\u06cc \u0627\u0632 \u0686\u0631\u062e\u0647 \u0639\u0645\u0631 \u062a\u0648\u0633\u0639\u0647 \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0648\u0628 \u0627\u0633\u062a.  \u0645\u0633\u0644\u0645\u0627\u064b \u0627\u0646\u062a\u062e\u0627\u0628 \u0627\u0628\u0632\u0627\u0631 \u0645\u0646\u0627\u0633\u0628 \u0628\u0631\u0627\u06cc \u0634\u0645\u0627 \u0648 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0627\u0632 \u0627\u0647\u0645\u06cc\u062a \u0628\u06cc\u0634\u062a\u0631\u06cc \u0628\u0631\u062e\u0648\u0631\u062f\u0627\u0631 \u0627\u0633\u062a.  \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0627\u0646\u062a\u0647\u0627 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Cypress \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u0634\u062a.  &quot;\u067e\u0627\u06cc\u0627\u0646 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627&raquo;  \u062a\u0633\u062a \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 &#8230;"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c\" >\u0645\u0639\u0631\u0641\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%da%86%d8%b1%d8%a7_%d8%a7%d8%b2_%d8%b3%d8%b1%d9%88_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d9%85%d8%9f\" >\u0686\u0631\u0627 \u0627\u0632 \u0633\u0631\u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645\u061f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%da%86%d8%b1%d8%a7_%d8%a7%d8%b2_%d8%b3%d8%b1%d9%88_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d9%86%d9%85%db%8c_%da%a9%d9%86%db%8c%d9%85%d8%9f\" >\u0686\u0631\u0627 \u0627\u0632 \u0633\u0631\u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0646\u0645\u06cc \u06a9\u0646\u06cc\u0645\u061f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%d9%86%d8%b5%d8%a8_%d9%88_%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_cypress\" >\u0646\u0635\u0628 \u0648 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc Cypress<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#cypress_api_and_style\" >Cypress API and Style<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86_%d8%b3%d8%b1%d9%88_%d8%a8%d9%87_%d9%be%d8%b1%d9%88%da%98%d9%87\" >\u0627\u0641\u0632\u0648\u062f\u0646 \u0633\u0631\u0648 \u0628\u0647 \u067e\u0631\u0648\u0698\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%d9%be%db%8c%da%a9%d8%b1%d8%a8%d9%86%d8%af%db%8c_%d9%85%d8%aa%d8%ba%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d8%ac%d9%87%d8%a7%d9%86%db%8c_%d8%af%d8%b1_%d9%81%db%8c%da%a9%d8%b3%da%86%d8%b1%d9%87%d8%a7\" >\u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u062c\u0647\u0627\u0646\u06cc \u062f\u0631 \u0641\u06cc\u06a9\u0633\u0686\u0631\u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d8%b1%d9%88%d8%b4_%d9%87%d8%a7%db%8c_%d8%b3%d9%81%d8%a7%d8%b1%d8%b4%db%8c\" >\u0627\u06cc\u062c\u0627\u062f \u0631\u0648\u0634 \u0647\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%d9%86%d8%a7%d9%85_%d9%85%d8%b3%d8%aa%d8%b9%d8%a7%d8%b1_%db%8c%da%a9_%d8%af%d8%b1%d8%ae%d9%88%d8%a7%d8%b3%d8%aa_xhr\" >\u0646\u0627\u0645 \u0645\u0633\u062a\u0639\u0627\u0631 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a XHR<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%d9%be%d8%a7%d8%b3%d8%ae_%d9%87%d8%a7%db%8c_%d8%af%d8%b1%d8%ae%d9%88%d8%a7%d8%b3%d8%aa_%d8%aa%d9%85%d8%b3%d8%ae%d8%b1_xhr\" >\u067e\u0627\u0633\u062e \u0647\u0627\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u062a\u0645\u0633\u062e\u0631 XHR<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%d8%b3%d8%b1%d8%aa%d8%a7%d8%b3%d8%b1%db%8c-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-%d8%a8%d8%a7-%d8%a7%d8%aa%d9%88%d9%85%d8%a7%d8%b3%db%8c\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 12<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<h2 id=\"introduction\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c\"><\/span>\u0645\u0639\u0631\u0641\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u062a\u0648\u0645\u0627\u0633\u06cc\u0648\u0646 \u062a\u0633\u062a \u0633\u0631\u062a\u0627\u0633\u0631 \u0628\u062e\u0634 \u0645\u0647\u0645\u06cc \u0627\u0632 \u0686\u0631\u062e\u0647 \u0639\u0645\u0631 \u062a\u0648\u0633\u0639\u0647 \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0648\u0628 \u0627\u0633\u062a.  \u0627\u0646\u062a\u062e\u0627\u0628 <em>\u0627\u0628\u0632\u0627\u0631 \u0645\u0646\u0627\u0633\u0628<\/em> \u0628\u0631\u0627\u06cc \u0634\u0645\u0627 <em>\u0648<\/em> \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0645\u0633\u0644\u0645\u0627\u064b \u0645\u0647\u0645\u062a\u0631 \u0627\u0633\u062a.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 <em>\u062a\u0633\u062a \u0627\u0646\u062a\u0647\u0627 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.cypress.io\/\">\u0633\u0631\u0648<\/a><\/em>.<\/p>\n<blockquote>\n<p><em>&#8220;\u067e\u0627\u06cc\u0627\u0646 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627&#8221;<\/em> \u062a\u0633\u062a \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 process \u0634\u0628\u06cc\u0647 \u0633\u0627\u0632\u06cc \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0648 \u062a\u0639\u0627\u0645\u0644 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0627 \u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633\u060c \u0648 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0627\u06cc\u0646\u06a9\u0647 \u0622\u06cc\u0627 \u062e\u0637\u0627 \u062f\u0631 \u0622\u0646 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06cc\u0627 \u062e\u06cc\u0631 process.<\/p>\n<\/blockquote>\n<h2 id=\"whyusecypress\"><span class=\"ez-toc-section\" id=\"%da%86%d8%b1%d8%a7_%d8%a7%d8%b2_%d8%b3%d8%b1%d9%88_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d9%85%d8%9f\"><\/span>\u0686\u0631\u0627 \u0627\u0632 \u0633\u0631\u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0628\u0632\u0631\u06af\u062a\u0631\u06cc\u0646 \u0645\u0632\u06cc\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Cypress \u0686\u06cc\u0632\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 Cypress \u0628\u0647 \u0622\u0646 \u0645\u06cc \u06af\u0648\u06cc\u0646\u062f <em>&#8220;\u0633\u0641\u0631 \u062f\u0631 \u0632\u0645\u0627\u0646&#8221;<\/em>.<\/p>\n<p>\u0622\u0646 \u0631\u0627 \u0622\u0633\u0627\u0646 \u0645\u06cc \u06a9\u0646\u062f process \u0627\u0634\u06a9\u0627\u0644 \u0632\u062f\u0627\u06cc\u06cc \u0628\u0627 \u0627\u062c\u0627\u0632\u0647 \u062f\u0627\u062f\u0646 \u0628\u0647 \u0634\u0645\u0627 \u0628\u0631\u0627\u06cc \u0645\u0634\u0627\u0647\u062f\u0647 \u0647\u0645\u0647 \u0686\u06cc\u0632\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0632\u0645\u0648\u0646 \u0627\u062a\u0641\u0627\u0642 \u0627\u0641\u062a\u0627\u062f\u0647 \u0627\u0633\u062a <em>\u06af\u0632\u0627\u0631\u0634 \u0641\u0631\u0645\u0627\u0646<\/em> \u0648 \u0622\u0646 <em>\u067e\u06cc\u0634 \u0646\u0645\u0627\u06cc\u0634 \u0628\u0631\u0646\u0627\u0645\u0647<\/em>.  \u0647\u0631 \u0645\u0631\u062d\u0644\u0647 \u0648\u0636\u0639\u06cc\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u062f\u0631 \u0632\u0645\u0627\u0646 \u0627\u062c\u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc\u200c\u062f\u0647\u062f \u0648 \u0628\u0647 \u0634\u0645\u0627 \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0631\u0627 \u0645\u06cc\u200c\u062f\u0647\u062f \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0645\u0634\u06a9\u0644\u06cc \u067e\u06cc\u0634 \u0645\u06cc\u200c\u0622\u06cc\u062f \u062f\u0642\u06cc\u0642\u0627\u064b \u0645\u0634\u06a9\u0644 \u0631\u0627 \u0645\u0634\u062e\u0635 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0645\u0627 \u0628\u062e\u0634 \u0642\u0627\u0628\u0644 \u062a\u0648\u062c\u0647\u06cc \u0627\u0632 \u0627\u062f\u0631\u0627\u06a9 \u0634\u0646\u0627\u062e\u062a\u06cc \u0622\u0646\u0647\u0627 \u0631\u0627 \u067e\u0627\u06cc\u0647 \u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u0628\u06cc\u0646\u0627\u06cc\u06cc \u0645\u0627\u060c \u0648 <em>&#8220;\u0633\u0641\u0631 \u062f\u0631 \u0632\u0645\u0627\u0646&#8221;<\/em> \u0628\u0647 \u0645\u0627 \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0631\u0627 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u0634\u0647\u0648\u062f\u06cc (\u0627\u0646\u0633\u0627\u0646\u06cc) \u0627\u0634\u06a9\u0627\u0644\u0627\u062a \u0631\u0627 \u0634\u06a9\u0627\u0631 \u06a9\u0646\u06cc\u0645\u060c \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0647\u0645\u0686\u0646\u0627\u0646 \u0627\u0632 \u0645\u0632\u0627\u06cc\u0627\u06cc \u0627\u062a\u0648\u0645\u0627\u0633\u06cc\u0648\u0646 \u0628\u0647 \u0645\u0627 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646 \u0627\u06cc\u0646 \u06cc\u06a9 \u0631\u0648\u06cc\u06a9\u0631\u062f \u0628\u0633\u06cc\u0627\u0631 \u0637\u0628\u06cc\u0639\u06cc \u0628\u0631\u0627\u06cc \u062c\u0633\u062a\u062c\u0648\u06cc \u0627\u0634\u06a9\u0627\u0644 \u0627\u0633\u062a \u0631\u0648\u06cc \u0627\u06cc\u0646 \u0648\u0627\u0642\u0639\u06cc\u062a \u06a9\u0647 \u0627\u06cc\u0646 \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u0645\u062a\u0645\u0631\u06a9\u0632 \u0627\u0633\u062a \u0631\u0648\u06cc \u062a\u0633\u062a \u067e\u0627\u06cc\u0627\u0646 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627\u060c \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u06a9\u0647 \u0628\u0647 \u063a\u06cc\u0631 \u0627\u0632 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u060c \u0645\u0627 \u062f\u0631 \u0648\u0627\u0642\u0639 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646\u0686\u0647 \u0631\u0627 \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0646\u0647\u0627\u06cc\u06cc \u0645\u06cc \u0628\u06cc\u0646\u062f\u060c \u0628\u0628\u06cc\u0646\u06cc\u0645.<\/p>\n<p>\u0628\u0631\u062e\u06cc \u0627\u0632 \u062f\u0644\u0627\u06cc\u0644 \u062f\u06cc\u06af\u0631\u06cc \u06a9\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0627\u0632 Cypress \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u0639\u0628\u0627\u0631\u062a\u0646\u062f \u0627\u0632:<\/p>\n<ul>\n<li>\u0645\u0628\u062a\u0646\u06cc \u0646\u06cc\u0633\u062a \u0631\u0648\u06cc \u0633\u0644\u0646\u06cc\u0648\u0645 \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0633\u0627\u0626\u0644 \u0645\u0634\u0627\u0628\u0647\u06cc \u0646\u062f\u0627\u0631\u062f \u0648 \u062f\u06cc\u062f\u06af\u0627\u0647 \u062c\u062f\u06cc\u062f\u06cc \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.  \u0633\u0631\u0648 \u0627\u0632 \u067e\u0627\u06cc\u0647 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/li>\n<li>\u0628\u06cc\u0634 \u0627\u0632 \u062d\u062f \u0645\u062a\u0645\u0631\u06a9\u0632 \u0631\u0648\u06cc <em>\u062a\u0633\u062a \u0627\u0646\u062a\u0647\u0627 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627<\/em>.<\/li>\n<li>\u0627\u06af\u0631 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0628\u0627 Cypress \u062a\u0633\u062a \u06a9\u0646\u06cc\u062f.<\/li>\n<li>\u0634\u0645\u0627 \u0641\u0642\u0637 \u0628\u0627\u06cc\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0631\u0627 \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u06cc\u062f.<\/li>\n<li>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0641\u0648\u0642 \u0627\u0644\u0639\u0627\u062f\u0647 \u0622\u0633\u0627\u0646 \u0648 \u0633\u0631\u06cc\u0639 \u0627\u0633\u062a.<\/li>\n<li>\u0628\u0627 \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0646 \u062a\u0648\u0633\u0639\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0627\u06cc\u062c\u0627\u062f \u0634\u062f.<\/li>\n<li>\u0627\u0633\u0646\u0627\u062f \u0631\u0633\u0645\u06cc \u0641\u0631\u0627\u0648\u0627\u0646<\/li>\n<li>\u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u062a\u06a9 \u062a\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc \u0634\u0628\u06a9\u0647\u200c\u0627\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0646\u0642\u0637\u0647\u200c\u0627\u06cc \u06a9\u0647 \u0627\u0632 \u0645\u0631\u0648\u0631\u06af\u0631 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0628\u0627 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0647\u0645\u0647 \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u0645\u0634\u0627\u0647\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/li>\n<li>\u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0634\u0628\u06a9\u0647 \u0631\u0627 \u062e\u0631\u062f \u06a9\u0646\u06cc\u062f\u060c \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0634\u0628\u06a9\u0647 \u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f (\u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 Cypress \u0628\u0631\u0627\u06cc \u062a\u0633\u062a API \u0646\u06cc\u0632 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f).<\/li>\n<li>\u0641\u0639\u0627\u0644 \u0648 \u0634\u0641\u0627\u0641 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/cypress-io\">\u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646<\/a>.<\/li>\n<\/ul>\n<p>\u0633\u0631\u0648 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0648\u06cc \u0628\u0627\u0644\u0627\u06cc <em>\u0645\u0648\u06a9\u0627<\/em> \u0648 <em>\u0686\u0627\u06cc<\/em>\u060c \u06a9\u0647 \u0647\u0631 \u062f\u0648 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 BDD \u0648 TDD \u0645\u062f\u0631\u0646 \u0648 \u0645\u062d\u0628\u0648\u0628 \u0647\u0633\u062a\u0646\u062f \u0648 \u062f\u0631 \u0648\u0627\u0642\u0639 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0646\u062d\u0648 \u0631\u0627 \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0642\u0631\u0636 \u0645\u06cc \u06af\u06cc\u0631\u0646\u062f.  \u0627\u06af\u0631 \u0642\u0628\u0644\u0627 \u0628\u0627 \u0627\u06cc\u0646\u0647\u0627 \u06a9\u0627\u0631 \u06a9\u0631\u062f\u0647 \u0628\u0627\u0634\u06cc\u062f\u060c \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f <em>\u0642\u0644\u0627\u0628 \u0633\u0631\u0648<\/em> \u0645\u0633\u062a\u0642\u06cc\u0645\u0627\u064b \u0627\u0632 \u0645\u0648\u06a9\u0627 \u0648\u0627\u0645 \u06af\u0631\u0641\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<h2 id=\"whynotusecypress\"><span class=\"ez-toc-section\" id=\"%da%86%d8%b1%d8%a7_%d8%a7%d8%b2_%d8%b3%d8%b1%d9%88_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d9%86%d9%85%db%8c_%da%a9%d9%86%db%8c%d9%85%d8%9f\"><\/span>\u0686\u0631\u0627 \u0627\u0632 \u0633\u0631\u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0646\u0645\u06cc \u06a9\u0646\u06cc\u0645\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0647\u06cc\u0686 \u0627\u0628\u0632\u0627\u0631 \u06a9\u0627\u0645\u0644\u06cc \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f\u060c \u0648 \u0628\u0627 \u06af\u0633\u062a\u0631\u0634 &#8211; \u0647\u06cc\u0686 \u0627\u0628\u0632\u0627\u0631 \u062a\u0633\u062a \u06a9\u0627\u0645\u0644\u06cc \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f.  \u0633\u0631\u0648 \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0639\u0627\u0644\u06cc \u0627\u0633\u062a\u060c \u0627\u0632 \u0627\u06cc\u0646 \u0642\u0627\u0639\u062f\u0647 \u0645\u0633\u062a\u062b\u0646\u06cc \u0646\u06cc\u0633\u062a.<\/p>\n<p>\u0628\u0633\u062a\u0647 \u0628\u0647 \u0631\u0648\u06cc \u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0634\u062e\u0635\u06cc \u06cc\u0627 \u067e\u0631\u0648\u0698\u0647 \u0634\u0645\u0627\u060c \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u0648\u0627\u0631\u062f \u0630\u06a9\u0631 \u0634\u062f\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u0632\u0627\u06cc\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0645\u0639\u0627\u06cc\u0628 \u062a\u0628\u062f\u06cc\u0644 \u0634\u0648\u0646\u062f:<\/p>\n<ul>\n<li>\u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u0632 \u0633\u0644\u0646\u06cc\u0648\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0646\u0645\u06cc \u06a9\u0646\u062f \u0648 \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u0633\u062a\u060c \u0628\u0627\u06cc\u062f \u062f\u0627\u0646\u0634 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0631\u0627 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f.  \u0633\u0644\u0646\u06cc\u0648\u0645 \u0627\u0632 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c \u062c\u0627\u0648\u0627\u060c \u067e\u0627\u06cc\u062a\u0648\u0646\u060c Ruby \u0648 \u0633\u06cc#.<\/li>\n<li>\u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0628\u06cc\u0634 \u0627\u0632 \u062d\u062f \u0645\u062a\u0645\u0631\u06a9\u0632 \u0627\u0633\u062a \u0631\u0648\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0627\u0646\u062a\u0647\u0627 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627\u060c \u0631\u0627\u0647 \u062d\u0644\u06cc \u0646\u06cc\u0633\u062a \u06a9\u0647 \u0628\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 \u0627\u0646\u0648\u0627\u0639 \u062f\u06cc\u06af\u0631 \u062a\u0633\u062a \u0647\u0627 (\u0628\u0647 \u062c\u0632 \u062a\u0633\u062a API) \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u06cc\u062f.<\/li>\n<li>\u0627\u0632 \u0647\u0645\u0647 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0646\u0645\u06cc \u06a9\u0646\u062f (\u0648 \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0647\u0631\u06af\u0632 \u0646\u062e\u0648\u0627\u0647\u062f \u0634\u062f) (\u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0644\u06cc\u0633\u062a \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627\u06cc \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0634\u062f\u0647 \u0631\u0627 \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/docs.cypress.io\/guides\/guides\/launching-browsers#Browser-Icon\">\u0627\u06cc\u0646\u062c\u0627<\/a>) \u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u06cc\u06a9 \u0645\u0634\u06a9\u0644 \u0628\u0627\u0634\u062f \u0632\u06cc\u0631\u0627 \u0627\u0646\u0648\u0627\u0639 \u062e\u0627\u0635\u06cc \u0627\u0632 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc IE\u060c Opera \u06cc\u0627 Safari \u0631\u0627 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0646\u0646\u062f.<\/li>\n<li>\u0628\u062f\u0648\u0646 \u062a\u0633\u062a \u0645\u0648\u0628\u0627\u06cc\u0644<\/li>\n<li>\u0647\u0646\u06af\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0645\u0633\u062a\u0642\u06cc\u0645 URL\u060c \u067e\u0648\u0633\u062a\u0647 \u067e\u0648\u0633\u062a\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<li>\u0646\u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0627 \u0628\u06cc\u0634 \u0627\u0632 \u06cc\u06a9 \u0628\u0631\u06af\u0647 \u06a9\u0627\u0631 \u06a9\u0631\u062f.<\/li>\n<li>\u0646\u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0647 \u06cc\u06a9 URL \u062f\u0627\u0645\u0646\u0647 \u062f\u06cc\u06af\u0631 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u06a9\u0631\u062f &#8211; \u0627\u06af\u0631 \u0628\u06cc\u0634 \u0627\u0632 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0628\u062e\u0634\u06cc \u0627\u0632 \u0631\u0627\u0647 \u062d\u0644 \u062e\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06cc\u0627 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0686\u06cc\u0632\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u06cc\u06a9 \u0645\u0634\u06a9\u0644 \u0628\u0632\u0631\u06af \u0628\u0627\u0634\u062f. \u0631\u0648\u06cc \u06cc\u06a9 UI \u0634\u062e\u0635 \u062b\u0627\u0644\u062b  \u0634\u0645\u0627 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u06cc\u06af\u0631 \u062e\u0648\u062f \u0646\u06af\u0647 \u062f\u0627\u0631\u06cc\u062f \u06cc\u0627 \u06a9\u0627\u0645\u0644\u0627\u064b \u0645\u062a\u06a9\u06cc \u0628\u0627\u0634\u06cc\u062f \u0631\u0648\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0634\u0628\u06a9\u0647 \u0628\u0631\u0627\u06cc \u0648\u0627\u06a9\u0634\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627<\/li>\n<li>\u0646\u0633\u0628\u062a\u0627 \u062c\u062f\u06cc\u062f \u0627\u0633\u062a\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0628\u0647 \u0627\u0646\u062f\u0627\u0632\u0647 \u06a9\u0627\u0641\u06cc \u0646\u062f\u0627\u0631\u062f <em>\u0627\u0646\u062c\u0645\u0646<\/em> \u0645\u0648\u0627\u062f \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0642\u062f\u06cc\u0645\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.<\/li>\n<li>\u0628\u0647 \u0646\u0638\u0631 \u0645\u06cc\u200c\u0631\u0633\u062f \u0628\u0631\u062e\u06cc \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627\u06cc \u0646\u0642\u0634\u0647 \u0631\u0627\u0647 \u0628\u0631\u0627\u06cc \u0628\u0631\u062e\u06cc \u0627\u0632 \u0627\u0642\u062f\u0627\u0645\u0627\u062a\u06cc \u06a9\u0647 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0647\u06cc\u062f &#8211; \u0645\u0627\u0646\u0646\u062f \u0622\u067e\u0644\u0648\u062f \u0641\u0627\u06cc\u0644\u060c \u0634\u0646\u0627\u0648\u0631 \u06a9\u0631\u062f\u0646 \u0648 \u0627\u0633\u06a9\u0631\u0648\u0644 \u06a9\u0631\u062f\u0646\u060c \u0639\u0642\u0628 \u0627\u0641\u062a\u0627\u062f\u0647\u200c\u0627\u0646\u062f.  \u0628\u0627\u06cc\u062f \u0631\u0627\u0647 \u062d\u0644 \u0647\u0627\u06cc\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f.<\/li>\n<li>\u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0627\u0631\u062a\u0628\u0627\u0637 \u0645\u0633\u062a\u0642\u06cc\u0645 \u0628\u0627 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u06cc\u0627 \u062a\u0642\u0631\u06cc\u0628\u0627\u064b \u0647\u0631 \u0686\u06cc\u0632\u06cc \u062e\u0627\u0631\u062c \u0627\u0632 \u06a9\u0627\u0631 \u0645\u0633\u062a\u0642\u06cc\u0645 \u0645\u0631\u0648\u0631\u06af\u0631 \u0631\u0627 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f\u060c \u06a9\u0627\u0631 \u0642\u0627\u0628\u0644 \u062a\u0648\u062c\u0647\u06cc \u0644\u0627\u0632\u0645 \u0627\u0633\u062a.  \u062f\u0627\u0631\u0646\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u06cc\u0632\u06cc \u0645\u06cc \u06a9\u0646\u0646\u062f \u0631\u0648\u06cc \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0622\u062f\u0627\u067e\u062a\u0648\u0631\u0647\u0627\u06cc \u0628\u06a9\u200c\u0627\u0646\u062f \u0631\u0627 \u0628\u0631\u0627\u06cc \u0632\u0628\u0627\u0646\u200c\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0645\u0646\u062a\u0634\u0631 \u06a9\u0631\u062f.  \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627 \u0628\u0647 \u0645\u062d\u0636 \u0627\u0646\u062a\u0634\u0627\u0631 \u0628\u0647 \u0633\u0631\u0639\u062a \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<\/ul>\n<p>\u0628\u0631\u062e\u06cc \u0627\u0632 \u0627\u06cc\u0646\u0647\u0627 \u062e\u0648\u0627\u0647\u062f \u0634\u062f <strong>\u0647\u0631\u06af\u0632 \u062a\u063a\u06cc\u06cc\u0631 \u0646\u0645\u06cc \u06a9\u0646\u062f<\/strong> \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0628\u0631\u062e\u06cc \u0628\u0631\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u06cc\u0632\u06cc \u0634\u062f\u0647 \u0627\u0646\u062f.  \u0627\u06af\u0631 \u062c\u0632\u0626\u06cc\u0627\u062a \u0628\u06cc\u0634\u062a\u0631\u06cc \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0631\u0648\u06cc \u06a9\u062f\u0627\u0645 \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627 \u062d\u0641\u0638 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0648 \u06a9\u062f\u0627\u0645\u200c\u0647\u0627 \u0646\u0647\u060c \u0622\u0646\u0647\u0627 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/docs.cypress.io\/guides\/references\/trade-offs#Permanent-trade-offs-1\">\u0645\u0628\u0627\u062f\u0644\u0627\u062a<\/a> page  \u06cc\u06a9 \u0645\u06a9\u0627\u0646 \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u0627\u0633\u062a.<\/p>\n<h2 id=\"installingandsettingupcypress\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%b5%d8%a8_%d9%88_%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_cypress\"><\/span>\u0646\u0635\u0628 \u0648 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc Cypress<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0631\u0627\u06cc \u0622\u0633\u0627\u0646 \u06a9\u0631\u062f\u0646 \u0622\u0632\u0645\u0627\u06cc\u0634 Cypress \u0648 \u0627\u062c\u0627\u0632\u0647 \u062f\u0627\u062f\u0646 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u062a\u0645\u0627\u0645 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0622\u0646 &#8211; \u062a\u06cc\u0645 Cypress \u0645\u062c\u0645\u0648\u0639\u0647 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0631\u0627 \u06af\u0631\u062f\u0622\u0648\u0631\u06cc \u06a9\u0631\u062f. <em>\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062f\u0645\u0648<\/em> \u0627\u06af\u0631 \u067e\u0631\u0648\u0698\u0647 \u0627\u06cc \u0631\u0627 \u0641\u0639\u0627\u0644 \u0648 \u0622\u0645\u0627\u062f\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0646\u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<blockquote>\n<p>\u0645\u0627 \u0627\u0632 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/cypress-io\/cypress-example-kitchensink\"><em>\u0633\u06cc\u0646\u06a9 \u0622\u0634\u067e\u0632\u062e\u0627\u0646\u0647<\/em> \u0628\u0631\u0646\u0627\u0645\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc<\/a>.<\/p>\n<\/blockquote>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0648\u06cc\u0646\u062f\u0648\u0632\u060c \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f <code>npm run start:ci:windows<\/code> \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u0628\u0631\u0646\u0627\u0645\u0647<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u067e\u0633 \u0627\u0632 \u0634\u0631\u0648\u0639 \u0628\u0631\u0646\u0627\u0645\u0647\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f Cypress \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u0645 <code>npm<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install cypress --save-dev<\/span>\n<\/code><\/pre>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0631\u0627\u0647\u200c\u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645 <code>npx<\/code> \u06cc\u0627 <code>yarn<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> .\/node_modules\/.bin\/cypress run open <span class=\"hljs-comment\"># Directly<\/span><\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npx cypress open <span class=\"hljs-comment\"># Using npx<\/span><\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> yarn run cypress open <span class=\"hljs-comment\"># Using yarn<\/span><\/span>\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0642\u0628\u0644\u0627\u064b \u0645\u0634\u062e\u0635\u0627\u062a \u0646\u0645\u0648\u0646\u0647 \u0632\u06cc\u0627\u062f\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0627\u0634\u062a:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/end-to-end-testing-with-cypress-1.png\" alt=\"\u0645\u0634\u062e\u0635\u0627\u062a \u0646\u0645\u0648\u0646\u0647 \u0646\u0645\u0627\u06cc\u0634\u06cc \u0633\u0631\u0648\" title=\"\"><\/p>\n<p>\u06a9\u0644\u06cc\u06a9 \u06a9\u0631\u062f\u0646 \u0631\u0648\u06cc \u0647\u0631 \u06cc\u06a9 \u0627\u0632 \u0622\u0646\u0647\u0627 (\u0645\u062b\u0644\u0627 <code>actions.specs.js<\/code>) \u0631\u0627\u0646\u0631 \u0631\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/end-to-end-testing-with-cypress-2.png\" alt=\"\u0645\u0634\u062e\u0635\u0627\u062a \u0646\u0645\u0627\u06cc\u0634\u06cc \u0633\u0631\u0648\" title=\"\"><\/p>\n<h2 id=\"cypressapiandstyle\"><span class=\"ez-toc-section\" id=\"cypress_api_and_style\"><\/span>Cypress API and Style<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0633\u0631\u0648 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0648\u06cc \u0628\u0627\u0644\u0627\u06cc Mocha \u0648 Chai \u0648 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0646\u062d\u0648 \u0648 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0639\u0627\u0631\u06cc\u062a \u06af\u0631\u0641\u062a\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u06cc\u0639\u0646\u06cc \u0645\u0647\u0645\u062a\u0631\u06cc\u0646 \u0639\u0646\u0627\u0635\u0631 \u0648\u0627\u0645 \u06af\u0631\u0641\u062a\u0647 \u0634\u062f\u0647 \u0639\u0628\u0627\u0631\u062a\u0646\u062f \u0627\u0632 <code>describe()<\/code>\u060c <code>context()<\/code>\u060c <code>it()<\/code> <code>specify()<\/code>  \u0645\u0648\u0627\u062f \u0648 \u0631\u0648\u0634 \u0647\u0627.  \u0622\u0646\u0647\u0627 \u0627\u0633\u0627\u0633\u0627 \u0644\u0641\u0627\u0641\u200c\u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0648\u0627\u0642\u0639\u06cc \u0647\u0633\u062a\u0646\u062f <em>\u062d\u0627\u0634\u06cc\u0647 \u0646\u0648\u06cc\u0633\u06cc \u06af\u0631\u0648\u0647 \u0647\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc<\/em> \u0628\u0627 \u0628\u0631\u0686\u0633\u0628 \u0647\u0627<\/p>\n<p>\u0634\u0627\u06cc\u0627\u0646 \u0630\u06a9\u0631 \u0627\u0633\u062a \u06a9\u0647 <code>specify()<\/code> \u0648 <code>it()<\/code> \u0645\u062a\u0631\u0627\u062f\u0641 \u0647\u0633\u062a\u0646\u062f\u060c \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 <code>describe()<\/code> \u0648 <code>context()<\/code>.  \u0628\u0633\u062a\u0647 \u0628\u0647 \u0631\u0648\u06cc \u0686\u06cc\u0632\u06cc \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0634\u0645\u0627 \u0637\u0628\u06cc\u0639\u06cc \u062a\u0631 \u0628\u0647 \u0646\u0638\u0631 \u0645\u06cc \u0631\u0633\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0647\u0631 \u062a\u0631\u06a9\u06cc\u0628\u06cc \u0627\u0632 \u0627\u06cc\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p><code>describe()<\/code>  \u0628\u0631\u0627\u06cc \u062f\u0627\u062f\u0646 \u0632\u0645\u06cc\u0646\u0647 \u0628\u0647 \u0645\u062c\u0645\u0648\u0639\u0647 \u0627\u06cc \u0627\u0632 \u062a\u0633\u062a \u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f\u060c \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 <code>it()<\/code> \u062a\u0633\u062a \u0647\u0627\u06cc \u0641\u0631\u062f\u06cc \u0631\u0627 \u0634\u0631\u062d \u0645\u06cc \u062f\u0647\u062f.  \u0628\u0647 \u0637\u0648\u0631 \u0645\u0639\u0645\u0648\u0644\u060c \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u0633\u0627\u062e\u062a\u0627\u0631\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 \u0627\u06cc\u0646 \u0644\u0627\u0646\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">describe(<span class=\"hljs-string\">\"Element X Testing\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n    it(<span class=\"hljs-string\">\"Does Y\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        <span class=\"hljs-comment\">\/\/ Test...<\/span>\n    });\n    it(<span class=\"hljs-string\">\"Does Z\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        <span class=\"hljs-comment\">\/\/ Test...<\/span>\n    });\n});\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0647\u0633\u062a <em>\u0635\u0631\u0641\u0627<\/em> \u062a\u0627 \u0628\u0631\u0627\u06cc \u062e\u0648\u062f\u0645\u0627\u0646 \u0648 \u0633\u0627\u06cc\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646\u060c \u0646\u06af\u0627\u0647\u06cc \u06af\u0630\u0631\u0627 \u0628\u0647 \u0622\u0646\u0686\u0647 \u062f\u0631 \u062d\u0627\u0644 \u0627\u0646\u062c\u0627\u0645 \u0627\u0633\u062a\u060c \u0622\u0633\u0627\u0646 \u062a\u0631 \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u0628\u062f\u0648\u0646 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u06af\u0630\u0631 \u0627\u0632 \u06a9\u0644 \u0632\u0646\u062c\u06cc\u0631\u0647 (\u0628\u0627\u0644\u0642\u0648\u0647 \u0637\u0648\u0644\u0627\u0646\u06cc) \u0631\u0648\u0634 \u0647\u0627\u06cc \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0686\u06cc\u0632\u06cc.<\/p>\n<p>\u062f\u0631 \u0647\u0631 \u0622\u0632\u0645\u0648\u0646\u060c \u0645\u0627 \u062a\u06a9\u06cc\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f \u0631\u0648\u06cc \u0646\u0645\u0648\u0646\u0647 \u0633\u0631\u0648 (<code>cy<\/code>) \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u0631\u0648\u0634 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0645\u0627\u0646\u0646\u062f <code>visit()<\/code>\u060c <code>get()<\/code>\u060c <code>fixture()<\/code>\u0648 \u063a\u06cc\u0631\u0647 \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627\u06cc \u0632\u0646\u062c\u06cc\u0631\u0647 \u0627\u06cc \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0646\u062a\u0627\u06cc\u062c.<\/p>\n<p>\u0627\u06cc\u0646 <code>visit()<\/code> \u0648 <code>get()<\/code> \u0631\u0648\u0634\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0628\u0633\u06cc\u0627\u0631 \u0631\u0627\u06cc\u062c \u0647\u0633\u062a\u0646\u062f\u060c \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u06cc\u0627\u0646 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u06a9\u0647 \u0639\u0646\u0635\u0631 \u0648 URL \u0628\u0627\u0632\u062f\u06cc\u062f \u0634\u062f\u0647 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u0648 \u062f\u0631 \u0635\u0648\u0631\u062a \u0639\u062f\u0645 \u0648\u062c\u0648\u062f \u062e\u0637\u0627\u060c \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647\u200c\u0639\u0646\u0648\u0627\u0646 \u062a\u0633\u062a\u200c\u0647\u0627\u06cc \u0642\u0628\u0648\u0644 \u0634\u062f\u0647 \u062f\u0631 \u0646\u0638\u0631 \u0645\u06cc\u200c\u06af\u06cc\u0631\u0646\u062f.  \u0622\u0646\u0647\u0627 \u0646\u06cc\u0632 \u0647\u0633\u062a\u0646\u062f <em>\u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u062f<\/em> \u0627\u0632 \u0647\u0631 \u0632\u0646\u062c\u06cc\u0631\u0647\u060c \u0627\u0632 \u0627\u06cc\u0646 \u0631\u0648\u060c \u0622\u0646\u0647\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0634\u0646\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a <em>\u0648\u0627\u0644\u062f\u06cc\u0646<\/em> \u0645\u0648\u0627\u062f \u0648 \u0631\u0648\u0634 \u0647\u0627.<\/p>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u0645\u0634\u0627\u0628\u0647 \u0628\u0627 \u0627\u062f\u0639\u0627\u06cc \u0648\u062c\u0648\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0622\u06cc\u0627 \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06cc\u0627 \u062e\u06cc\u0631 <code>contains()<\/code> \u06cc\u06a9 \u0627\u0631\u0632\u0634<\/p>\n<p>\u0627\u06cc\u0646 <code>exec()<\/code> \u0645\u062a\u062f \u06cc\u06a9 \u062f\u0633\u062a\u0648\u0631 \u0631\u0627 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u062f \u0631\u0648\u06cc \u0631\u0627\u0628\u0637 \u062e\u0637 \u0641\u0631\u0645\u0627\u0646 \u0648 <code>request()<\/code> \u0645\u062a\u062f \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a HTTP \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0627\u06cc\u0646 <code>type()<\/code> \u0631\u0648\u0634\u060c \u0645\u062d\u062a\u0648\u0627\u06cc \u0645\u062a\u0646\u06cc \u0631\u0627 \u0628\u0647 \u0639\u0646\u0627\u0635\u0631\u06cc \u0648\u0627\u0631\u062f \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0645\u062d\u062a\u0648\u0627\u06cc \u0645\u062a\u0646\u06cc \u0631\u0627 \u0628\u067e\u0630\u06cc\u0631\u0646\u062f \u0648 <code>click()<\/code> \u0631\u0648\u06cc \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0627\u0646\u062a\u062e\u0627\u0628 \u0634\u062f\u0647 \u06a9\u0644\u06cc\u06a9 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0641\u0642\u0637 \u0628\u0627 \u0627\u06cc\u0646 \u0686\u0646\u062f \u0631\u0648\u0634\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06a9\u0627\u0631\u0647\u0627\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0632\u06cc\u0627\u062f\u06cc \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f\u060c \u0648 \u06cc\u06a9 \u0645\u062c\u0645\u0648\u0639\u0647 \u062a\u0633\u062a \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0634\u0627\u0645\u0644 \u0628\u06cc\u0634\u062a\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0627\u0631\u062f \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\">describe(<span class=\"hljs-string\">\"Testing CRUD Form\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n    it(<span class=\"hljs-string\">\"Visits the addition page\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        cy.visit(<span class=\"hljs-string\">'\/addProduct'<\/span>);\n    });\n    it(<span class=\"hljs-string\">\"Gets the input field and inputs text\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        cy.get(<span class=\"hljs-string\">'.input-element'<\/span>)\n          .type(<span class=\"hljs-string\">'Product 1'<\/span>);\n    });\n    it(<span class=\"hljs-string\">\"Clicks the 'Add Product' button\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        cy.contains(<span class=\"hljs-string\">'Add Product'<\/span>)\n          .click();\n    });\n    it(<span class=\"hljs-string\">\"Checks if X was added correctly\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        cy.get(<span class=\"hljs-string\">'product-title'<\/span>)\n          .should(<span class=\"hljs-string\">'have.value'<\/span>, <span class=\"hljs-string\">'Product 1'<\/span>);\n    });\n    it(<span class=\"hljs-string\">\"Runs a CLI Command\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        cy.exec(<span class=\"hljs-string\">'npm run other-service'<\/span>);\n    });\n    it(<span class=\"hljs-string\">\"Sends POST HTTP request\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        cy.request(<span class=\"hljs-string\">'POST'<\/span>, <span class=\"hljs-string\">'\/host\/other-service\/updateCustomers'<\/span>, { <span class=\"hljs-attr\">mail<\/span>: <span class=\"hljs-string\">'Product 1 is out!'<\/span> })\n          .its(<span class=\"hljs-string\">'body'<\/span>);\n    });\n});\n<\/code><\/pre>\n<p>\u0646\u062d\u0648 Mocha \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062f\u0631 Cypress \u0628\u0633\u06cc\u0627\u0631 \u0633\u0627\u062f\u0647\u060c \u0633\u0631\u0631\u0627\u0633\u062a \u0648 \u0634\u0647\u0648\u062f\u06cc \u0627\u0633\u062a.  \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>describe()<\/code> \u0648 <code>it()<\/code> \u0628\u0644\u0648\u06a9 \u0647\u0627 \u0628\u0647 \u0645\u0627 \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0631\u0627 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u0637\u0628\u06cc\u0639\u06cc \u062f\u0631 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0647\u0627 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u0645 \u0648 \u0622\u0646\u0686\u0647 \u0631\u0627 \u06a9\u0647 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u0646\u062f \u062d\u0627\u0634\u06cc\u0647 \u0646\u0648\u06cc\u0633\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0627\u06cc\u0646 <code>should()<\/code> \u0631\u0648\u0634 \u0645\u062a\u06a9\u06cc \u0627\u0633\u062a \u0631\u0648\u06cc \u0627\u0638\u0647\u0627\u0631\u0627\u062a \u0686\u0627\u06cc\u060c \u06a9\u0647 \u0646\u0633\u0628\u062a\u0627\u064b \u0634\u0647\u0648\u062f\u06cc \u0646\u06cc\u0632 \u0647\u0633\u062a\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u062a\u0633\u062a \u0647\u0627 \u0622\u0645\u0627\u062f\u0647 \u0634\u062f\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> cypress run --browser chrome<\/span>\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u062f\u0633\u062a\u0648\u0631 \u062a\u0645\u0627\u0645 \u062a\u0633\u062a \u0647\u0627\u06cc \u062b\u0628\u062a \u0634\u062f\u0647 \u0631\u0627 \u062a\u0627 \u0632\u0645\u0627\u0646 \u062a\u06a9\u0645\u06cc\u0644 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u062f.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u062c\u0644\u0648 \u0628\u0631\u0648\u06cc\u0645 \u0648 Cypress \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u0648\u0627\u0642\u0639\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<h2 id=\"addingcypresstoaproject\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86_%d8%b3%d8%b1%d9%88_%d8%a8%d9%87_%d9%be%d8%b1%d9%88%da%98%d9%87\"><\/span>\u0627\u0641\u0632\u0648\u062f\u0646 \u0633\u0631\u0648 \u0628\u0647 \u067e\u0631\u0648\u0698\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u06cc\u06a9 \u0648\u06cc\u0631\u0627\u06cc\u0634\u06af\u0631 \u06a9\u062f \u0645\u0648\u0631\u062f \u0646\u0638\u0631 \u062e\u0648\u062f \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f \u0648 \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f root\u0648 \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0647\u062f\u0627\u06cc\u062a \u06a9\u0646\u06cc\u062f <code>\/cypress\/integration\/examples\/actions.specs.js<\/code> \u0628\u0631\u0627\u06cc \u062f\u06cc\u062f\u0646 \u06a9\u062f \u067e\u0634\u062a \u062a\u0645\u0627\u0645 \u062a\u0633\u062a \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u0647\u0632\u0627\u0631\u0627\u0646 \u0646\u0645\u0648\u0646\u0647 \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f\u060c \u0627\u0645\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u0645\u0648\u0646\u0647 \u062e\u0648\u062f \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>spec.js<\/code> \u062f\u0631 \u06cc\u06a9 \u0644\u062d\u0638\u0647 \u0641\u0627\u06cc\u0644 \u06a9\u0646\u06cc\u062f \u0648 \u06a9\u0627\u0648\u0634 \u06a9\u0646\u06cc\u062f:<\/p>\n<ul>\n<li>\u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc (<code>cypress.js<\/code>) \u0641\u0627\u06cc\u0644<\/li>\n<li>\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0641\u06cc\u06a9\u0633\u0686\u0631<\/li>\n<li>\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631\u0627\u062a<\/li>\n<\/ul>\n<p>\u0641\u0627\u06cc\u0644 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u062f\u0648\u0628\u0644\u0647 \u0634\u062f\u0647 <code>cypress.js<\/code> \u0628\u0647 \u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc \u0634\u0648\u062f root \u0648 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0641\u0642\u0637 \u062d\u0627\u0648\u06cc \u06cc\u06a9 \u0645\u06a9\u0627\u0646 \u0646\u06af\u0647\u062f\u0627\u0631 \u0628\u0631\u0627\u06cc \u0634\u0646\u0627\u0633\u0647 \u067e\u0631\u0648\u0698\u0647 \u0634\u0645\u0627 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\">{\t\n   <span class=\"hljs-attr\">\"projectId\"<\/span>: <span class=\"hljs-string\">\"yourId\"<\/span>\n}\n<\/code><\/pre>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <code>baseUrl<\/code> \u06a9\u0644\u06cc\u062f\u060c \u0648 \u06cc\u06a9 \u0645\u0642\u062f\u0627\u0631 \u0645\u0646\u0627\u0633\u0628 \u0628\u0647 \u0622\u0646 \u0627\u062e\u062a\u0635\u0627\u0635 \u062f\u0647\u06cc\u062f.  \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0627\u062c\u0631\u0627 \u0627\u0633\u062a \u0631\u0648\u06cc \u0628\u0646\u062f\u0631 <code>8080<\/code>\u060c \u0632\u06cc\u0631 <code>localhost<\/code> \u0628\u0647 \u0622\u0646 \u0627\u0634\u0627\u0631\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\">{\n  <span class=\"hljs-attr\">\"projectId\"<\/span>: <span class=\"hljs-string\">\"4b7344\"<\/span>,\n  <span class=\"hljs-attr\">\"baseUrl\"<\/span>: <span class=\"hljs-string\">\"http:\/\/localhost:8080\"<\/span>\n}\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u062c\u062f\u06cc\u062f \u062f\u0631 \u0632\u06cc\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>\/integration<\/code> \u062a\u0645\u0627\u0633 \u06af\u0631\u0641\u062a <code>my_tests<\/code> \u0648 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0628\u0647 \u0646\u0627\u0645 <code>tests.spec.js<\/code>.  \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u06a9\u0647 \u062f\u0631 Cypress \u0627\u0632 \u0642\u0628\u0644 \u06af\u0632\u06cc\u0646\u0647 \u0627\u062c\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u062c\u062f\u06cc\u062f \u0631\u0627 \u0627\u0632 \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u062f\u060c \u0632\u06cc\u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u067e\u0627\u0633\u062e\u06af\u0648 \u0641\u0627\u06cc\u0644 \u0631\u0627 \u0627\u0633\u06a9\u0646 \u0645\u06cc \u06a9\u0646\u062f. <code>\/integration<\/code> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0628\u0631\u0627\u06cc \u062a\u0633\u062a \u0647\u0627\u06cc \u062c\u062f\u06cc\u062f<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u062c\u0644\u0648 \u0628\u0631\u0648\u06cc\u0645 \u0648 \u0686\u0646\u062f \u062a\u0633\u062a \u0631\u0627 \u062f\u0631 \u0645\u0627 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u0645 <code>tests.spec.js<\/code> \u0641\u0627\u06cc\u0644:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/\/ &lt;reference types=\"cypress\" \/&gt;<\/span>\n\n<span class=\"hljs-comment\">\/* In general, it is a good practice to store \n all your selectors in variables, since they \n might change in the future *\/<\/span>\n<span class=\"hljs-keyword\">var<\/span> email;\n<span class=\"hljs-keyword\">var<\/span> emailSelector = <span class=\"hljs-string\">'.action-email'<\/span>;\n\ndescribe(<span class=\"hljs-string\">'Email Input'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n    <span class=\"hljs-comment\">\/* beforeEach() which will run before every \n    it() test in the file. This is great \n    if you want to perform some common actions \n    before each test *\/<\/span>\n    beforeEach(<span class=\"hljs-function\">() =&gt;<\/span> {\n        <span class=\"hljs-comment\">\/* Since we defined `baseUrl` in cypress.json,\n        using `\/` as the value in `cy.visit()` will navigate to it.\n        Adding `commands\/actions` will add the value to the `baseUrl`. *\/<\/span>\n        cy.visit(<span class=\"hljs-string\">'\/commands\/actions'<\/span>);\n        <span class=\"hljs-comment\">\/* We are reading the example fixture file and assigning its\n        value to a global variable so it is accessible in every test *\/<\/span>\n        cy.fixture(<span class=\"hljs-string\">'example'<\/span>).then(<span class=\"hljs-function\">(<span class=\"hljs-params\">json<\/span>)=&gt;<\/span>{\n            email = json.email;\n        });\n    });\n\n    it(<span class=\"hljs-string\">'Clicks \u0631\u0648\u06cc Actions, and writes the email from the fixture'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        cy.get(emailSelector)\n            .type(email)\n            .should(<span class=\"hljs-string\">'have.value'<\/span>, email);\n    });\n});\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 <code>beforeEach()<\/code> \u0645\u062a\u062f \u0642\u0628\u0644 \u0627\u0632 \u0647\u0631 \u06a9\u062f\u0627\u0645 \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f <code>it()<\/code> \u0631\u0648\u0634.  \u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0648\u0638\u0627\u06cc\u0641 \u0645\u0634\u062a\u0631\u06a9 \u0631\u0627 \u062f\u0631 \u0622\u0646\u062c\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0627\u0632 \u062a\u06a9\u0631\u0627\u0631 \u0622\u0646\u0647\u0627 \u062f\u0631 \u0647\u0631 \u06cc\u06a9 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u0645 <code>it()<\/code> \u0632\u0646\u06af \u0632\u062f\u0646.  \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c \u0645\u0627 \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc \u0628\u0647 \u0622\u0646 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <code>localhost:8080\/commands\/actions<\/code>.  \u0627\u06cc\u0646 <code>visit()<\/code> \u0645\u062a\u062f \u06cc\u06a9 \u0631\u0634\u062a\u0647 (URL) \u0631\u0627 \u0628\u0631\u0627\u06cc \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0645\u06cc \u067e\u0630\u06cc\u0631\u062f \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u062f <code>baseUrl<\/code> \u062f\u0631 \u0641\u0627\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u062a\u0639\u0631\u06cc\u0641 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u0645\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <em>\u062b\u0627\u0628\u062a<\/em>.  \u0641\u06cc\u06a9\u0633\u0686\u0631\u0647\u0627 \u0641\u0642\u0637 \u0627\u0633\u0646\u0627\u062f \u062b\u0627\u0628\u062a \u0647\u0633\u062a\u0646\u062f (JSON \u06cc\u06a9 \u0641\u0631\u0645\u062a \u0645\u062d\u0628\u0648\u0628 \u0628\u0631\u0627\u06cc \u0630\u062e\u06cc\u0631\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0633\u062a\u060c \u0628\u0647 \u0637\u0648\u0631 \u0637\u0628\u06cc\u0639\u06cc)\u060c \u06a9\u0647 \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0628\u0631\u0627\u06cc \u062a\u0632\u0631\u06cc\u0642 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0628\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0647\u0627\u06cc \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645.  \u0622\u0646\u0647\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0628\u0631\u0627\u06cc \u062e\u0631\u062f \u06a9\u0631\u062f\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0634\u0628\u06a9\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc JSON \u0631\u0627 \u0645\u06cc\u200c\u062e\u0648\u0627\u0646\u06cc\u0645 <code>example<\/code> \u0641\u0627\u06cc\u0644\u060c \u0648\u0627\u0642\u0639 \u062f\u0631 \u0632\u06cc\u0631 <code>cypress\/fixtures\/example.json<\/code>\u0648 \u0627\u0632 \u0645\u0642\u062f\u0627\u0631 \u0627\u0633\u062a\u062e\u0631\u0627\u062c \u0634\u062f\u0647 \u0628\u0631\u0627\u06cc \u062a\u062e\u0635\u06cc\u0635 \u0622\u0646 \u0628\u0647 \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f <code>email<\/code> \u0645\u062a\u063a\u06cc\u0631.<\/p>\n<p>\u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u062c\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 \u062d\u0631\u0648\u0641 \u0627\u0644\u0641\u0628\u0627\u06cc \u0631\u0634\u062a\u0647\u200c\u0627\u06cc\u060c \u0627\u0632 \u0627\u06cc\u0645\u06cc\u0644 \u0646\u0645\u0648\u0646\u0647 \u062f\u0631 \u062a\u0633\u062a\u200c\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u0627\u0634\u0627\u0631\u0647 \u06a9\u0631\u062f\u06cc\u0645\u060c <code>get()<\/code> \u0645\u062a\u062f \u0639\u0646\u0635\u0631 \u0631\u0627 \u0628\u0627 the \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u0645\u06cc \u06a9\u0646\u062f <code>action-email<\/code> \u06a9\u0644\u0627\u0633  \u0645\u0627 \u0642\u0628\u0644\u0627\u064b \u0627\u06cc\u0646 \u06a9\u0644\u0627\u0633 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <code>emailSelector<\/code> \u0645\u062a\u063a\u06cc\u0631.  \u0633\u067e\u0633\u060c \u0645\u0627 \u0645\u06cc \u0646\u0648\u06cc\u0633\u06cc\u0645 <code>email<\/code> \u0627\u0632 <code>example.json<\/code> \u0641\u0627\u06cc\u0644 \u062f\u0631 \u0622\u0646 \u0639\u0646\u0635\u0631 &#8211; \u0628\u0647 \u0637\u0648\u0631 \u0645\u0648\u062b\u0631 \u0622\u0646 \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0645\u0627 \u0627\u062f\u0639\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0627\u0642\u062f\u0627\u0645 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0645\u0648\u0641\u0642\u06cc\u062a \u0622\u0645\u06cc\u0632 \u0628\u0648\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.chaijs.com\/guide\/styles\/\"><em>\u0686\u0627\u06cc<\/em> <code>should()<\/code>  \u0631\u0648\u0634<\/a>.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u062f\u0627\u0645\u0647 \u062f\u0647\u06cc\u0645 \u0648 \u0627\u06cc\u0646 \u062a\u0633\u062a \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> cypress run<\/span>\n<\/code><\/pre>\n<p>\u06a9\u0647 \u0645\u0646\u062c\u0631 \u0628\u0647:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/end-to-end-testing-with-cypress-4.png\" alt=\"\u0627\u062c\u0631\u0627\u06cc \u062a\u0645\u0627\u0645 \u062a\u0633\u062a \u0647\u0627\u06cc \u0633\u0631\u0648 \u0627\u0632 \u0637\u0631\u06cc\u0642 cli\" title=\"\"><\/p>\n<h2 id=\"configuringglobalvariableswithinfixtures\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%da%a9%d8%b1%d8%a8%d9%86%d8%af%db%8c_%d9%85%d8%aa%d8%ba%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d8%ac%d9%87%d8%a7%d9%86%db%8c_%d8%af%d8%b1_%d9%81%db%8c%da%a9%d8%b3%da%86%d8%b1%d9%87%d8%a7\"><\/span>\u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u062c\u0647\u0627\u0646\u06cc \u062f\u0631 \u0641\u06cc\u06a9\u0633\u0686\u0631\u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u06af\u0631 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645 <code>emailSelector<\/code> \u0645\u062a\u063a\u06cc\u0631 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0646\u0638\u0645\u200c\u062a\u0631 \u0627\u0632 \u0627\u06cc\u0646 \u062a\u0633\u062a\u200c\u0647\u0627 &#8211; \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u062e\u0648\u0627\u0647\u06cc\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u062c\u0647\u0627\u0646\u06cc \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u0645.  \u0627\u06cc\u0646 \u06cc\u06a9 \u0645\u0648\u0631\u062f \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u0628\u0631\u0627\u06cc \u0648\u0633\u0627\u06cc\u0644 \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0622\u0646 \u0628\u0647 \u0622\u0646\u0647\u0627 \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u0645 <code>cy.fixture()<\/code>.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 JSON \u062c\u062f\u06cc\u062f \u062f\u0631 \u0632\u06cc\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>\/fixtures<\/code> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc\u060c \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>selectors.js<\/code> \u06a9\u0647 \u0634\u0627\u0645\u0644 \u062a\u0645\u0627\u0645 \u0627\u0646\u062a\u062e\u0627\u0628\u06af\u0631\u0647\u0627\u06cc \u0633\u0637\u062d \u062c\u0647\u0627\u0646\u06cc \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<pre><code class=\"hljs\">{\n <span class=\"hljs-attr\">\"emailSelector\"<\/span>: <span class=\"hljs-string\">\".action-email\"<\/span>\n}\n<\/code><\/pre>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0647\u0631 \u06cc\u06a9 \u0627\u0632 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u062b\u0627\u0628\u062a \u0645\u0648\u062c\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0627\u0645\u0627 \u0628\u0647 \u0637\u0648\u0631 \u06a9\u0644\u06cc\u060c \u0628\u0647\u062a\u0631 \u0627\u0633\u062a \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u062c\u062f\u06cc\u062f\u06cc \u0628\u0631\u0627\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u062e\u0627\u0635 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0627\u06cc\u0646\u06a9\u0647 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0647\u0645\u0647 \u0645\u0646\u0638\u0648\u0631\u0647 \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0628\u0633\u0627\u0632\u06cc\u062f.  \u0627\u06cc\u0646 \u0633\u0627\u0632\u0645\u0627\u0646 \u0631\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0633\u0627\u062f\u0647 \u062a\u0631 \u0648 \u0633\u0627\u0632\u06af\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<\/p><\/div><\/div><\/div>\n<h2 id=\"creatingcustommethods\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d8%b1%d9%88%d8%b4_%d9%87%d8%a7%db%8c_%d8%b3%d9%81%d8%a7%d8%b1%d8%b4%db%8c\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u0631\u0648\u0634 \u0647\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0647\u0645\u0627\u0646 \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f <code>beforeEach()<\/code> \u0631\u0648\u06cc  \u0686\u0646\u062f\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u0645\u0634\u062e\u0635\u0627\u062a &#8211; \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0622\u0646 \u0628\u0647 \u0641\u0627\u06cc\u0644 \u0627\u0632 \u0627\u06cc\u0646 \u0627\u0641\u0632\u0648\u0646\u06af\u06cc \u0646\u06cc\u0632 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f <code>commands.js<\/code> \u0641\u0627\u06cc\u0644.  \u0647\u0631 \u0631\u0648\u0634\u06cc \u06a9\u0647 \u0628\u0647 <code>commands.js<\/code> \u0641\u0627\u06cc\u0644 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0631\u0648\u0634 \u0633\u0641\u0627\u0631\u0634\u06cc \u062b\u0628\u062a \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>cy<\/code> \u0646\u0645\u0648\u0646\u0647\u060c \u0645\u062b\u0627\u0644.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0627\u06af\u0631 \u062f\u0627\u0626\u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0628\u0627\u0632\u062f\u06cc\u062f \u0627\u0632 <code>commands\/actions<\/code> URL\u060c \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u06cc\u06a9 \u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645\u060c \u0645\u062b\u0644\u0627\u064b\u060c <code>navigateToActionsPage()<\/code> \u06a9\u0647 \u062f\u0631 \u0633\u0637\u062d \u062c\u0647\u0627\u0646\u06cc \u0642\u0627\u0628\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06cc\u0646 <code>commands.js<\/code> \u0641\u0627\u06cc\u0644 \u062f\u0631 \u0632\u06cc\u0631 \u0642\u0631\u0627\u0631 \u062f\u0627\u0631\u062f <code>\/support<\/code> \u0641\u0647\u0631\u0633\u062a \u0631\u0627\u0647\u0646\u0645\u0627:<\/p>\n<pre><code class=\"hljs\">Cypress.Commands.add(<span class=\"hljs-string\">'navigateToActionsPage'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n    cy.visit(<span class=\"hljs-string\">'\/commands\/actions'<\/span>);\n})\n<\/code><\/pre>\n<p>\u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <em>\u0646<\/em> \u062f\u0633\u062a\u0648\u0631\u0627\u062a \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u060c \u0648 \u0641\u0642\u0637 \u0628\u0647 \u0622\u0646\u0647\u0627 \u0627\u0631\u062c\u0627\u0639 \u062f\u0647\u06cc\u062f \u0628\u0647 \u062c\u0627\u06cc \u0646\u0648\u0634\u062a\u0646 \u062f\u0648\u0628\u0627\u0631\u0647 \u0648 \u062f\u0648\u0628\u0627\u0631\u0647.  \u0628\u0631\u06af\u0631\u062f\u06cc\u0645 \u0628\u0647 <code>tests.spec.js<\/code> \u0648 \u06a9\u062f \u0645\u0627 \u0631\u0627 \u062f\u0648\u0628\u0627\u0631\u0647 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f \u062a\u0627 \u062d\u0630\u0641 \u0634\u0648\u062f <code>cy.visit()<\/code> \u062a\u0645\u0627\u0633 \u0628\u06af\u06cc\u0631\u06cc\u062f \u0648 \u0627\u0632 \u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>commands.js<\/code> \u0641\u0627\u06cc\u0644:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/\/ &lt;reference types=\"cypress\" \/&gt;<\/span>\n\n<span class=\"hljs-keyword\">var<\/span> email;\n<span class=\"hljs-keyword\">var<\/span> emailSelector;\n\ndescribe(<span class=\"hljs-string\">'Email Input'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n    beforeEach(<span class=\"hljs-function\">() =&gt;<\/span> {\n        <span class=\"hljs-comment\">\/\/ Our method in `commands.js`<\/span>\n        <span class=\"hljs-comment\">\/\/ can now be used from anywhere <\/span>\n        cy.navigateToActionsPage();\n        cy.fixture(<span class=\"hljs-string\">'example'<\/span>).then(<span class=\"hljs-function\">(<span class=\"hljs-params\">json<\/span>)=&gt;<\/span>{\n            email = json.email;\n        });\n        <span class=\"hljs-comment\">\/\/ We can now read the selectors fixture <\/span>\n        <span class=\"hljs-comment\">\/\/ file and load it into our global variable <\/span>\n        <span class=\"hljs-comment\">\/\/ to store the selector<\/span>\n        cy.fixture(<span class=\"hljs-string\">'selectors'<\/span>).then(<span class=\"hljs-function\">(<span class=\"hljs-params\">json<\/span>)=&gt;<\/span>{\n            emailSelector = json.emailSelector;\n        });\n    });\n    it(<span class=\"hljs-string\">'Clicks \u0631\u0648\u06cc Actions, and writes the email from fixture'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n        cy.get(emailSelector).type(email).should(<span class=\"hljs-string\">'have.value'<\/span>, email);\n    });\n});\n<\/code><\/pre>\n<p>\u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u062a\u0641\u0627\u0648\u062a \u0686\u0646\u062f\u0627\u0646\u06cc \u0628\u0647 \u0646\u0638\u0631 \u0646\u0631\u0633\u062f\u060c \u0627\u0645\u0627 \u062f\u0627\u0634\u062a\u0646 \u067e\u0631\u0648\u0698\u0647 \u0627\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f page \u0645\u062b\u0644\u0627\u064b 20 \u0641\u06cc\u0644\u062f \u0648\u0631\u0648\u062f\u06cc \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u0633\u062a\u0639\u062f \u062a\u063a\u06cc\u06cc\u0631 \u0647\u0633\u062a\u0646\u062f \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u06a9\u0647 \u062f\u0627\u0634\u062a\u0646 \u06cc\u06a9 \u0641\u0636\u0627\u06cc \u0645\u062a\u0645\u0631\u06a9\u0632 \u0628\u0631\u0627\u06cc \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 \u0627\u0646\u062a\u062e\u0627\u0628\u06af\u0631\u0647\u0627 \u0628\u0631\u0627\u06cc \u0646\u06af\u0647\u062f\u0627\u0631\u06cc \u062e\u0648\u0628 \u06a9\u062f \u0636\u0631\u0648\u0631\u06cc \u0627\u0633\u062a.<\/p>\n<h2 id=\"aliasinganxhrrequest\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%a7%d9%85_%d9%85%d8%b3%d8%aa%d8%b9%d8%a7%d8%b1_%db%8c%da%a9_%d8%af%d8%b1%d8%ae%d9%88%d8%a7%d8%b3%d8%aa_xhr\"><\/span>\u0646\u0627\u0645 \u0645\u0633\u062a\u0639\u0627\u0631 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a XHR<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u06cc\u06a9 <em>XMLHttpRequest<\/em> (\u062f\u0631\u062e\u0648\u0627\u0633\u062a XHR) \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0648 \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 \u06cc\u06a9 \u0635\u0641\u062d\u0647 \u0648\u0628\u060c \u0628\u062f\u0648\u0646 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u062c\u062f\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f.  \u062f\u0631 \u0627\u0628\u062a\u062f\u0627 \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0642\u0627\u0644 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc XML \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0628\u0648\u062f\u060c \u0627\u0645\u0627 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0648 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc JSON \u0628\u0647 \u062c\u0627\u06cc \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f\u060c \u062d\u062a\u06cc \u0627\u06af\u0631 \u0646\u0627\u0645 \u0622\u0646 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0641\u0642\u0637 \u0628\u0631\u0627\u06cc XML \u0627\u0633\u062a.  \u0627\u06cc\u0646 \u06cc\u06a9 \u0633\u0646\u0627\u0631\u06cc\u0648\u06cc \u063a\u06cc\u0631 \u0645\u0639\u0645\u0648\u0644 \u0646\u06cc\u0633\u062a\u060c \u0632\u06cc\u0631\u0627 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0631\u0627 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u0646\u062f \u0648 \u067e\u0627\u0633\u062e \u0647\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u0628\u0647 \u0622\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627 \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u0646\u062f. \u0631\u0648\u06cc \u06cc\u06a9 \u0648\u0628 page.<\/p>\n<p>\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0645\u0633\u062a\u0639\u0627\u0631 XHR \u0631\u0627 \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0639\u0645\u0644\u06a9\u0631\u062f \u0622\u0646\u0647\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 Cypress \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645.  \u0627\u0628\u062a\u062f\u0627\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0631\u0648\u0634 \u0633\u0641\u0627\u0631\u0634\u06cc \u062f\u06cc\u06af\u0631 \u0631\u0627 \u0628\u0647 \u0631\u0648\u0634 \u062e\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <code>commands.js<\/code> \u0641\u0627\u06cc\u0644 \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0645\u062a\u062f \u062c\u0647\u0627\u0646\u06cc \u0628\u0647 \u0622\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645 \u0648 \u0627\u0632 \u0622\u0646 \u062f\u0631 \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>beforeEach()<\/code> \u0642\u0644\u0627\u0628:<\/p>\n<pre><code class=\"hljs\">Cypress.Commands.add(<span class=\"hljs-string\">'navigateToAliasingPage'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n    cy.visit(<span class=\"hljs-string\">'\/commands\/aliasing'<\/span>);\n})\n<\/code><\/pre>\n<p>\u0628\u0639\u062f\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062c\u062f\u06cc\u062f \u0628\u0647 \u0646\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>aliasing_tests.spec.js<\/code> \u062f\u0631 \u0645\u0627 <code>\/my_tests<\/code> \u0641\u0647\u0631\u0633\u062a \u0631\u0627\u0647\u0646\u0645\u0627.<\/p>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0627\u0632 \u0637\u0631\u0641 \u062f\u06cc\u06af\u0631\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u0642\u0637\u0639\u0647 \u06a9\u062f \u062f\u06cc\u06af\u0631 \u0631\u0627 \u0646\u06cc\u0632 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f (\u062f\u0631 \u062f\u0627\u062e\u0644 a \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a <code>describe()<\/code>) \u062f\u0631 \u0641\u0627\u06cc\u0644 \u0645\u0648\u062c\u0648\u062f \u0645\u0627.  \u0627\u06af\u0631\u0686\u0647\u060c \u0628\u0647 \u0637\u0648\u0631 \u06a9\u0644\u06cc\u060c \u062d\u0641\u0638 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644\u060c \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u062c\u062f\u06cc\u062f \u062f\u0631 \u0647\u0646\u06af\u0627\u0645 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u062f\u06cc\u06af\u0631\u060c \u062a\u0645\u0631\u06cc\u0646 \u062e\u0648\u0628\u06cc \u0627\u0633\u062a.<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <code>cy.intercept()<\/code> \u0648 <code>cy.wait()<\/code> \u0631\u0648\u0634\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0628\u0631\u0627\u06cc \u0627\u062b\u0628\u0627\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627 \u0648 \u067e\u0627\u0633\u062e\u200c\u0647\u0627\u06cc \u0634\u0628\u06a9\u0647 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647\u200c\u0627\u0646\u062f.  \u0627\u06cc\u0646 <code>cy.intercept()<\/code> \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0628\u0631\u0627\u06cc \u062c\u0627\u0633\u0648\u0633\u06cc \u0648 \u062e\u0631\u062f \u06a9\u0631\u062f\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627 \u0648 \u067e\u0627\u0633\u062e\u200c\u0647\u0627\u06cc \u0634\u0628\u06a9\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f \u0648 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u0622\u0646 \u0645\u06cc\u200c\u0634\u0648\u062f <code>cy.route()<\/code> \u0631\u0648\u0634.  \u0627\u0632 \u0633\u0648\u06cc \u062f\u06cc\u06af\u0631\u060c <code>cy.wait()<\/code> \u0631\u0648\u0634 \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0638\u0627\u0631 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0632\u0645\u0627\u0646 \u062b\u0627\u0628\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <em>\u06cc\u0627<\/em> \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06cc\u06a9 \u0645\u0646\u0628\u0639 \u0645\u0633\u062a\u0639\u0627\u0631 \u062d\u0644 \u0634\u0648\u062f.<\/p>\n<p>\u0645\u0627 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a XHR \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0631\u0633\u0627\u0644 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <code>\/comments<\/code> \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc\u060c \u062f\u0631 \u0627\u0646\u062a\u0638\u0627\u0631 \u067e\u0627\u0633\u062e \u0648 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0622\u0646.  \u0627\u06cc\u0646 \u062f\u0642\u06cc\u0642\u0627\u064b \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u0646\u0627\u0633\u0628\u06cc \u0627\u0633\u062a <code>intercept()<\/code> (\u0628\u0631\u0627\u06cc \u062e\u0631\u062f \u06a9\u0631\u062f\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a) \u0648 <code>wait()<\/code> (\u0645\u0646\u062a\u0638\u0631 \u0628\u0645\u0627\u0646\u06cc\u062f \u062a\u0627 \u0645\u0646\u0628\u0639 \u0628\u0631\u06af\u0634\u062a\u06cc \u062d\u0644 \u0634\u0648\u062f).<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0686\u0646\u062f \u062a\u0633\u062a \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <code>aliasing_tests.spec.js<\/code> \u0641\u0627\u06cc\u0644:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/\/ &lt;reference types=\"cypress\" \/&gt;<\/span>\ncontext(<span class=\"hljs-string\">'Aliasing XHR'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {    \n  <span class=\"hljs-comment\">\/\/ Aliasing in beforeEach makes the route aliased in every test in this context    <\/span>\n  beforeEach(<span class=\"hljs-function\">() =&gt;<\/span> {        \n    <span class=\"hljs-comment\">\/\/ Stub and access any XHR GET request and route to **\/comments\/*.         <\/span>\n    <span class=\"hljs-comment\">\/\/ The ** and * are wild cards, meaning it could be `\/microservice\/comments\/1`<\/span>\n    <span class=\"hljs-comment\">\/\/ or in our case `https:\/\/jsonplaceholder.cypress.io\/comments\/1`       <\/span>\n    <span class=\"hljs-comment\">\/\/ the `as()` function allows us to later `get()` this route with any valid chainable function<\/span>\n    cy.intercept(<span class=\"hljs-string\">'GET'<\/span>, <span class=\"hljs-string\">'**\/comments\/*'<\/span>).as(<span class=\"hljs-string\">'getComment'<\/span>);        \n    cy.navigateToAliasingPage();    \n  });        \n  it(<span class=\"hljs-string\">'clicks a button and expects a comment'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {        \n    <span class=\"hljs-comment\">\/\/ Clicking this button will create and XHR request that generates a comment        <\/span>\n    cy.get(<span class=\"hljs-string\">'.network-btn'<\/span>).click()        \n    <span class=\"hljs-comment\">\/\/ `wait()` is one of the valid chainable actions where we can use the aliased endpoint<\/span>\n    <span class=\"hljs-comment\">\/\/ `then()` will allow us to access all the elements of the response <\/span>\n    <span class=\"hljs-comment\">\/\/ for validation whether or not this is available \u0631\u0648\u06cc UI        <\/span>\n    cy.wait(<span class=\"hljs-string\">'@getComment'<\/span>).then(<span class=\"hljs-function\">(<span class=\"hljs-params\">getCommentResponse<\/span>) =&gt;<\/span> {            \n      <span class=\"hljs-comment\">\/\/ `getCommentResponse` contains all the data from our response. <\/span>\n      <span class=\"hljs-comment\">\/\/ You can investigate this in the network tab of your browser            <\/span>\n      <span class=\"hljs-comment\">\/\/ Check that the response code is what we expect            <\/span>\n      expect(getCommentResponse.response.statusCode).to.equal(<span class=\"hljs-number\">200<\/span>);            \n      <span class=\"hljs-comment\">\/\/ Check that the `response.body` has a parameter named 'email', equal to a certain value<\/span>\n      expect(getCommentResponse.response.body.email).to.equal(<span class=\"hljs-string\">'(email\u00a0protected)'<\/span>);            \n      <span class=\"hljs-comment\">\/\/ Perform same check but for the `name` parameter            <\/span>\n      expect(getCommentResponse.response.body.name).to.equal(<span class=\"hljs-string\">'id labore ex et quam laborum'<\/span>);        \n    });    \n  });\n});\n<\/code><\/pre>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u062f\u0627\u0645\u0647 \u062f\u0647\u06cc\u0645 \u0648 \u0627\u06cc\u0646 \u062a\u0633\u062a \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> cypress run --record --spec <span class=\"hljs-string\">\"cypress\/integration\/my_tests\/aliasing_tests.spec.js\"<\/span><\/span>\n<\/code><\/pre>\n<p>\u06a9\u0647 \u0645\u0646\u062c\u0631 \u0628\u0647:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/end-to-end-testing-with-cypress-5.png\" alt=\"\u0627\u0631\u0633\u0627\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc XHR \u0628\u0627 \u0633\u0631\u0648\" title=\"\"><\/p>\n<h2 id=\"mockingxhrrequestresponses\"><span class=\"ez-toc-section\" id=\"%d9%be%d8%a7%d8%b3%d8%ae_%d9%87%d8%a7%db%8c_%d8%af%d8%b1%d8%ae%d9%88%d8%a7%d8%b3%d8%aa_%d8%aa%d9%85%d8%b3%d8%ae%d8%b1_xhr\"><\/span>\u067e\u0627\u0633\u062e \u0647\u0627\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u062a\u0645\u0633\u062e\u0631 XHR<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u06cc\u06a9\u06cc \u062f\u06cc\u06af\u0631 \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0645\u0641\u06cc\u062f\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0622\u0646 \u062a\u0648\u062c\u0647 \u06a9\u0646\u06cc\u062f \u0627\u06cc\u0646 \u0648\u0627\u0642\u0639\u06cc\u062a \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0637\u0648\u0631 \u06a9\u0627\u0645\u0644 \u0627\u0632 \u0622\u0646 \u0635\u0631\u0641 \u0646\u0638\u0631 \u06a9\u0646\u06cc\u062f process \u0627\u06cc\u062c\u0627\u062f \u0646\u0638\u0631 \u0627\u0632 \u0628\u062e\u0634 \u0642\u0628\u0644  \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0634\u0628\u06a9\u0647\u060c \u067e\u0627\u0633\u062e \u0633\u0627\u062e\u062a\u06af\u06cc \u062e\u0648\u062f \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f <code>cy.intercept()<\/code>.  \u0627\u06cc\u0646 \u0632\u0645\u0627\u0646\u06cc \u0645\u0641\u06cc\u062f \u0627\u0633\u062a \u06a9\u0647 \u0628\u06a9\u200c\u0627\u0646\u062f \u0647\u0646\u0648\u0632 \u062a\u0648\u0633\u0639\u0647 \u0646\u06cc\u0627\u0641\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u0627\u0633\u062e \u0631\u0627 \u0642\u0628\u0644 \u0627\u0632 \u0627\u062a\u0645\u0627\u0645 \u0622\u0646 \u0645\u0633\u062e\u0631\u0647 \u06a9\u0646\u06cc\u062f\u060c \u06cc\u0627 \u0641\u0642\u0637 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0641\u0642\u0637 \u0627\u06cc\u0646 \u0628\u062e\u0634 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u06a9\u0627\u0631\u0628\u0631\u062f \u062f\u06cc\u06af\u0631\u06cc \u0628\u0631\u0627\u06cc \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0641\u06cc\u06a9\u0633\u0686\u0631 \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u062f\u0627\u0631\u06cc\u0645.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>mock_comment.json<\/code> \u06a9\u0647 \u062d\u0627\u0648\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u0633\u062e\u0631\u0647 \u0634\u062f\u0647 \u06cc\u06a9 \u0646\u0638\u0631 \u0627\u0633\u062a \u0648 \u0645\u062d\u062a\u0648\u0627\u06cc JSON \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<pre><code class=\"hljs\">{  \n  <span class=\"hljs-attr\">\"postId\"<\/span>: <span class=\"hljs-number\">1<\/span>,  \n  <span class=\"hljs-attr\">\"id\"<\/span>: <span class=\"hljs-number\">1<\/span>,  \n  <span class=\"hljs-attr\">\"name\"<\/span>: <span class=\"hljs-string\">\"My Name\"<\/span>,  \n  <span class=\"hljs-attr\">\"email\"<\/span>: <span class=\"hljs-string\">\"(email\u00a0protected)\"<\/span>,  \n  <span class=\"hljs-attr\">\"body\"<\/span>: <span class=\"hljs-string\">\"My Comment Body\"<\/span>\n}\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062f\u06cc\u06af\u0631 \u0628\u0647 \u0646\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>intercepting_requests.spec.js<\/code> \u0632\u06cc\u0631 <code>\/my_tests<\/code> \u0641\u0647\u0631\u0633\u062a \u0631\u0627\u0647\u0646\u0645\u0627.  \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c \u0645\u0627 \u0647\u0645\u0627\u0646 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0631\u0627 \u0642\u0637\u0639 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645\u060c \u0627\u0645\u0627 \u0641\u06cc\u06a9\u0633\u0686\u0631 \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0627\u0633\u062e \u062a\u0632\u0631\u06cc\u0642 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645\u060c \u0648 \u06a9\u0627\u0645\u0644\u0627\u064b \u0627\u0632 \u0622\u0646 \u0635\u0631\u0641\u0646\u0638\u0631 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 <em>\u0648\u0627\u0642\u0639\u06cc<\/em> \u062f\u0631\u062e\u0648\u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/\/ &lt;reference types=\"cypress\" \/&gt;<\/span>\ndescribe(<span class=\"hljs-string\">'Intercepting XHR'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n  beforeEach(<span class=\"hljs-function\">() =&gt;<\/span> {       \n    <span class=\"hljs-comment\">\/\/ By adding an object `{fixture: 'mock_comment.json'}` in the `intercept()` call,<\/span>\n    <span class=\"hljs-comment\">\/\/ we are telling cypress to use the JSON file as the response.      <\/span>\n    <span class=\"hljs-comment\">\/\/ It can also be aliased using `.as()`.  <\/span>\n    cy.intercept(<span class=\"hljs-string\">'GET'<\/span>, <span class=\"hljs-string\">'**\/comments\/*'<\/span>,\n                 {<span class=\"hljs-attr\">fixture<\/span>: <span class=\"hljs-string\">'mock_comment.json'<\/span>}).as(<span class=\"hljs-string\">'getComment'<\/span>);       \n    cy.navigateToAliasingPage();    \n  });        \n  it(<span class=\"hljs-string\">'Clicks a button and expects a comment'<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {        \n    cy.get(<span class=\"hljs-string\">'.network-btn'<\/span>).click()        \n    <span class=\"hljs-comment\">\/\/ There is no need to validate the response now since we mocked it,<\/span>\n    <span class=\"hljs-comment\">\/\/ but there is a need to validate the UI        <\/span>\n    cy.fixture(<span class=\"hljs-string\">'mock_comment'<\/span>).then(<span class=\"hljs-function\">(<span class=\"hljs-params\">json<\/span>)=&gt;<\/span>{           \n      <span class=\"hljs-comment\">\/\/ We are accessing the comment directly from `mock_comment.json`<\/span>\n      <span class=\"hljs-comment\">\/\/ and checking that the UI is displaying it in its fullest         <\/span>\n      cy.get(<span class=\"hljs-string\">'.network-comment'<\/span>).should(<span class=\"hljs-string\">'have.text'<\/span>, json.body);        \n    });    \n  });\n});\n<\/code><\/pre>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u06cc\u0646 \u062a\u0633\u062a \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> cypress run --record --spec <span class=\"hljs-string\">\"cypress\/integration\/my_tests\/intercepting_requests.spec.js\"<\/span><\/span>\n<\/code><\/pre>\n<p>\u06a9\u0647 \u0645\u0646\u062c\u0631 \u0628\u0647:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/end-to-end-testing-with-cypress-6.png\" alt=\"\u067e\u0627\u0633\u062e \u062a\u0645\u0633\u062e\u0631 \u0622\u0645\u06cc\u0632 XHR \u0628\u0631\u0627\u06cc \u0633\u0631\u0648\" title=\"\"><\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>Cypress \u06cc\u06a9 \u0627\u0628\u0632\u0627\u0631 \u062a\u0633\u062a \u0646\u0648\u0638\u0647\u0648\u0631 \u0639\u0627\u0644\u06cc \u0627\u0633\u062a.  \u0627\u06cc\u0646 \u0628\u0633\u06cc\u0627\u0631 \u0633\u0628\u06a9 \u0648\u0632\u0646 \u0648 \u0622\u0633\u0627\u0646 \u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc\u060c \u0648 \u0634\u06af\u0641\u062a \u0627\u0646\u06af\u06cc\u0632 \u0628\u0631\u0627\u06cc TDD\u060c \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0648\u06cc \u0628\u0627\u0644\u0627\u06cc \u0645\u0648\u06a9\u0627 \u0648 \u0686\u0627\u06cc.  \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0631\u0627 \u0628\u0647 \u0634\u0645\u0627 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u06a9\u0627\u0645\u0644 \u0628\u06a9 \u0627\u0646\u062f \u062e\u0648\u062f \u0631\u0627 \u0645\u0633\u062e\u0631\u0647 \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0647 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0642\u0628\u0644 \u0627\u0632 \u0627\u062f\u063a\u0627\u0645 \u0628\u0627 \u0628\u06a9 \u0627\u0646\u062f \u06cc\u0627 \u062f\u0631 \u0635\u0648\u0631\u062a\u06cc \u06a9\u0647 \u0628\u06a9 \u0627\u0646\u062f \u0634\u0645\u0627 \u0647\u0646\u0648\u0632 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0639\u0627\u0644\u06cc \u0627\u0633\u062a.  \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u062f\u0631 \u0628\u0631\u062e\u06cc \u0645\u0648\u0627\u0631\u062f \u0628\u0647 \u0634\u06a9\u0644\u200c\u062f\u0647\u06cc \u0628\u06a9\u200c\u0627\u0646\u062f \u06a9\u0645\u06a9 \u06a9\u0646\u062f\u060c \u0632\u06cc\u0631\u0627 \u062f\u0642\u06cc\u0642\u0627\u064b \u0622\u0646\u0686\u0647 \u0631\u0627 \u06a9\u0647 \u0642\u0633\u0645\u062a \u062c\u0644\u0648\u06cc\u06cc \u0627\u0646\u062a\u0638\u0627\u0631 \u062f\u0627\u0631\u062f \u0645\u0634\u062e\u0635 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0627\u06af\u0631 \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u0627\u0628\u0632\u0627\u0631\u06cc \u0647\u0633\u062a\u06cc\u062f \u06a9\u0647 \u062f\u0631 \u0645\u0648\u0627\u0631\u062f\u06cc \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0628\u0633\u06cc\u0627\u0631 \u0627\u0646\u0639\u0637\u0627\u0641\u200c\u067e\u0630\u06cc\u0631 \u0628\u0627\u0634\u062f\u060c \u0648 \u0628\u0647 \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u0628\u0632\u0631\u06af\u060c \u0634\u062e\u0635\u06cc \u0648 \u0633\u0641\u0627\u0631\u0634\u06cc\u200c\u0634\u062f\u0647 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0647 \u0633\u0644\u0646\u06cc\u0648\u0645 \u0628\u0686\u0633\u0628\u06cc\u062f.<\/p>\n<\/div>\n<p>    (\u0628\u0631\u0686\u0633\u0628\u200c\u0647\u0627 \u0628\u0631\u0627\u06cc \u062a\u0631\u062c\u0645\u0647)# \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<br \/>\n<br \/><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-16 03:34:04<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;15722&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u062a\u0633\u062a \u0633\u0631\u062a\u0627\u0633\u0631\u06cc \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0627 \u0627\u062a\u0648\u0645\u0627\u0633\u06cc\u0648\u0646 \u062a\u0633\u062a CypressEnd-to-End \u0628\u062e\u0634 \u0645\u0647\u0645\u06cc \u0627\u0632 \u0686\u0631\u062e\u0647 \u0639\u0645\u0631 \u062a\u0648\u0633\u0639\u0647 \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0648\u0628 \u0627\u0633\u062a.  \u0645\u0633\u0644\u0645\u0627\u064b \u0627\u0646\u062a\u062e\u0627\u0628 \u0627\u0628\u0632\u0627\u0631 \u0645\u0646\u0627\u0633\u0628 \u0628\u0631\u0627\u06cc \u0634\u0645\u0627 \u0648 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0627\u0632 \u0627\u0647\u0645\u06cc\u062a \u0628\u06cc\u0634\u062a\u0631\u06cc \u0628\u0631\u062e\u0648\u0631\u062f\u0627\u0631 \u0627\u0633\u062a.  \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0627\u0646\u062a\u0647\u0627 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Cypress \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u0634\u062a.  \\u0026quot;\u067e\u0627\u06cc\u0627\u0646 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627\\u0026raquo;  \u062a\u0633\u062a \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 ...&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 12<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc \u0627\u062a\u0648\u0645\u0627\u0633\u06cc\u0648\u0646 \u062a\u0633\u062a \u0633\u0631\u062a\u0627\u0633\u0631 \u0628\u062e\u0634 \u0645\u0647\u0645\u06cc \u0627\u0632 \u0686\u0631\u062e\u0647 \u0639\u0645\u0631 \u062a\u0648\u0633\u0639\u0647 \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0648\u0628 \u0627\u0633\u062a. \u0627\u0646\u062a\u062e\u0627\u0628 \u0627\u0628\u0632\u0627\u0631 \u0645\u0646\u0627\u0633\u0628 \u0628\u0631\u0627\u06cc \u0634\u0645\u0627 \u0648 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0645\u0633\u0644\u0645\u0627\u064b \u0645\u0647\u0645\u062a\u0631 \u0627\u0633\u062a. \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u062a\u0633\u062a \u0627\u0646\u062a\u0647\u0627 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0633\u0631\u0648. &#8220;\u067e\u0627\u06cc\u0627\u0646 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627&#8221; \u062a\u0633\u062a \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 process \u0634\u0628\u06cc\u0647 \u0633\u0627\u0632\u06cc \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0648 \u062a\u0639\u0627\u0645\u0644 \u06a9\u0627\u0631\u0628\u0631 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":15723,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[],"class_list":["post-15722","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15722","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=15722"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15722\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/15723"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=15722"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=15722"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=15722"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}