
यैंडेक्स के वॉयस असिस्टेंट एलिस के लिए अपना कौशल बनाने के अवसर को लगभग एक साल बीत चुका है। कैटलॉग में नए कौशल रोज़ आते हैं, और उनकी कुल संख्या कई सौ है। दुर्भाग्य से, इसे हल्के ढंग से डालने के लिए कुछ कौशल के साथ संचार "जोड़ नहीं करता है।" कौशल या तो एक ही वाक्यांश पर लूप करता है या आमतौर पर टूट जाता है और प्रतिक्रिया नहीं करता है।
इस लेख में, मैं Node.js. पर कौशल के लिए कार्यात्मक स्वचालित परीक्षण लिखने पर विचार करूंगा। ऐसे परीक्षणों की उपस्थिति आपको बेहतर कौशल बनाने की अनुमति देती है और उनके प्रदर्शन में आत्मविश्वास देती है।
मौजूदा परीक्षण उपकरण
ऐलिस के लिए कौशल एक वेब सर्वर है जो एक विशिष्ट प्रारूप में POST अनुरोधों का जवाब दे सकता है। फिलहाल, कई उपकरण हैं जहाँ आप कौशल URL को स्थानांतरित कर सकते हैं और इसके संचालन की जाँच कर सकते हैं:
- आधिकारिक डेवलपर कंसोल , जहां आप पाठ के साथ कौशल का परीक्षण कर सकते हैं और अनुरोध / उत्तर देख सकते हैं
- Aimylogic स्टेशन सिम्युलेटर, आवाज का समर्थन करता है
- कौशल के स्थानीय परीक्षण के लिए ओपन-सोर्स प्रोजेक्ट डायलॉग .popstas.ru
इन उपकरणों की ख़ासियत यह है कि वे मैनुअल कौशल परीक्षण के लिए कुछ यूआई प्रदान करते हैं। मैं निरंतर एकीकरण की सर्वश्रेष्ठ परंपराओं में चाहता हूं
कंसोल में कमांड चलाएँ, स्वचालित रूप से सभी लिपियों की जांच करें और उसके बाद ही नया संस्करण अपलोड करें।
उसी समय, मैं व्यक्तिगत कौशल मॉड्यूल की इकाई परीक्षण में तल्लीन नहीं करना चाहता। अनुरोध / प्रतिक्रिया प्रोटोकॉल प्रलेखन में दर्ज किया गया है , और यह इस स्तर पर है कि परीक्षण करना बेहतर है। फिर, आंतरिक वास्तुकला को पूरी तरह से फिर से लिखने के बाद भी, आपको परीक्षणों को बदलना नहीं होगा। यही है, संक्षेप में, ये कार्यात्मक परीक्षण हैं।
मुझे इस तरह के कार्य के लिए Node.js के लिए एक तैयार पुस्तकालय नहीं मिला, इसलिए हम अपना खुद का लिखेंगे :)
कौशल का परीक्षण करें
GitHub पर Yandex रिपॉजिटरी से आधिकारिक कौशल उदाहरण लें। यह कौशल "तोता" है, जो उपयोगकर्ता द्वारा कही गई हर बात को दोहराता है। माइक्रो फ्रेमवर्क के आधार पर निर्मित और इसमें कोड की केवल कुछ पंक्तियाँ होती हैं:
पहली कॉल पर, कौशल को उपयोगकर्ता (मूल_अभियोजन) से एक रिक्त संदेश प्राप्त होगा और "Hello!" । अन्य मामलों में, यह केवल उपयोगकर्ता के संदेश को response.text फ़ील्ड में कॉपी करता है।
मैंने micro() फ़ंक्शन में मूल GitHub उदाहरण कोड को लपेटा ताकि निर्यात एक http सर्वर लौटाए, जिसे हम परीक्षणों में उपयोग करेंगे।
टेस्ट प्लान
तो, इस तरह के कौशल को परीक्षणों के साथ कवर करने के लिए, आपको निम्नलिखित की आवश्यकता है:
- स्थानीय पोर्ट पर कौशल के साथ एक सर्वर उठाएँ
- दो मामलों की जाँच करें:
 - उपयोगकर्ता कौशल में प्रवेश करता है, कौशल को "हैलो!"
- उपयोगकर्ता कौशल के लिए एक संदेश भेजता है, कौशल को उसी संदेश के साथ जवाब देना चाहिए
 
- कौशल और शो रिपोर्ट के साथ सर्वर बंद करो
इन जांचों को स्वचालित करके, आप उन्हें प्रत्येक कमिट से पहले चला सकते हैं और सुनिश्चित करें कि कुछ भी टूटा हुआ नहीं है।
हम योजना के अनुसार परीक्षण कोड लिखेंगे, मोचा के लिए वाक्यविन्यास का उपयोग करते हुए। मान लें कि हमारे पास पहले से ही कुछ User वर्ग हैं जो हमारी ज़रूरत के अनुसार सब कुछ कर सकते हैं:
 
यह User वर्ग लिखने के लिए रहता है और परीक्षण चलाना संभव होगा।
आभासी उपयोगकर्ता
मुख्य बात जो एक परीक्षण उपयोगकर्ता को करने में सक्षम होना चाहिए, वांछित प्रारूप में डेटा के साथ कौशल url के लिए POST अनुरोध भेजना है। अनुरोध प्रारूप प्रलेखन में वर्णित है । अब हमें सभी क्षेत्रों की आवश्यकता नहीं है, इसलिए मैंने केवल आवश्यक छोड़ दिया ताकि उदाहरण कोड को न बढ़ाया जाए। टिप्पणियों के साथ User वर्ग:
 
लांच
शुरू करने के लिए, यह उपयोगकर्ता और सर्वर कक्षाओं को परीक्षण फ़ाइल में आयात करने के लिए बना रहता है, और उस पोर्ट का मूल्य भी निर्धारित करता है जिस पर सर्वर बढ़ेगा:
 
सभी आवश्यक निर्भरताएं स्थापित करें:
 npm install micro node-fetch mocha 
और परीक्षण चलाएं:
 $ mocha test.js ✓ should get hello on enter 1 passing (34ms) 
सब ठीक है, परीक्षा पास हो गई!
लेकिन आगे बढ़ने से पहले, आपको यह सुनिश्चित करने की ज़रूरत है कि परीक्षण वास्तव में काम करता है। ऐसा करने के लिए, प्रतिक्रिया कौशल को "हैलो!" "नमस्ते!" और इसे फिर से चलाएं:
 $ mocha test.js 0 passing (487ms) 1 failing 1) should get hello on enter: AssertionError [ERR_ASSERTION]: '!' == 'Hello!' + expected - actual -! +Hello! 
परीक्षण में एक त्रुटि दिखाई दी - जैसा कि यह होना चाहिए।
अब हमें लगता है कि पहला मामला कवर किया गया है।
हम उपयोगकर्ता को संवाद करना सिखाते हैं
दूसरा मामला तब रहता है जब उपयोगकर्ता कौशल के लिए एक संदेश भेजता है और उसी संदेश को वापस प्राप्त करना चाहिए। ताकि उपयोगकर्ता "संवाद" कर सके, मैंने User वर्ग में say(message) विधि जोड़ दी। मैंने थोड़ा रिफैक्टिंग भी किया: मैंने http- रिक्वेस्ट को एक अलग तरीके से भेजा और इसे enter() अंदर इस्तेमाल किया enter() और say(message) :
 
दूसरे मामले का परीक्षण कोड इस तरह दिखता है:
 it('should reply the same message', async () => {  
हम फिर से शुरू करते हैं, और हम देखते हैं कि दोनों परीक्षण बीत चुके हैं:
 $ mocha test.js ✓ should get hello on enter ✓ should reply the same message 2 passing (37ms) 
आगे के कदम
उसी तरह, आप कौशल के लिए और अधिक जटिल स्क्रिप्ट जोड़ सकते हैं, उन्हें परीक्षणों के साथ कवर कर सकते हैं। यह सुनिश्चित करेगा कि नए परिवर्तन पुराने को न तोड़ें।
निर्मित परीक्षण बुनियादी ढांचे में भी सुधार किया जा सकता है:
- Userवर्ग को संशोधित करें ताकि अनुरोध में शेष फ़ील्ड को बदला जा सके (उदाहरण के लिए, उस बॉक्स को चेक करें जिसे उपयोगकर्ता के पास स्क्रीन नहीं है)
- कनेक्ट कोड-कवरेज (उदा। nyc )
- प्री-कमिट / प्री-पुश हुक (जैसे हस्की का उपयोग करके) पर सभी चेक लटकाएं
मेरे पास कई कौशल हैं, इसलिए मैंने परीक्षण उपयोगकर्ता वर्ग को एक अलग एलिस-टेस्टर पैकेज में रखा, शायद कोई काम आएगा।
मैंने GitHub पर लेख से उदाहरण का पूर्ण कार्य कोड भी पोस्ट किया । आप रिपॉजिटरी और प्रयोग को क्लोन कर सकते हैं।
आपका ध्यान के लिए धन्यवाद!