{"id":14241,"date":"2024-01-04T13:48:14","date_gmt":"2024-01-04T10:18:14","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%aa%d8%b3%d8%aa-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c\/"},"modified":"2024-01-04T13:48:14","modified_gmt":"2024-01-04T10:18:14","slug":"%d8%aa%d8%b3%d8%aa-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%b3%d8%aa-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c\/","title":{"rendered":"\u062a\u0633\u062a \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0647\u0627\u06cc Vue.js \u0628\u0627 Vue Test UtilsSoftware \u062a\u0633\u062a \u0627\u0633\u062a process \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u0648 \u062a\u0623\u06cc\u06cc\u062f \u0627\u06cc\u0646\u06a9\u0647 \u06cc\u06a9 \u0645\u062d\u0635\u0648\u0644 \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631\u06cc \u0628\u0627 \u0645\u0648\u0641\u0642\u06cc\u062a \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0648\u0638\u0627\u06cc\u0641 \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u062e\u0648\u062f \u0631\u0627 \u0628\u062f\u0648\u0646 \u0647\u06cc\u0686 \u062e\u0637\u0627\u06cc\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f.  \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0628\u0631\u062e\u06cc \u0627\u0632 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u062a\u0644\u0627\u0641 \u0648\u0642\u062a \u0628\u0647 \u0646\u0638\u0631 \u0628\u0631\u0633\u062f\u060c \u0627\u0645\u0627 \u0645\u0647\u0645 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u06cc\u0627 \u0627\u062c\u0632\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u062f \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f &#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-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c\/#vue_test_utils_%da%86%db%8c%d8%b3%d8%aa%d8%9f\" >Vue Test Utils \u0686\u06cc\u0633\u062a\u061f<\/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-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c\/#%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_%d9%85%d8%ad%db%8c%d8%b7_%d8%aa%d8%b3%d8%aa_%d9%85%d8%a7\" >\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u062d\u06cc\u0637 \u062a\u0633\u062a \u0645\u0627<\/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-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c\/#%d9%86%d9%88%d8%b4%d8%aa%d9%86_%d8%a7%d9%88%d9%84%db%8c%d9%86_%d8%a2%d8%b2%d9%85%d9%88%d9%86\" >\u0646\u0648\u0634\u062a\u0646 \u0627\u0648\u0644\u06cc\u0646 \u0622\u0632\u0645\u0648\u0646<\/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-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c\/#%d8%b1%d9%86%d8%af%d8%b1_%d9%85%d8%b4%d8%b1%d9%88%d8%b7\" >\u0631\u0646\u062f\u0631 \u0645\u0634\u0631\u0648\u0637<\/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-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c\/#%d8%b1%d9%88%d8%b4_%d8%aa%d8%b3%d8%aa_%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af%d9%87%d8%a7%db%8c_%d9%85%d9%86%d8%aa%d8%b4%d8%b1_%d8%b4%d8%af%d9%87\" >\u0631\u0648\u0634 \u062a\u0633\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647<\/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-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%db%8c\/#%d8%b1%d9%88%d8%b4_%d8%aa%d8%b3%d8%aa_%d9%81%d8%b1%d9%85_%d9%87%d8%a7\" >\u0631\u0648\u0634 \u062a\u0633\u062a \u0641\u0631\u0645 \u0647\u0627<\/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-%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa-%d9%87%d8%a7%db%8c-vue-js-%d8%a8%d8%a7-vue-test-utilssoftware-%d8%aa%d8%b3%d8%aa-%d8%a7%d8%b3%d8%aa-process-%d8%a7%d8%b1%d8%b2%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\"> 9<\/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<p>\u062a\u0633\u062a \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0627\u0633\u062a process \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u0648 \u062a\u0623\u06cc\u06cc\u062f \u0627\u06cc\u0646\u06a9\u0647 \u06cc\u06a9 \u0645\u062d\u0635\u0648\u0644 \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631\u06cc \u0628\u0627 \u0645\u0648\u0641\u0642\u06cc\u062a \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0648\u0638\u0627\u06cc\u0641 \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u062e\u0648\u062f \u0631\u0627 \u0628\u062f\u0648\u0646 \u0647\u06cc\u0686 \u062e\u0637\u0627\u06cc\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f.  \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0628\u0631\u062e\u06cc \u0627\u0632 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u062a\u0644\u0627\u0641 \u0648\u0642\u062a \u0628\u0647 \u0646\u0638\u0631 \u0628\u0631\u0633\u062f\u060c \u0627\u0645\u0627 \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u062e\u0648\u0628 \u0628\u0633\u0627\u0632\u06cc\u062f\u060c \u0645\u0647\u0645 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u06cc\u0627 \u0627\u062c\u0632\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u062f.<\/p>\n<p><a href=\"https:\/\/test-utils.vuejs.org\/\" target=\"_blank\" rel=\"noopener noreferrer\">Vue Test Utils<\/a> (VTU) \u0645\u062c\u0645\u0648\u0639\u0647 \u0627\u06cc \u0627\u0632 \u062a\u0648\u0627\u0628\u0639 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u0647\u062f\u0641 \u0633\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0627\u062c\u0632\u0627\u06cc Vue.js \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f.  \u0631\u0648\u0634 \u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0633\u0648\u0627\u0631 \u06a9\u0631\u062f\u0646 \u0648 \u062a\u0639\u0627\u0645\u0644 \u0628\u0627 \u0627\u062c\u0632\u0627\u06cc Vue \u0628\u0647 \u0635\u0648\u0631\u062a \u0627\u06cc\u0632\u0648\u0644\u0647 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.  \u0627\u0632 \u0632\u0645\u0627\u0646 \u0627\u0646\u062a\u0642\u0627\u0644 \u0627\u0632 Vue 2 \u0628\u0647 Vue 3\u060c \u0646\u0633\u062e\u0647 \u062c\u062f\u06cc\u062f\u06cc \u0627\u0632 Vue Test Utils \u0628\u0647 \u0637\u0648\u0631 \u062e\u0627\u0635 \u0628\u0631\u0627\u06cc Vue 3 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0645\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0631\u0648\u06cc\u06a9\u0631\u062f \u062a\u0633\u062a \u0627\u0648\u0644\u060c \u06cc\u06a9 \u0646\u0645\u0648\u0646\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u06cc\u200c\u0633\u0627\u0632\u06cc\u0645.  \u0645\u0627 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u0648\u0627\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue Test Utils \u0631\u0627 \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u0624\u0644\u0641\u0647\u200c\u0647\u0627\u06cc Vue \u0648 \u0631\u0648\u0634 \u0646\u0648\u0634\u062a\u0646 \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 \u0622\u0633\u0627\u0646 \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0628\u0627 Vue Test Utils \u067e\u0648\u0634\u0634 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f.<\/p>\n<h2 id=\"whatisvuetestutils\"><span class=\"ez-toc-section\" id=\"vue_test_utils_%da%86%db%8c%d8%b3%d8%aa%d8%9f\"><\/span>Vue Test Utils \u0686\u06cc\u0633\u062a\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0645\u0633\u062a\u0646\u062f\u0627\u062a\u060c Vue Test Utils (VTU) \u0645\u062c\u0645\u0648\u0639\u0647 \u0627\u06cc \u0627\u0632 \u062a\u0648\u0627\u0628\u0639 \u06a9\u0645\u06a9\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0633\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0627\u062c\u0632\u0627\u06cc Vue.js \u0637\u0631\u0627\u062d\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0627\u06cc\u0646 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0631\u0648\u0634\u06cc \u0628\u0631\u0627\u06cc \u0646\u0635\u0628 \u0627\u062c\u0632\u0627\u06cc Vue \u0648 \u062a\u0639\u0627\u0645\u0644 \u0628\u0627 \u0622\u0646\u0647\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0627\u06cc\u0632\u0648\u0644\u0647 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.  \u0627\u0632 \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0644\u0641\u0627\u0641 \u06cc\u0627\u062f \u06a9\u0631\u062f.  \u062f\u0631 \u0627\u0635\u0644\u060c \u0644\u0641\u0627\u0641 \u0627\u0646\u062a\u0632\u0627\u0639\u06cc \u0627\u0632 \u062c\u0632\u0621 \u0646\u0635\u0628 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0628\u0631\u062e\u06cc \u0627\u0632 \u062a\u0648\u0627\u0628\u0639 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0631\u0627 \u0622\u0633\u0627\u0646 \u062a\u0631 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u06a9\u062f \u0631\u0627 \u0648\u0627\u0631\u062f \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0627\u062c\u062a\u0646\u0627\u0628 \u0627\u0632 \u0645\u0639\u0631\u0641\u06cc \u0627\u0634\u06a9\u0627\u0644 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0647\u0645 \u0627\u0633\u062a.  \u0634\u0627\u06cc\u062f\u060c \u0627\u06af\u0631 \u0627\u0634\u062a\u0628\u0627\u0647\u0627\u064b \u06cc\u06a9 \u0628\u0627\u06af \u0631\u0627 \u0628\u0647 \u062a\u0648\u0644\u06cc\u062f \u0631\u0633\u0627\u0646\u062f\u0647 \u0627\u06cc\u062f\u060c \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0642\u0628\u0644 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u0647 \u0633\u0631\u0648\u0631\u0647\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f \u0628\u0631\u0633\u062f\u060c \u0645\u0637\u0644\u0639 \u0634\u0648\u06cc\u062f.  \u0622\u0632\u0645\u0627\u06cc\u0634 \u0635\u062d\u06cc\u062d \u067e\u0627\u06cc\u06af\u0627\u0647 \u06a9\u062f \u0634\u0645\u0627 \u0631\u0627 \u0642\u0627\u062f\u0631 \u0645\u06cc \u0633\u0627\u0632\u062f \u062a\u0627 \u0642\u0628\u0644 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0622\u0633\u06cc\u0628\u06cc \u0648\u0627\u0631\u062f \u0634\u0648\u062f\u060c \u0645\u0634\u06a9\u0644 \u0631\u0627 \u0628\u0631\u0637\u0631\u0641 \u06a9\u0646\u06cc\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0627\u06af\u0631 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u0628\u0631\u0627\u06cc \u0637\u0648\u0644\u0627\u0646\u06cc \u0645\u062f\u062a \u0647\u0633\u062a\u06cc\u062f\u060c \u0645\u0647\u0645 \u0627\u0633\u062a \u06a9\u0647 \u067e\u0627\u06cc\u06af\u0627\u0647 \u06a9\u062f \u062e\u0648\u062f \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u062f.<\/p>\n<h2 id=\"settingupourtestingenvironment\"><span class=\"ez-toc-section\" id=\"%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_%d9%85%d8%ad%db%8c%d8%b7_%d8%aa%d8%b3%d8%aa_%d9%85%d8%a7\"><\/span>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u062d\u06cc\u0637 \u062a\u0633\u062a \u0645\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639\u060c \u06cc\u06a9 \u067e\u0648\u0634\u0647 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u0648 \u0628\u0627 \u0627\u062c\u0631\u0627\u06cc \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 Vue.js \u0631\u0627 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm init vue@latest<\/span>\n<\/code><\/pre>\n<p>\u062f\u0633\u062a\u0648\u0631 \u0628\u0627\u0644\u0627 \u0646\u0635\u0628 \u0648 \u0627\u062c\u0631\u0627 \u062e\u0648\u0627\u0647\u062f \u0634\u062f <a href=\"https:\/\/github.com\/vuejs\/create-vue\" target=\"_blank\" rel=\"noopener noreferrer\">create-vue<\/a>\u060c \u0627\u0628\u0632\u0627\u0631 \u0631\u0633\u0645\u06cc \u062f\u0627\u0631\u0628\u0633\u062a \u067e\u0631\u0648\u0698\u0647 Vue.  \u0633\u067e\u0633\u060c \u0686\u0646\u062f\u06cc\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0646\u0635\u0628 \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f.  \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">\u2714 Project name: ... &lt;your-project-name&gt;\n\u2714 Add TypeScript? ... No \/ Yes\n\u2714 Add JSX Support? ... No \/ Yes\n\u2714 Add Vue Router for Single Page Application development? ... No \/ Yes\n\u2714 Add Pinia for state management? ... No \/ Yes\n\u2714 Add Vitest for Unit testing? ... No \/ Yes\n\u2714 Add Cypress for both Unit and End-to-End testing? ... No \/ Yes\n\u2714 Add ESLint for code quality? ... No \/ Yes\n\u2714 Add Prettier for code formatting? ... No \/ Yes\n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u00abESLint\u00bb\u060c \u00abPrettier\u00bb \u0648 \u00abJSX support\u00bb \u00ab\u0628\u0644\u0647\u00bb \u0648 \u0628\u0631\u0627\u06cc \u0628\u0642\u06cc\u0647 \u06af\u0632\u06cc\u0646\u0647 \u00ab\u0646\u0647\u00bb \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f.  \u0633\u067e\u0633 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0646\u0635\u0628 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \u0648 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> <span class=\"hljs-built_in\">cd<\/span> &lt;your-project-name&gt;<\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install<\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm run dev<\/span>\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0628\u0631\u0627\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 <a href=\"https:\/\/test-utils.vuejs.org\/\" target=\"_blank\" rel=\"noopener noreferrer\">Vue Test Utils<\/a>\u060c \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install --save-dev @vue\/test-utils<\/span>\n<span class=\"hljs-meta\">\n#<\/span><span class=\"bash\"> or<\/span>\n<span class=\"hljs-meta\">\n$<\/span><span class=\"bash\"> yarn add --dev @vue\/test-utils<\/span>\n<\/code><\/pre>\n<p>Vue Test Utils \u0627\u0633\u0627\u0633\u0627\u064b \u0686\u0627\u0631\u0686\u0648\u0628-\u0622\u06af\u0646\u0648\u0633\u062a\u06cc\u06a9 \u0627\u0633\u062a &#8211; \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0647\u0631 \u062a\u0633\u062a\u06cc \u06a9\u0647 \u062f\u0648\u0633\u062a \u062f\u0627\u0631\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.  \u0633\u0627\u062f\u0647 \u062a\u0631\u06cc\u0646 \u0631\u0627\u0647 \u0628\u0631\u0627\u06cc \u0627\u0645\u062a\u062d\u0627\u0646 \u06a9\u0631\u062f\u0646 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a <a href=\"https:\/\/jestjs.io\/\" target=\"_blank\" rel=\"noopener noreferrer\">\u0634\u0648\u062e\u06cc<\/a>\u060c \u06cc\u06a9 \u062a\u0633\u062a \u062f\u0648\u0646\u062f\u0647 \u0645\u062d\u0628\u0648\u0628 \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc <code>.vue<\/code> \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0628\u0627 Jest\u060c \u0634\u0645\u0627 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f <code>vue-jest<\/code>.  \u0628\u0631\u0627\u06cc \u0646\u0635\u0628 <code>vue-jest<\/code>\u060c \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install --save-dev vue-jest<\/span>\n<\/code><\/pre>\n<p>\u0633\u067e\u0633 Jest \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install --save-dev jest<\/span>\n<\/code><\/pre>\n<p>\u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062c\u062f\u06cc\u062f \u062f\u0631 \u067e\u0648\u0634\u0647 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0628\u0647 \u0646\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f <code>jest.config.js<\/code> \u0648 \u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-built_in\">module<\/span>.exports = {\n  <span class=\"hljs-attr\">preset<\/span>: <span class=\"hljs-string\">\"ts-jest\"<\/span>,\n  <span class=\"hljs-attr\">globals<\/span>: {},\n  <span class=\"hljs-attr\">testEnvironment<\/span>: <span class=\"hljs-string\">\"jsdom\"<\/span>,\n  <span class=\"hljs-attr\">transform<\/span>: {\n    <span class=\"hljs-string\">\"^.+\\\\.vue$\"<\/span>: <span class=\"hljs-string\">\"vue-jest\"<\/span>,\n    <span class=\"hljs-string\">\"^.+\\\\js$\"<\/span>: <span class=\"hljs-string\">\"babel-jest\"<\/span>,\n  },\n  <span class=\"hljs-attr\">moduleFileExtensions<\/span>: (<span class=\"hljs-string\">\"vue\"<\/span>, <span class=\"hljs-string\">\"js\"<\/span>, <span class=\"hljs-string\">\"json\"<\/span>, <span class=\"hljs-string\">\"jsx\"<\/span>, <span class=\"hljs-string\">\"ts\"<\/span>, <span class=\"hljs-string\">\"tsx\"<\/span>, <span class=\"hljs-string\">\"node\"<\/span>),\n};\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u0646\u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u062e\u0648\u062f\u062a\u0627\u0646 \u0622\u0646 \u0631\u0627 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627 \u0634\u0628\u06cc\u0647\u200c\u0633\u0627\u0632\u06cc \u0645\u062e\u0632\u0646 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0647\u0645\u0631\u0627\u0647 \u0628\u0627\u0634\u06cc\u062f. \u0631\u0648\u06cc GitHub <a href=\"https:\/\/github.com\/daacode\/vtu-next-demo\" target=\"_blank\" rel=\"noopener noreferrer\">\u0627\u06cc\u0646\u062c\u0627<\/a>.<\/p>\n<h2 id=\"writingyourfirsttest\"><span class=\"ez-toc-section\" id=\"%d9%86%d9%88%d8%b4%d8%aa%d9%86_%d8%a7%d9%88%d9%84%db%8c%d9%86_%d8%a2%d8%b2%d9%85%d9%88%d9%86\"><\/span>\u0646\u0648\u0634\u062a\u0646 \u0627\u0648\u0644\u06cc\u0646 \u0622\u0632\u0645\u0648\u0646<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue Test Utils \u0631\u0627 \u0628\u0627 \u0646\u0648\u0634\u062a\u0646 \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0633\u0627\u062f\u0647 \u0645\u0631\u0648\u0631 \u06a9\u0646\u06cc\u0645.  \u0628\u0627\u0632 \u06a9\u0646 <code>App.vue<\/code> \u0648 \u06cc\u06a9 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a demo todo \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">&lt;template&gt;\n  <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n&lt;\/template&gt;\n\n<span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">lang<\/span>=<span class=\"hljs-string\">\"ts\"<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">\"TodoApp\"<\/span>,\n\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">todos<\/span>: (\n        {\n          <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-number\">1<\/span>,\n          <span class=\"hljs-attr\">text<\/span>: <span class=\"hljs-string\">\"Go to the grocery store\"<\/span>,\n          <span class=\"hljs-attr\">completed<\/span>: <span class=\"hljs-literal\">false<\/span>,\n        },\n      ),\n    };\n  },\n};\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span><\/span>\n<\/code><\/pre>\n<p>\u067e\u0633 \u0627\u0632 \u0622\u0646\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u0648\u0644\u06cc\u0646 \u0622\u0632\u0645\u0627\u06cc\u0634 \u062e\u0648\u062f \u0631\u0627 \u0628\u0646\u0648\u06cc\u0633\u06cc\u0645 \u062a\u0627 \u062a\u0623\u06cc\u06cc\u062f \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u06cc\u06a9 todo \u0631\u0646\u062f\u0631 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0628\u0627\u0632 \u06a9\u0646 <code>App.spec.ts<\/code> \u0648 \u062a\u0633\u062a \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { mount } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"@vue\/test-utils\"<\/span>;\n<span class=\"hljs-keyword\">import<\/span> App <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\".\/App.vue\"<\/span>;\n\ntest(<span class=\"hljs-string\">\"renders a todo\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> wrapper = mount(App);\n\n  <span class=\"hljs-keyword\">const<\/span> todo = wrapper.get(<span class=\"hljs-string\">'(data-test=\"todo\")'<\/span>);\n\n  expect(todo.text()).toBe(<span class=\"hljs-string\">\"Go to the grocery store\"<\/span>);\n});\n<\/code><\/pre>\n<p>\u062f\u0631 \u062a\u0633\u062a \u0628\u0627\u0644\u0627 \u0627\u0632 <code>mount<\/code> \u0627\u0632 VTU \u0628\u0631\u0627\u06cc \u0631\u0646\u062f\u0631 \u06a9\u0631\u062f\u0646 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a.  \u0628\u0639\u062f \u0632\u0646\u06af \u0645\u06cc\u0632\u0646\u06cc\u0645 <code>mount<\/code> \u0648 \u062c\u0632\u0621 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0627\u0648\u0644\u06cc\u0646 \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u062f.  \u062f\u0631 \u0627\u0635\u0644\u060c \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u06cc\u0627\u0641\u062a\u0646 \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0628\u0627 \u0627\u0646\u062a\u062e\u0627\u0628\u06af\u0631 \u0647\u0633\u062a\u06cc\u0645 <code>data-test=\"todo\"<\/code> &#8211; \u062f\u0631 DOM\u060c \u0628\u0647 \u0646\u0638\u0631 \u0645\u06cc \u0631\u0633\u062f <code>&lt;div data-test=\"todo\"&gt;...&lt;\/div&gt;<\/code>.  \u0628\u0639\u062f\u060c \u0645\u0627 \u0631\u0627 \u0635\u062f\u0627 \u0645\u06cc \u0632\u0646\u06cc\u0645 <code>text<\/code> \u0631\u0648\u0634\u06cc \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u062d\u062a\u0648\u0627\u060c \u06a9\u0647 \u0627\u0646\u062a\u0638\u0627\u0631 \u062f\u0627\u0631\u06cc\u0645 \u00ab\u0628\u0631\u0648 \u0628\u0647 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0645\u0648\u0627\u062f \u063a\u0630\u0627\u06cc\u06cc\u00bb \u0628\u0627\u0634\u062f.<\/p>\n<p>\u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u0627\u06af\u0631 \u062a\u0633\u062a \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645 \u0628\u0627 \u067e\u06cc\u063a\u0627\u0645 \u062e\u0637\u0627\u06cc \u0632\u06cc\u0631 \u0646\u0627\u0645\u0648\u0641\u0642 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<pre><code class=\"hljs\">  FAIL  src\/App.spec.ts\n  \u2715 renders a todo (13ms)\n\n  \u25cf renders a todo\n  \n     Unable to get (data-test=\"todo\") within: &lt;div&gt;&lt;\/div&gt;\n<\/code><\/pre>\n<p>\u0622\u0632\u0645\u0627\u06cc\u0634 \u0646\u0627\u0645\u0648\u0641\u0642 \u0628\u0648\u062f \u0632\u06cc\u0631\u0627 \u0645\u0627 \u0647\u06cc\u0686 \u0645\u0648\u0631\u062f\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0646\u0645\u06cc\u200c\u062f\u0647\u06cc\u0645\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 <code>get()<\/code> \u062a\u0645\u0627\u0633 \u062f\u0631 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0646 \u06cc\u06a9 \u0644\u0641\u0627\u0641 \u0646\u0627\u06a9\u0627\u0645 \u0627\u0633\u062a.  \u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u06cc\u0645 <code>&lt;template&gt;<\/code> \u062f\u0631 <code>App.vue<\/code> \u0628\u0631\u0627\u06cc \u0627\u0631\u0627\u0626\u0647 <code>todos<\/code> \u0622\u0631\u0627\u06cc\u0647:<\/p>\n<pre><code class=\"hljs\">&lt;template&gt;\n  <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">v-for<\/span>=<span class=\"hljs-string\">\"todo in todos\"<\/span> <span class=\"hljs-attr\">:key<\/span>=<span class=\"hljs-string\">\"todo.id\"<\/span> <span class=\"hljs-attr\">data-test<\/span>=<span class=\"hljs-string\">\"todo\"<\/span>&gt;<\/span>\n      {{ todo.text }}\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n&lt;\/template&gt;\n<\/code><\/pre>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u062a\u063a\u06cc\u06cc\u0631 \u0628\u0627\u0644\u0627\u060c \u0622\u0632\u0645\u0648\u0646 \u0642\u0628\u0648\u0644 \u0645\u06cc \u0634\u0648\u062f:<\/p>\n<pre><code class=\"hljs\">PASS  src\/App.spec.ts\n  \u2713 renders a todo (24ms)\n\nTest Suites: 1 passed, 1 total\nTests:       1 passed, 1 total\nSnapshots:   0 total\nTime:        2.092s\nRan all test suites.\n\u2728  Done in 5.51s.\n<\/code><\/pre>\n<p>\u0634\u0645\u0627 \u0627\u0648\u0644\u06cc\u0646 \u062a\u0633\u062a \u0645\u0624\u0644\u0641\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u0645\u0648\u0641\u0642\u06cc\u062a \u0646\u0648\u0634\u062a\u06cc\u062f.<\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06af\u0627\u0645 \u0628\u0639\u062f\u06cc\u060c \u0627\u06cc\u0646 \u0642\u0627\u0628\u0644\u06cc\u062a \u0631\u0627 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u06cc\u06a9 todo \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u062f.  \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u06cc\u0627\u0628\u06cc \u0628\u0647 \u0622\u0646\u060c \u0628\u0647 \u0641\u0631\u0645\u06cc \u0628\u0627 \u0648\u0631\u0648\u062f\u06cc \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645 \u062a\u0627 \u06a9\u0627\u0631\u0628\u0631 \u0628\u062a\u0648\u0627\u0646\u062f \u0645\u062a\u0646\u06cc \u0631\u0627 \u062a\u0627\u06cc\u067e \u06a9\u0646\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0648\u0642\u062a\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0641\u0631\u0645 \u0631\u0627 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u0646\u062a\u0638\u0627\u0631 \u062f\u0627\u0631\u06cc\u0645 todo \u0627\u0631\u0627\u0626\u0647 \u0634\u0648\u062f.  \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0628\u0647 \u062a\u0633\u062a \u0632\u06cc\u0631 \u0646\u06af\u0627\u0647\u06cc \u0628\u06cc\u0646\u062f\u0627\u0632\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { mount } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"@vue\/test-utils\"<\/span>;\n<span class=\"hljs-keyword\">import<\/span> App <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\".\/App.vue\"<\/span>;\n\ntest(<span class=\"hljs-string\">\"creates a todo\"<\/span>, <span class=\"hljs-keyword\">async<\/span> () =&gt; {\n  <span class=\"hljs-keyword\">const<\/span> wrapper = mount(App);\n\n  <span class=\"hljs-keyword\">await<\/span> wrapper.get(<span class=\"hljs-string\">'(data-test=\"new-todo\")'<\/span>).setValue(<span class=\"hljs-string\">\"New todo\"<\/span>);\n  <span class=\"hljs-keyword\">await<\/span> wrapper.get(<span class=\"hljs-string\">'(data-test=\"form\")'<\/span>).trigger(<span class=\"hljs-string\">\"submit\"<\/span>);\n\n  expect(wrapper.findAll(<span class=\"hljs-string\">'(data-test=\"todo\")'<\/span>)).toHaveLength(<span class=\"hljs-number\">2<\/span>);\n});\n<\/code><\/pre>\n<p>\u062f\u0631 \u0622\u0632\u0645\u0648\u0646 \u0641\u0648\u0642\u060c \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>mount<\/code> \u0631\u0648\u0634 \u0631\u0646\u062f\u0631 \u0639\u0646\u0635\u0631  \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0627\u0638\u0647\u0627\u0631 \u062f\u0627\u0634\u062a\u06cc\u0645 \u06a9\u0647 \u062a\u0646\u0647\u0627 1 \u06a9\u0627\u0631 \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a &#8211; \u0627\u06cc\u0646 \u0645\u0648\u0636\u0648\u0639 \u0631\u0648\u0634\u0646\u200c\u062a\u0631 \u0645\u06cc\u200c\u0634\u0648\u062f \u06a9\u0647 \u0645\u0627 \u06cc\u06a9 \u06a9\u0627\u0631 \u0627\u0636\u0627\u0641\u06cc \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645\u060c \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u062e\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0646\u0634\u0627\u0646 \u0645\u06cc\u200c\u062f\u0647\u062f.  \u0628\u0631\u0627\u06cc \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc <code>input<\/code>\u060c \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>setValue<\/code> \u0631\u0648\u0634 &#8211; \u0627\u06cc\u0646 \u0645\u0627 \u0631\u0627 \u0642\u0627\u062f\u0631 \u0645\u06cc \u0633\u0627\u0632\u062f \u0645\u0642\u062f\u0627\u0631 \u0648\u0631\u0648\u062f\u06cc \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0633\u067e\u0633 \u067e\u0633 \u0627\u0632 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc <code>input<\/code>\u060c \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>trigger<\/code> \u0631\u0648\u0634\u06cc \u0628\u0631\u0627\u06cc \u0634\u0628\u06cc\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0641\u0631\u0645\u060c \u0648 \u0633\u067e\u0633 \u0627\u062f\u0639\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u062a\u0639\u062f\u0627\u062f \u0645\u0648\u0627\u0631\u062f \u06a9\u0627\u0631 \u0627\u0632 1 \u0628\u0647 2 \u0627\u0641\u0632\u0627\u06cc\u0634 \u06cc\u0627\u0641\u062a\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06af\u0631 \u062a\u0633\u062a \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f\u060c \u0634\u06a9\u0633\u062a \u0645\u06cc \u062e\u0648\u0631\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc <code>App.vue<\/code> \u0634\u0627\u0645\u0644 \u0634\u0648\u062f <code>form<\/code> \u0648 <code>input<\/code> \u0639\u0646\u0627\u0635\u0631 \u0628\u0631\u0627\u06cc \u0642\u0628\u0648\u0644\u06cc \u062f\u0631 \u0622\u0632\u0645\u0648\u0646:<\/p>\n<pre><code class=\"hljs\">&lt;template&gt;\n  <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">v-for<\/span>=<span class=\"hljs-string\">\"todo in todos\"<\/span> <span class=\"hljs-attr\">:key<\/span>=<span class=\"hljs-string\">\"todo.id\"<\/span> <span class=\"hljs-attr\">data-test<\/span>=<span class=\"hljs-string\">\"todo\"<\/span>&gt;<\/span>\n      {{ todo.text }}\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">form<\/span> <span class=\"hljs-attr\">data-test<\/span>=<span class=\"hljs-string\">\"form\"<\/span> @<span class=\"hljs-attr\">submit.prevent<\/span>=<span class=\"hljs-string\">\"createTodo\"<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">data-test<\/span>=<span class=\"hljs-string\">\"new-todo\"<\/span> <span class=\"hljs-attr\">v-model<\/span>=<span class=\"hljs-string\">\"newTodo\"<\/span> \/&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">form<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n&lt;\/template&gt;\n\n<span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">lang<\/span>=<span class=\"hljs-string\">\"ts\"<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">\"TodoApp\"<\/span>,\n\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">newTodo<\/span>: <span class=\"hljs-string\">\"\"<\/span>,\n      <span class=\"hljs-attr\">todos<\/span>: (\n        {\n          <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-number\">1<\/span>,\n          <span class=\"hljs-attr\">text<\/span>: <span class=\"hljs-string\">\"Go to the grocery store\"<\/span>,\n          <span class=\"hljs-attr\">completed<\/span>: <span class=\"hljs-literal\">false<\/span>,\n        },\n      ),\n    };\n  },\n\n  <span class=\"hljs-attr\">methods<\/span>: {\n    <span class=\"hljs-function\"><span class=\"hljs-title\">createTodo<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-built_in\">this<\/span>.todos.push({\n        <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-number\">2<\/span>,\n        <span class=\"hljs-attr\">text<\/span>: <span class=\"hljs-built_in\">this<\/span>.newTodo,\n        <span class=\"hljs-attr\">completed<\/span>: <span class=\"hljs-literal\">false<\/span>,\n      });\n    },\n  },\n};\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span><\/span>\n<\/code><\/pre>\n<p>\u062f\u0631 \u06a9\u062f \u0628\u0627\u0644\u0627\u060c \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>v-model<\/code> \u0628\u0631\u0627\u06cc \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 <code>input<\/code> \u0648 <code>@submit<\/code> \u0628\u0631\u0627\u06cc \u06af\u0648\u0634 \u062f\u0627\u062f\u0646 \u0628\u0647 \u0641\u0631\u0645 \u0627\u0631\u0633\u0627\u0644\u06cc  \u0648\u0642\u062a\u06cc \u0641\u0631\u0645 \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u060c <code>createTodo<\/code> \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f \u0648 \u06cc\u06a9 todo \u062c\u062f\u06cc\u062f \u0631\u0627 \u062f\u0631 \u0622\u0631\u0627\u06cc\u0647 todos \u0648\u0627\u0631\u062f \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<pre><code class=\"hljs\">PASS  src\/App.spec.ts\n  \u2713 creates a todo (19ms)\n\nTest Suites: 1 passed, 1 total\nTests:       1 passed, 1 total\nSnapshots:   0 total\nTime:        1.185s, estimated 2s\nRan all test suites.\n\u2728  Done in 4.71s.\n<\/code><\/pre>\n<h2 id=\"conditionalrendering\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%86%d8%af%d8%b1_%d9%85%d8%b4%d8%b1%d9%88%d8%b7\"><\/span>\u0631\u0646\u062f\u0631 \u0645\u0634\u0631\u0648\u0637<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>VTU (Vue Test Utils) \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0631\u0646\u062f\u0631 \u06a9\u0631\u062f\u0646 \u0648 \u0627\u062b\u0628\u0627\u062a \u0648\u0636\u0639\u06cc\u062a \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc\u200c\u06a9\u0646\u062f \u062a\u0627 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u0634\u0648\u062f \u06a9\u0647 \u062f\u0631\u0633\u062a \u0631\u0641\u062a\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u062f.  \u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0631\u0648\u0634 \u0631\u0646\u062f\u0631 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0647\u0627 \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0631\u0648\u0634 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0645\u062d\u062a\u0648\u0627\u06cc \u0622\u0646\u0647\u0627 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u0631\u0646\u062f\u0631 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u06cc\u06a9\u06cc \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u06a9\u0644\u06cc\u062f\u06cc Vue\u060c \u062f\u0631\u062c\/\u062d\u0630\u0641 \u062f\u06cc\u0646\u0627\u0645\u06cc\u06a9 \u0639\u0646\u0627\u0635\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a <code>v-if<\/code>.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0647 \u0631\u0648\u0634 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u0648\u0644\u0641\u0647 \u0627\u06cc \u06a9\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0646\u06af\u0627\u0647 \u06a9\u0646\u06cc\u0645 <code>v-if<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> Nav = {\n  <span class=\"hljs-attr\">template<\/span>: <span class=\"hljs-string\">`\n  &lt;nav&gt;\n     &lt;a id=\"user-profile\" href=\"\/profile\"&gt;User Profile&lt;\/a&gt;\n     &lt;a v-if=\"subscribed\" id=\"subscribed\" href=\"\/dashboard\"&gt;User Dashboard&lt;\/a&gt;\n  &lt;\/nav&gt;\n    `<\/span>,\n\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">subscribed<\/span>: <span class=\"hljs-literal\">false<\/span>,\n    };\n  },\n};\n<\/code><\/pre>\n<p>\u062f\u0631 <code>&lt;Nav&gt;<\/code> \u062c\u0632\u0621 \u0628\u0627\u0644\u0627\u060c \u067e\u06cc\u0648\u0646\u062f\u06cc \u0628\u0647 \u0646\u0645\u0627\u06cc\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u062f\u0631 \u0647\u0645\u06cc\u0646 \u062d\u0627\u0644\u060c \u0627\u06af\u0631 <code>subscribed<\/code> \u0645\u0642\u062f\u0627\u0631 \u062f\u0631\u0633\u062a \u0627\u0633\u062a\u060c \u0645\u0627 \u067e\u06cc\u0648\u0646\u062f\u06cc \u0628\u0647 \u062f\u0627\u0634\u0628\u0648\u0631\u062f \u06a9\u0627\u0631\u0628\u0631 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0633\u0647 \u0633\u0646\u0627\u0631\u06cc\u0648 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u062f\u0631\u0633\u062a \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u0646\u062f:<\/p>\n<ul>\n<li>\u0631\u0627 <code>\/profile<\/code> \u0644\u06cc\u0646\u06a9 \u0628\u0627\u06cc\u062f \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0634\u0648\u062f<\/li>\n<li>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0645\u0634\u062a\u0631\u06a9 \u0627\u0633\u062a\u060c <code>\/dashboard<\/code> \u0644\u06cc\u0646\u06a9 \u0628\u0627\u06cc\u062f \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0634\u0648\u062f<\/li>\n<li>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0645\u0634\u062a\u0631\u06a9 \u0646\u06cc\u0633\u062a\u060c <code>\/dashboard<\/code> \u0644\u06cc\u0646\u06a9 \u0646\u0628\u0627\u06cc\u062f \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0634\u0648\u062f<\/li>\n<\/ul>\n<p>Vue Test Utils <code>wrapper<\/code> \u062f\u0627\u0631\u062f <code>get()<\/code> \u0631\u0648\u0634\u06cc \u06a9\u0647 \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0645\u0648\u062c\u0648\u062f \u0631\u0627 \u062c\u0633\u062a\u062c\u0648 \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f <code>querySelector<\/code> \u0646\u062d\u0648.  \u0645\u0627 \u0645\u062d\u062a\u0648\u0627\u06cc \u067e\u06cc\u0648\u0646\u062f \u062f\u0627\u0634\u0628\u0648\u0631\u062f \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0627\u062e\u062a\u0635\u0627\u0635 \u0645\u06cc \u062f\u0647\u06cc\u0645 <code>get()<\/code>:<\/p>\n<pre><code class=\"hljs\">test(<span class=\"hljs-string\">\"renders the user dashboard link\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> wrapper = mount(Nav);\n\n  <span class=\"hljs-keyword\">const<\/span> userProfileLink = wrapper.get(<span class=\"hljs-string\">\"#user-profile\"<\/span>);\n  expect(userProfileLink.text()).toEqual(<span class=\"hljs-string\">\"User Profile\"<\/span>);\n});\n<\/code><\/pre>\n<p>\u0634\u0627\u06cc\u062f \u0627\u06af\u0631 <code>get()<\/code> \u0645\u062a\u062f \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0645\u0646\u0637\u0628\u0642 \u0628\u0627 \u0627\u0646\u062a\u062e\u0627\u0628\u06af\u0631 \u0631\u0627 \u0628\u0631\u0646\u0645\u06cc\u200c\u06af\u0631\u062f\u0627\u0646\u062f\u060c \u06cc\u06a9 \u062e\u0637\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u062a\u0633\u062a \u0634\u0645\u0627 \u0646\u0627\u0645\u0648\u0641\u0642 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f.  \u0631\u0627 <code>get()<\/code> \u0631\u0648\u0634 a \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f <code>DOMWrapper<\/code> \u0627\u06af\u0631 \u0639\u0646\u0635\u0631\u06cc \u067e\u06cc\u062f\u0627 \u0634\u0648\u062f<\/p>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644 <code>get<\/code> \u0631\u0648\u0634 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f \u0631\u0648\u06cc \u0627\u06cc\u0646 \u0641\u0631\u0636 \u06a9\u0647 \u0639\u0646\u0627\u0635\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u0646\u062f \u0648 \u062f\u0631 \u0635\u0648\u0631\u062a \u0639\u062f\u0645 \u0648\u062c\u0648\u062f\u060c \u062e\u0637\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0627\u062b\u0628\u0627\u062a \u0648\u062c\u0648\u062f \u062a\u0648\u0635\u06cc\u0647 \u0646\u0645\u06cc \u0634\u0648\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c Vue Test Utils \u062f\u0631 \u0627\u062e\u062a\u06cc\u0627\u0631 \u0645\u0627 \u0642\u0631\u0627\u0631 \u0645\u06cc \u062f\u0647\u062f <code>find<\/code> \u0648 <code>exists<\/code> \u0645\u0648\u0627\u062f \u0648 \u0631\u0648\u0634 \u0647\u0627.  \u0622\u0632\u0645\u0648\u0646 \u0628\u0639\u062f\u06cc \u0628\u06cc\u0627\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0627\u06af\u0631 <code>subscribed<\/code> \u0646\u0627\u062f\u0631\u0633\u062a \u0627\u0633\u062a (\u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0686\u0646\u06cc\u0646 \u0627\u0633\u062a)\u060c \u067e\u06cc\u0648\u0646\u062f \u062f\u0627\u0634\u0628\u0648\u0631\u062f \u06a9\u0627\u0631\u0628\u0631 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0646\u06cc\u0633\u062a:<\/p>\n<pre><code class=\"hljs\">test(<span class=\"hljs-string\">\"does not render user dashboard link\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> wrapper = mount(Nav);\n\n  <span class=\"hljs-comment\">\/\/ Using `wrapper.get` would throw and make the test fail.<\/span>\n  expect(wrapper.find(<span class=\"hljs-string\">\"#subscribed\"<\/span>).exists()).toBe(<span class=\"hljs-literal\">false<\/span>);\n});\n<\/code><\/pre>\n<p>\u062f\u0631 \u062a\u0633\u062a \u0628\u0627\u0644\u0627\u060c \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u06a9\u0647 \u0645\u0627 \u0622\u0646 \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u06a9\u0631\u062f\u06cc\u0645 <code>exists()<\/code> \u0631\u0648\u0634 \u0631\u0648\u06cc \u0645\u0642\u062f\u0627\u0631 \u0628\u0627\u0632\u06af\u0634\u062a\u06cc \u0627\u0632 <code>.find()<\/code>.  \u0628\u0647 \u0627\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0627\u0633\u062a <code>find()<\/code>\u060c \u067e\u0633\u0646\u062f\u06cc\u062f\u0646 <code>mount()<\/code>\u060c \u0647\u0645\u0686\u0646\u06cc\u0646 a \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f <code>wrapper<\/code>.  \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0641\u0647\u0631\u0633\u062a\u06cc \u0627\u0632 \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0634\u062f\u0647 \u0628\u0631\u0627\u06cc \u0631\u0646\u062f\u0631 \u0634\u0631\u0637\u06cc \u0631\u0627 \u0628\u06cc\u0627\u0628\u06cc\u062f <a href=\"https:\/\/test-utils.vuejs.org\/guide\/essentials\/conditional-rendering.html#using-data\" target=\"_blank\" rel=\"noopener noreferrer\">\u0627\u06cc\u0646\u062c\u0627<\/a>.<\/p>\n<h2 id=\"howtotestemittedevents\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%88%d8%b4_%d8%aa%d8%b3%d8%aa_%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af%d9%87%d8%a7%db%8c_%d9%85%d9%86%d8%aa%d8%b4%d8%b1_%d8%b4%d8%af%d9%87\"><\/span>\u0631\u0648\u0634 \u062a\u0633\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 Vue\u060c \u0645\u0624\u0644\u0641\u0647\u200c\u0647\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 props \u0648 \u0628\u0627 \u0627\u0646\u062a\u0634\u0627\u0631 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0628\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0628\u0627 \u06cc\u06a9\u062f\u06cc\u06af\u0631 \u062a\u0639\u0627\u0645\u0644 \u062f\u0627\u0631\u0646\u062f <code>$emit<\/code>.  \u062d\u0627\u0644\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0631\u0648\u0634 \u062a\u0623\u06cc\u06cc\u062f \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0645\u0646\u062a\u0634\u0631 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f\u060c \u0628\u06cc\u0627\u0646\u062f\u0627\u0632\u06cc\u0645 <code>emitted()<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 Vue Test Utils.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u06cc\u0646 \u0633\u0627\u062f\u0647 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645 <code>Counter<\/code> \u062c\u0632\u0621 \u0632\u06cc\u0631  \u062f\u06a9\u0645\u0647 \u0627\u06cc \u062f\u0627\u0631\u062f \u06a9\u0647 \u0628\u0627 \u06a9\u0644\u06cc\u06a9 \u06a9\u0631\u062f\u0646 \u0631\u0648\u06cc \u0622\u0646\u060c \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u0634\u0645\u0627\u0631\u0634 \u062f\u0627\u062e\u0644\u06cc \u0631\u0627 \u0627\u0641\u0632\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f \u0648 \u0645\u0642\u062f\u0627\u0631 \u0622\u0646 \u0631\u0627 \u0645\u0646\u062a\u0634\u0631 \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> Counter = {\n  <span class=\"hljs-attr\">template<\/span>: <span class=\"hljs-string\">'&lt;button @click=\"handleClick\"&gt;Increment&lt;\/button&gt;'<\/span>,\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">count<\/span>: <span class=\"hljs-number\">0<\/span>,\n    };\n  },\n  <span class=\"hljs-attr\">methods<\/span>: {\n    <span class=\"hljs-function\"><span class=\"hljs-title\">handleClick<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-built_in\">this<\/span>.count += <span class=\"hljs-number\">1<\/span>;\n      <span class=\"hljs-built_in\">this<\/span>.$emit(<span class=\"hljs-string\">\"increment\"<\/span>, <span class=\"hljs-built_in\">this<\/span>.count);\n    },\n  },\n};\n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u062a\u0633\u062a \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0628\u0627\u0644\u0627\u060c \u0628\u0627\u06cc\u062f \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 an <code>increment<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0627 \u062c\u062f\u06cc\u062f\u062a\u0631\u06cc\u0646 <code>count<\/code> \u0627\u0631\u0632\u0634 \u0645\u0646\u062a\u0634\u0631 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0645\u0627 \u0648\u0627\u0628\u0633\u062a\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u0628\u0648\u062f \u0631\u0648\u06cc \u0631\u0627 <code>emitted()<\/code> \u0631\u0648\u0634.  \u06cc\u06a9 \u0634\u06cc \u0631\u0627 \u0628\u0627 \u062a\u0645\u0627\u0645 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0624\u0644\u0641\u0647 \u0633\u0627\u0637\u0639 \u06a9\u0631\u062f\u0647 \u0627\u0633\u062a \u0648 \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u0647\u0627\u06cc \u0622\u0646\u0647\u0627 \u062f\u0631 \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0631\u0648\u0634 \u0639\u0645\u0644\u06a9\u0631\u062f \u0622\u0646 \u0628\u06cc\u0646\u062f\u0627\u0632\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\">test(<span class=\"hljs-string\">\"emits an event when clicked\"<\/span>, <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> wrapper = mount(Counter);\n\n  wrapper.find(<span class=\"hljs-string\">\"button\"<\/span>).trigger(<span class=\"hljs-string\">\"click\"<\/span>);\n  wrapper.find(<span class=\"hljs-string\">\"button\"<\/span>).trigger(<span class=\"hljs-string\">\"click\"<\/span>);\n\n  expect(wrapper.emitted()).toHaveProperty(<span class=\"hljs-string\">\"increment\"<\/span>);\n});\n<\/code><\/pre>\n<p>\u062f\u0631 \u062a\u0633\u062a \u0628\u0627\u0644\u0627\u060c \u0627\u0648\u0644\u06cc\u0646 \u0686\u06cc\u0632\u06cc \u06a9\u0647 \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u0627\u06cc\u0646 \u0627\u0633\u062a <code>emitted()<\/code> \u06cc\u06a9 \u0634\u06cc \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0647\u0631 \u06a9\u0644\u06cc\u062f \u0628\u0627 \u06cc\u06a9 \u0631\u0648\u06cc\u062f\u0627\u062f \u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0627\u0631\u062f.  \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c <code>increment<\/code>.<\/p>\n<p>\u0627\u06cc\u0646 \u0622\u0632\u0645\u0648\u0646 \u0627\u0644\u0627\u0646 \u0628\u0627\u06cc\u062f \u0642\u0628\u0648\u0644 \u0628\u0634\u0647  \u0645\u0627 \u0645\u0637\u0645\u0626\u0646 \u0634\u062f\u06cc\u0645 \u06a9\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f\u06cc \u0631\u0627 \u0628\u0627 \u0646\u0627\u0645 \u0635\u062d\u06cc\u062d \u0645\u0646\u062a\u0634\u0631 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645.  \u0627\u06af\u0631 \u0646\u062f\u06cc\u062f\u0647 \u0627\u06cc\u062f <code>trigger()<\/code> \u0631\u0648\u0634 \u0642\u0628\u0644\u060c \u0646\u06af\u0631\u0627\u0646 \u0646\u0628\u0627\u0634\u06cc\u062f.  \u0628\u0631\u0627\u06cc \u0634\u0628\u06cc\u0647 \u0633\u0627\u0632\u06cc \u062a\u0639\u0627\u0645\u0644 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062f\u0631 \u0645\u0648\u0631\u062f \u0627\u062f\u0639\u0627\u06cc \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0628\u06cc\u0627\u0645\u0648\u0632\u06cc\u062f <a href=\"https:\/\/test-utils.vuejs.org\/guide\/essentials\/event-handling.html#asserting-complex-events\" target=\"_blank\" rel=\"noopener noreferrer\">\u0627\u06cc\u0646\u062c\u0627<\/a>.<\/p>\n<h2 id=\"howtotestforms\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%88%d8%b4_%d8%aa%d8%b3%d8%aa_%d9%81%d8%b1%d9%85_%d9%87%d8%a7\"><\/span>\u0631\u0648\u0634 \u062a\u0633\u062a \u0641\u0631\u0645 \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0628\u062e\u0634\u060c \u0631\u0627\u0647\u200c\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u062a\u0639\u0627\u0645\u0644 \u0628\u0627 \u0639\u0646\u0627\u0635\u0631 \u0641\u0631\u0645\u060c \u062a\u0646\u0638\u06cc\u0645 \u0645\u0642\u0627\u062f\u06cc\u0631 \u0648 \u0631\u0627\u0647\u200c\u0627\u0646\u062f\u0627\u0632\u06cc \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0627\u06cc\u0646 \u0641\u0631\u0645 \u0627\u0635\u0644\u06cc \u062f\u0631 \u0632\u06cc\u0631 \u0628\u06cc\u0627\u0646\u062f\u0627\u0632\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\">&lt;template&gt;\n  <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"email\"<\/span> <span class=\"hljs-attr\">v-model<\/span>=<span class=\"hljs-string\">\"email\"<\/span> \/&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> @<span class=\"hljs-attr\">click<\/span>=<span class=\"hljs-string\">\"submit\"<\/span>&gt;<\/span>Submit<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n&lt;\/template&gt;\n\n<span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">email<\/span>: <span class=\"hljs-string\">\"\"<\/span>,\n    };\n  },\n  <span class=\"hljs-attr\">methods<\/span>: {\n    <span class=\"hljs-function\"><span class=\"hljs-title\">submit<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-built_in\">this<\/span>.$emit(<span class=\"hljs-string\">\"submit\"<\/span>, <span class=\"hljs-built_in\">this<\/span>.email);\n    },\n  },\n};\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span><\/span>\n<\/code><\/pre>\n<p>\u06cc\u06a9\u06cc \u0627\u0632 \u0631\u0627\u06cc\u062c\u200c\u062a\u0631\u06cc\u0646 \u0631\u0627\u0647\u200c\u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u062a\u0635\u0627\u0644 \u0648 \u0648\u0631\u0648\u062f\u06cc \u062f\u0627\u062f\u0647 \u062f\u0631 Vue \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a <code>v-model<\/code>.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0628\u0631\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0642\u062f\u0627\u0631 \u0648\u0631\u0648\u062f\u06cc \u062f\u0631 VTU\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 <code>setValue<\/code> \u0631\u0648\u0634.  \u06cc\u06a9 \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0631\u0627 \u0645\u06cc \u067e\u0630\u06cc\u0631\u062f\u060c \u0627\u063a\u0644\u0628 a <code>string<\/code> \u06cc\u0627 <code>boolean<\/code>\u060c \u0648 a \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f <code>promise<\/code>\u060c \u06a9\u0647 \u067e\u0633 \u0627\u0632 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc Vue DOM \u0628\u0631\u0637\u0631\u0641 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<pre><code class=\"hljs\">test(<span class=\"hljs-string\">\"sets the value\"<\/span>, <span class=\"hljs-keyword\">async<\/span> () =&gt; {\n  <span class=\"hljs-keyword\">const<\/span> wrapper = mount(Component);\n  <span class=\"hljs-keyword\">const<\/span> input = wrapper.find(<span class=\"hljs-string\">\"input\"<\/span>);\n\n  <span class=\"hljs-keyword\">await<\/span> input.setValue(<span class=\"hljs-string\">\"(email\u00a0protected)\"<\/span>);\n\n  expect(input.element.value).toBe(<span class=\"hljs-string\">\"(email\u00a0protected)\"<\/span>);\n});\n<\/code><\/pre>\n<p>\u062f\u0631 \u062a\u0633\u062a \u0628\u0627\u0644\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0628\u06cc\u0646\u06cc\u062f <code>setValue<\/code> \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u062f <code>value<\/code> \u0648\u06cc\u0698\u06af\u06cc \u0631\u0648\u06cc \u0639\u0646\u0627\u0635\u0631 \u0648\u0631\u0648\u062f\u06cc \u0628\u0647 \u0622\u0646\u0686\u0647 \u0628\u0647 \u0622\u0646 \u0645\u0646\u062a\u0642\u0644 \u0645\u06cc \u06a9\u0646\u06cc\u0645.  \u0645\u0627 \u0627\u0632 \u0627\u0646\u062a\u0638\u0627\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u0645 \u06a9\u0647 Vue \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0631\u0627 \u06a9\u0627\u0645\u0644 \u06a9\u0631\u062f\u0647 \u0648 \u0627\u06cc\u0646 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0631 DOM \u0645\u0646\u0639\u06a9\u0633 \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0642\u0628\u0644 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0627\u062f\u0639\u0627\u06cc\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645.<\/p>\n<p>\u0647\u0646\u06af\u0627\u0645 \u06a9\u0627\u0631 \u0628\u0627 \u0641\u0631\u0645 \u0647\u0627 \u0648 \u0639\u0646\u0627\u0635\u0631 \u0627\u06a9\u0634\u0646\u060c \u062a\u062d\u0631\u06cc\u06a9 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u062f\u0648\u0645\u06cc\u0646 \u0627\u0642\u062f\u0627\u0645 \u0645\u0647\u0645 \u0627\u0633\u062a.  \u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0648\u0636\u0639\u06cc\u062a \u062e\u0648\u062f \u0628\u06cc\u0627\u0646\u062f\u0627\u0632\u06cc\u0645 <code>button<\/code> \u0627\u0632 \u0645\u062b\u0627\u0644 \u0642\u0628\u0644\u06cc<\/p>\n<pre><code class=\"hljs\">&lt;button @click=<span class=\"hljs-string\">\"submit\"<\/span>&gt;Submit&lt;\/button&gt;\n<\/code><\/pre>\n<p>\u0628\u0647 \u0645\u0646\u0638\u0648\u0631 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06cc\u06a9 \u0631\u0648\u06cc\u062f\u0627\u062f \u06a9\u0644\u06cc\u06a9\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>trigger()<\/code> \u0631\u0648\u0634.<\/p>\n<pre><code class=\"hljs\">test(<span class=\"hljs-string\">\"trigger\"<\/span>, <span class=\"hljs-keyword\">async<\/span> () =&gt; {\n  <span class=\"hljs-keyword\">const<\/span> wrapper = mount(Component);\n\n  <span class=\"hljs-comment\">\/\/ Trigger the element<\/span>\n  <span class=\"hljs-keyword\">await<\/span> wrapper.find(<span class=\"hljs-string\">\"button\"<\/span>).trigger(<span class=\"hljs-string\">\"click\"<\/span>);\n\n  <span class=\"hljs-comment\">\/\/ Assert some action has been performed, like an emitted event.<\/span>\n  expect(wrapper.emitted()).toHaveProperty(<span class=\"hljs-string\">\"submit\"<\/span>);\n});\n<\/code><\/pre>\n<p>\u062f\u0631 \u062a\u0633\u062a \u0628\u0627\u0644\u0627\u060c \u0645\u0627 \u0631\u0627 \u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>click<\/code> \u0634\u0646\u0648\u0646\u062f\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0647 \u0637\u0648\u0631\u06cc \u06a9\u0647 \u062c\u0632\u0621 \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f <code>submit<\/code> \u0631\u0648\u0634.  \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0645\u0627 \u0628\u0627 <code>setValue<\/code>\u060c \u0645\u0627 \u0627\u0632 await \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u0645 \u06a9\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u062a\u0648\u0633\u0637 Vue \u0645\u0646\u0639\u06a9\u0633 \u0645\u06cc \u0634\u0648\u062f.  \u0633\u067e\u0633 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u062f\u0639\u0627 \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0631\u062e \u062f\u0627\u062f\u0647 \u0627\u0633\u062a.  \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c \u0645\u0627 \u0631\u0648\u06cc\u062f\u0627\u062f \u062f\u0631\u0633\u062a \u0631\u0627 \u0645\u0646\u062a\u0634\u0631 \u06a9\u0631\u062f\u06cc\u0645.<\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u06cc\u0646 \u062f\u0648 \u0631\u0627 \u062a\u0631\u06a9\u06cc\u0628 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0622\u06cc\u0627 \u0641\u0631\u0645 \u0633\u0627\u062f\u0647 \u0645\u0627 \u0648\u0631\u0648\u062f\u06cc \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0645\u0646\u062a\u0634\u0631 \u0645\u06cc \u06a9\u0646\u062f \u06cc\u0627 \u062e\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\">test(<span class=\"hljs-string\">\"emits the input to its parent\"<\/span>, <span class=\"hljs-keyword\">async<\/span> () =&gt; {\n  <span class=\"hljs-keyword\">const<\/span> wrapper = mount(Component);\n\n  <span class=\"hljs-comment\">\/\/ Set the value<\/span>\n  <span class=\"hljs-keyword\">await<\/span> wrapper.find(<span class=\"hljs-string\">\"input\"<\/span>).setValue(<span class=\"hljs-string\">\"(email\u00a0protected)\"<\/span>);\n\n  <span class=\"hljs-comment\">\/\/ Trigger the element<\/span>\n  <span class=\"hljs-keyword\">await<\/span> wrapper.find(<span class=\"hljs-string\">\"button\"<\/span>).trigger(<span class=\"hljs-string\">\"click\"<\/span>);\n\n  <span class=\"hljs-comment\">\/\/ Assert the `submit` event is emitted,<\/span>\n  expect(wrapper.emitted(<span class=\"hljs-string\">\"submit\"<\/span>)(<span class=\"hljs-number\">0<\/span>)(<span class=\"hljs-number\">0<\/span>)).toBe(<span class=\"hljs-string\">\"(email\u00a0protected)\"<\/span>);\n});\n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u06a9\u0633\u0628 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0634\u0646\u0648\u0646\u062f\u06af\u0627\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0648 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0627\u062c\u0632\u0627\u06cc \u0648\u0631\u0648\u062f\u06cc \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0628\u0627 VTU\u060c \u0628\u06cc\u0634\u062a\u0631 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f <a href=\"https:\/\/test-utils.vuejs.org\/guide\/essentials\/forms.html#triggering-events\" target=\"_blank\" rel=\"noopener noreferrer\">\u0627\u06cc\u0646\u062c\u0627<\/a>.<\/p>\n<p>Vue Test Utils \u0628\u0647 \u0634\u0645\u0627 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0628\u0631\u0627\u06cc \u0627\u062c\u0632\u0627\u06cc Vue \u062a\u0633\u062a \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f.  \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0641\u0642\u0637 VTU \u06a9\u0627\u0631\u0647\u0627\u06cc \u0632\u06cc\u0627\u062f\u06cc \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u062f.  \u0634\u0645\u0627 \u0628\u0627\u06cc\u062f \u0647\u0645\u06cc\u0634\u0647 \u06a9\u062f\u06cc \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f \u06a9\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0622\u0646 \u0622\u0633\u0627\u0646 \u062a\u0631 \u0628\u0627\u0634\u062f \u0648 \u062a\u0633\u062a \u0647\u0627\u06cc\u06cc \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f \u06a9\u0647 \u0645\u0639\u0646\u06cc \u062f\u0627\u0631 \u0648 \u0646\u06af\u0647\u062f\u0627\u0631\u06cc \u0622\u0646 \u0633\u0627\u062f\u0647 \u0628\u0627\u0634\u062f.  \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627 \u0631\u0627 \u062f\u0646\u0628\u0627\u0644 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0686\u06af\u0648\u0646\u0647 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0647\u0627\u06cc\u06cc \u0628\u0646\u0648\u06cc\u0633\u06cc\u0645 \u06a9\u0647 \u062a\u0633\u062a \u0622\u0646 \u0622\u0633\u0627\u0646 \u0628\u0627\u0634\u062f:<\/p>\n<p><strong>\u062c\u0632\u0626\u06cc\u0627\u062a \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0646\u06a9\u0646\u06cc\u062f<\/strong>: \u0647\u0645\u06cc\u0634\u0647 \u0628\u0647 \u0648\u0631\u0648\u062f\u06cc \u0647\u0627 \u0648 \u062e\u0631\u0648\u062c\u06cc \u0647\u0627 \u0627\u0632 \u062f\u06cc\u062f\u06af\u0627\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0641\u06a9\u0631 \u06a9\u0646\u06cc\u062f.  \u0648\u0631\u0648\u062f\u06cc \u0647\u0627 \u2013 \u0645\u0627\u0646\u0646\u062f \u062a\u0639\u0627\u0645\u0644\u060c \u067e\u0631\u0648\u067e\u0648\u0632\u0627\u0644 \u0647\u0627\u060c \u062c\u0631\u06cc\u0627\u0646 \u0647\u0627\u06cc \u062f\u0627\u062f\u0647\u060c \u0648 \u062e\u0631\u0648\u062c\u06cc \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f \u2013 \u0639\u0646\u0627\u0635\u0631 DOM\u060c \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0648 \u0639\u0648\u0627\u0631\u0636 \u062c\u0627\u0646\u0628\u06cc.<\/p>\n<p><strong>\u0627\u062c\u0632\u0627\u06cc \u06a9\u0648\u0686\u06a9\u062a\u0631 \u0648 \u0633\u0627\u062f\u0647 \u062a\u0631 \u0628\u0633\u0627\u0632\u06cc\u062f<\/strong>: \u06cc\u06a9 \u0642\u0627\u0646\u0648\u0646 \u06a9\u0644\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0627\u06af\u0631 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u06a9\u0645\u062a\u0631\u06cc \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u062f\u060c \u062a\u0633\u062a \u0622\u0646 \u0622\u0633\u0627\u0646\u062a\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f.  \u0633\u0627\u062e\u062a\u0646 \u0627\u062c\u0632\u0627\u06cc \u06a9\u0648\u0686\u06a9\u200c\u062a\u0631 \u0628\u0627\u0639\u062b \u0645\u06cc\u200c\u0634\u0648\u062f \u06a9\u0647 \u062a\u0631\u06a9\u06cc\u0628\u200c\u067e\u0630\u06cc\u0631\u062a\u0631 \u0648 \u062f\u0631\u06a9 \u0622\u0646\u200c\u0647\u0627 \u0622\u0633\u0627\u0646\u200c\u062a\u0631 \u0634\u0648\u062f.<\/p>\n<p>\u0642\u0628\u0644 \u0627\u0632 \u0646\u0648\u0634\u062a\u0646 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a\u060c \u062a\u0633\u062a \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f: \u0627\u06af\u0631 \u0627\u0632 \u0642\u0628\u0644 \u062a\u0633\u062a \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f\u060c \u0646\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06a9\u062f \u063a\u06cc\u0631 \u0642\u0627\u0628\u0644 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f.  \u0627\u06cc\u0646 \u06cc\u06a9\u06cc \u0627\u0632 \u0645\u0632\u0627\u06cc\u0627\u06cc \u0628\u0632\u0631\u06af \u0646\u0648\u0634\u062a\u0646 \u062a\u0633\u062a \u0642\u0628\u0644 \u0627\u0632 \u0646\u0648\u0634\u062a\u0646 \u0627\u062c\u0632\u0627\u0633\u062a.<\/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>\u0627\u0645\u06cc\u062f\u0648\u0627\u0631\u0645 \u0627\u0632 \u062e\u0648\u0627\u0646\u062f\u0646 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0644\u0630\u062a \u0628\u0631\u062f\u0647 \u0628\u0627\u0634\u06cc\u062f.  \u0645\u0627 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u062a\u0633\u062a Vue \u0631\u0627 \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0627\u0635 \u0628\u0631\u0627\u06cc Vue3 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0628\u0631\u0631\u0633\u06cc \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645.  \u0645\u0627 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u0648\u0627\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue Test Utils \u0631\u0627 \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u0624\u0644\u0641\u0647\u200c\u0647\u0627\u06cc Vue \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u06cc\u0645 \u0648 \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0631\u0648\u0634 \u0631\u0627\u0647\u200c\u0627\u0646\u062f\u0627\u0632\u06cc \u06cc\u06a9 \u0645\u062d\u06cc\u0637 \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0628\u0627 VTU\u060c \u0631\u0648\u0634 \u0627\u0646\u062c\u0627\u0645 \u0631\u0646\u062f\u0631 \u0634\u0631\u0637\u06cc \u0648 \u0631\u0648\u0634 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u0648 \u0639\u0646\u0627\u0635\u0631 \u0634\u06a9\u0644 \u0627\u0646\u062f\u0627\u062e\u062a\u06cc\u0645.<\/p>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-04 13:48: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;14241&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 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0647\u0627\u06cc Vue.js \u0628\u0627 Vue Test UtilsSoftware \u062a\u0633\u062a \u0627\u0633\u062a process \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u0648 \u062a\u0623\u06cc\u06cc\u062f \u0627\u06cc\u0646\u06a9\u0647 \u06cc\u06a9 \u0645\u062d\u0635\u0648\u0644 \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631\u06cc \u0628\u0627 \u0645\u0648\u0641\u0642\u06cc\u062a \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0648\u0638\u0627\u06cc\u0641 \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u062e\u0648\u062f \u0631\u0627 \u0628\u062f\u0648\u0646 \u0647\u06cc\u0686 \u062e\u0637\u0627\u06cc\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f.  \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0628\u0631\u062e\u06cc \u0627\u0632 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u062a\u0644\u0627\u0641 \u0648\u0642\u062a \u0628\u0647 \u0646\u0638\u0631 \u0628\u0631\u0633\u062f\u060c \u0627\u0645\u0627 \u0645\u0647\u0645 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u06cc\u0627 \u0627\u062c\u0632\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u062f \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f ...&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\"> 9<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u062a\u0633\u062a \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0627\u0633\u062a process \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u0648 \u062a\u0623\u06cc\u06cc\u062f \u0627\u06cc\u0646\u06a9\u0647 \u06cc\u06a9 \u0645\u062d\u0635\u0648\u0644 \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631\u06cc \u0628\u0627 \u0645\u0648\u0641\u0642\u06cc\u062a \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0648\u0638\u0627\u06cc\u0641 \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u062e\u0648\u062f \u0631\u0627 \u0628\u062f\u0648\u0646 \u0647\u06cc\u0686 \u062e\u0637\u0627\u06cc\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f. \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0628\u0631\u062e\u06cc \u0627\u0632 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u062a\u0644\u0627\u0641 \u0648\u0642\u062a \u0628\u0647 \u0646\u0638\u0631 \u0628\u0631\u0633\u062f\u060c \u0627\u0645\u0627 \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u062e\u0648\u0628 \u0628\u0633\u0627\u0632\u06cc\u062f\u060c \u0645\u0647\u0645 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":9056,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[3292,1843,2595,3295,3296,3294,3306,2508,1964,1840,3308,2303,3311,3297,1776,1811,3301,2433,1817,3305,2140,1779,2327,1814,3307,2796,1909,1965,1807,3298,639,1881,1103,3304,2301,1802,2179,1882,1803,2264,3293,1806,1795,3299,1810,3310,1783,3302,1790,3300,2795,2322,2375,2323,1785,2166,3303,3309,1831,1813],"class_list":["post-14241","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming","tag-vue","tag-nodejs-hosting","tag-process","tag-test","tag-utilssoftware","tag-vue-js","tag-3306","tag--javascript","tag----frontend","tag-1840","tag-3308","tag-2303","tag-3311","tag-3297","tag-1776","tag-1811","tag-3301","tag-2433","tag-1817","tag-3305","tag-2140","tag-1779","tag-2327","tag-1814","tag-3307","tag-2796","tag-1909","tag-1965","tag-1807","tag-3298","tag-639","tag-1881","tag-1103","tag-3304","tag-2301","tag-1802","tag-2179","tag-1882","tag-1803","tag-2264","tag-3293","tag-1806","tag-1795","tag-3299","tag-1810","tag-3310","tag-1783","tag-3302","tag-1790","tag-3300","tag-2795","tag-2322","tag-2375","tag--node","tag-1785","tag-2166","tag-3303","tag-3309","tag-1831","tag-1813"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/14241","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=14241"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/14241\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/9056"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=14241"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=14241"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=14241"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}