परीक्षण और गुणवत्ता आश्वासन
सॉफ्टवेयर प्रणाली को प्रयासों, समय और लागत अधिकता के दोहराव से बचने और निर्धारित समय के भीतर सिस्टम को पूरा करने का आश्वासन देने के लिए प्रत्येक विकास चरण पर इसके इच्छित व्यवहार और प्रगति की दिशा के लिए जाँच करने की आवश्यकता है। सॉफ्टवेयर सिस्टम को इसके लिए जाँचने की आवश्यकता है प्रयासों, समय और लागत अधिकता के दोहराव से बचने के लिए और निर्धारित समय के भीतर प्रणाली को पूरा करने का आश्वासन देने के लिए प्रत्येक विकास के स्तर पर प्रगति का उद्देश्य और दिशा।
सिस्टम की जाँच के लिए सिस्टम परीक्षण और गुणवत्ता आश्वासन सहायता के लिए आते हैं। इसमें शामिल हैं -
- उत्पाद स्तर की गुणवत्ता (परीक्षण)
- प्रक्रिया स्तर की गुणवत्ता।
आइए हम उनके बारे में संक्षेप में जाने -
परिक्षण
परीक्षण प्रक्रिया या गतिविधि है जो सिस्टम की गुणवत्ता और विश्वसनीयता में सुधार करने के लिए निर्दिष्ट उपयोगकर्ता आवश्यकताओं के अनुसार सॉफ्टवेयर की कार्यक्षमता और शुद्धता की जांच करता है। यह प्रणाली के विकास में एक महंगा, समय लेने वाला और महत्वपूर्ण दृष्टिकोण है, जिसके लिए समग्र परीक्षण प्रक्रिया की उचित योजना की आवश्यकता होती है।
एक सफल परीक्षण वह है जो त्रुटियों का पता लगाता है। यह प्रोग्राम को त्रुटि खोजने के स्पष्ट इरादे के साथ निष्पादित करता है, अर्थात, प्रोग्राम को विफल बनाता है। यह एक मजबूत प्रणाली बनाने के इरादे से प्रणाली के मूल्यांकन की एक प्रक्रिया है और मुख्य रूप से सिस्टम या सॉफ्टवेयर के कमजोर क्षेत्रों पर केंद्रित है।
सिस्टम परीक्षण के लक्षण
सिस्टम परीक्षण मॉड्यूल स्तर पर शुरू होता है और पूरे सॉफ्टवेयर सिस्टम के एकीकरण की ओर बढ़ता है। सिस्टम का परीक्षण करते समय विभिन्न परीक्षण तकनीकों का उपयोग अलग-अलग समय पर किया जाता है। यह छोटी परियोजनाओं के लिए डेवलपर और बड़ी परियोजनाओं के लिए स्वतंत्र परीक्षण समूहों द्वारा संचालित किया जाता है।
सिस्टम परीक्षण के चरण
निम्नलिखित चरण परीक्षण में शामिल हैं -
Test Strategy
यह एक बयान है जो सिस्टम के परीक्षण के लिए उपयोग किए जाने वाले विभिन्न स्तरों, विधियों, उपकरणों और तकनीकों के बारे में जानकारी प्रदान करता है। यह एक संगठन की सभी जरूरतों को पूरा करना चाहिए।
Test Plan
यह प्रणाली के परीक्षण के लिए एक योजना प्रदान करता है और पुष्टि करता है कि परीक्षण के तहत प्रणाली सभी डिजाइन और कार्यात्मक विनिर्देशों को पूरा करती है। परीक्षण योजना निम्नलिखित जानकारी प्रदान करती है -
- प्रत्येक परीक्षण चरण के उद्देश्य
- परीक्षण के लिए उपयोग किए गए दृष्टिकोण और उपकरण
- प्रत्येक परीक्षण गतिविधि के लिए जिम्मेदारियां और समय आवश्यक है
- उपकरण, सुविधाओं और परीक्षण पुस्तकालयों की उपलब्धता
- परीक्षणों की योजना और संचालन के लिए आवश्यक प्रक्रियाएं और मानक
- परीक्षण प्रक्रिया के सफल समापन के लिए जिम्मेदार कारक
Test Case Design
परीक्षण किए जाने वाले सिस्टम के प्रत्येक मॉड्यूल के लिए कई परीक्षण मामलों की पहचान की जाती है।
प्रत्येक परीक्षण मामले में यह निर्दिष्ट किया जाएगा कि किसी विशेष आवश्यकता या डिजाइन निर्णय के कार्यान्वयन का परीक्षण कैसे किया जाए और परीक्षण की सफलता के लिए मानदंड।
परीक्षण योजना के साथ परीक्षण के मामलों को एक सिस्टम विनिर्देश दस्तावेज़ के भाग के रूप में या एक अलग दस्तावेज़ में बुलाया जाता है test specification या test description।
Test Procedures
इसमें उन चरणों को शामिल किया गया है जिन्हें परीक्षण के प्रत्येक मामलों को निष्पादित करने के लिए पालन किया जाना चाहिए। इन प्रक्रियाओं को एक अलग दस्तावेज़ में निर्दिष्ट किया जाता है जिसे परीक्षण प्रक्रिया विनिर्देश कहा जाता है। यह दस्तावेज़ परीक्षण के परिणाम की रिपोर्ट करने के लिए किसी विशेष आवश्यकता और प्रारूप को भी निर्दिष्ट करता है।
Test Result Documentation
परीक्षण परिणाम फ़ाइल में निष्पादित मामलों की कुल संख्या, त्रुटियों की संख्या और त्रुटियों की प्रकृति के बारे में संक्षिप्त जानकारी है। परीक्षण के समग्र परिणाम का निर्धारण करने के लिए परीक्षण के विनिर्देश में इन परिणामों का मूल्यांकन मानदंडों के विरुद्ध किया जाता है।
परीक्षण के प्रकार
परीक्षण विभिन्न प्रकार के हो सकते हैं और विभिन्न प्रकार के परीक्षण किए जाते हैं जिनके आधार पर खोज करने के लिए बग की तलाश होती है -
इकाई का परीक्षण
कार्यक्रम परीक्षण के रूप में भी जाना जाता है, यह एक प्रकार का परीक्षण है जहां विश्लेषक प्रत्येक कार्यक्रम या मॉड्यूल पर स्वतंत्र रूप से परीक्षण या ध्यान केंद्रित करता है। यह कम से कम एक बार मॉड्यूल के प्रत्येक कथन को निष्पादित करने के इरादे से किया जाता है।
इकाई परीक्षण में, कार्यक्रम की सटीकता का आश्वासन नहीं दिया जा सकता है और विस्तार से विभिन्न इनपुट संयोजन का परीक्षण करना मुश्किल है।
यह अन्य परीक्षण तकनीकों की तुलना में एक कार्यक्रम में अधिकतम त्रुटियों की पहचान करता है।
एकीकरण जांच
एकीकरण परीक्षण में, विश्लेषक एक साथ काम करने वाले कई मॉड्यूल का परीक्षण करता है। इसका उपयोग सिस्टम और उसके मूल उद्देश्य, वर्तमान विनिर्देशों और सिस्टम प्रलेखन के बीच विसंगतियों को खोजने के लिए किया जाता है।
यहां विश्लेषकों को उन क्षेत्रों को खोजने की कोशिश की जाती है जहां मॉड्यूल को डेटा लंबाई, प्रकार और डेटा तत्व नाम के लिए अलग-अलग विनिर्देशों के साथ डिज़ाइन किया गया है।
यह पुष्टि करता है कि फ़ाइल का आकार पर्याप्त है और सूचकांकों को ठीक से बनाया गया है।
क्रियात्मक परीक्षण
फ़ंक्शन परीक्षण यह निर्धारित करता है कि सिस्टम अपने विनिर्देशों और प्रासंगिक मानकों के अनुसार सही ढंग से कार्य कर रहा है या नहीं। कार्यात्मक परीक्षण आमतौर पर सिस्टम के कार्यान्वयन से शुरू होता है, जो सिस्टम की सफलता के लिए बहुत महत्वपूर्ण है।
कार्यात्मक परीक्षण को दो श्रेणियों में विभाजित किया गया है -
Positive Functional Testing - इसमें सत्यापित करने के लिए मान्य इनपुट के साथ सिस्टम का परीक्षण करना शामिल है कि उत्पादित आउटपुट सही हैं।
Negative Functional Testing - इसमें अमान्य इनपुट और अवांछित ऑपरेटिंग स्थितियों के साथ सॉफ़्टवेयर का परीक्षण करना शामिल है।
सिस्टम परीक्षण के लिए नियम
सिस्टम परीक्षण को सफलतापूर्वक करने के लिए, आपको दिए गए नियमों का पालन करना होगा -
परीक्षण उपयोगकर्ता की आवश्यकताओं पर आधारित होना चाहिए।
परीक्षण स्क्रिप्ट लिखने से पहले, व्यापार तर्क को अच्छी तरह से समझना चाहिए।
टेस्ट प्लान जल्द से जल्द किया जाना चाहिए।
परीक्षण तीसरे पक्ष द्वारा किया जाना चाहिए।
इसे स्थैतिक सॉफ्टवेयर पर किया जाना चाहिए।
वैध और अमान्य इनपुट स्थितियों के लिए परीक्षण किया जाना चाहिए।
लागत कम करने के लिए परीक्षण की समीक्षा की जानी चाहिए।
सॉफ्टवेयर पर स्थिर और गतिशील दोनों परीक्षण किए जाने चाहिए।
परीक्षण मामलों और परीक्षण के परिणामों का दस्तावेजीकरण किया जाना चाहिए।
गुणवत्ता आश्वासन
यह सिस्टम या सॉफ़्टवेयर उत्पादों की समीक्षा और आश्वासन के लिए इसके प्रलेखन है कि सिस्टम आवश्यकताओं और विनिर्देशों को पूरा करता है।
क्यूए का उद्देश्य ग्राहकों को विनिर्देश के अनुसार उत्पाद के निरंतर वितरण द्वारा विश्वास प्रदान करना है।
सॉफ्टवेयर गुणवत्ता आश्वासन (SQA) एक ऐसी तकनीक है जिसमें सॉफ्टवेयर पेशेवरों द्वारा लागू प्रक्रियाएं और उपकरण शामिल हैं ताकि यह सुनिश्चित किया जा सके कि सॉफ्टवेयर अपने इच्छित उपयोग और प्रदर्शन के लिए निर्दिष्ट मानक को पूरा करता है।
SQA का मुख्य उद्देश्य सॉफ्टवेयर प्रोजेक्ट और इसके विकसित उत्पाद की उचित और सटीक दृश्यता प्रदान करना है।
यह सिस्टम विकास के जीवन चक्र के दौरान सॉफ्टवेयर उत्पाद और उसकी गतिविधियों की समीक्षा और ऑडिट करता है।
गुणवत्ता आश्वासन के उद्देश्य
गुणवत्ता आश्वासन के संचालन के उद्देश्य इस प्रकार हैं -
सॉफ्टवेयर विकास प्रक्रिया और अंतिम सॉफ्टवेयर विकसित करने के लिए निगरानी करना।
यह सुनिश्चित करने के लिए कि सॉफ्टवेयर प्रोजेक्ट प्रबंधन द्वारा निर्धारित मानकों और प्रक्रियाओं को लागू कर रहा है या नहीं।
इन गतिविधियों के SQA गतिविधियों और परिणामों के बारे में समूहों और व्यक्तियों को सूचित करना।
यह सुनिश्चित करने के लिए कि सॉफ्टवेयर के भीतर हल नहीं होने वाले मुद्दों को ऊपरी प्रबंधन द्वारा संबोधित किया जाता है।
उत्पाद, प्रक्रिया या मानकों में कमियों की पहचान करने और उन्हें ठीक करने के लिए।
गुणवत्ता आश्वासन के स्तर
क्यूए और परीक्षण के कई स्तर हैं जिन्हें सॉफ़्टवेयर उत्पाद को प्रमाणित करने के लिए निष्पादित करने की आवश्यकता होती है।
Level 1 − Code Walk-through
इस स्तर पर, आधिकारिक कोडिंग नियमों के किसी भी उल्लंघन के लिए ऑफ़लाइन सॉफ़्टवेयर की जांच या जाँच की जाती है। सामान्य तौर पर, इन-कोड टिप्पणियों के प्रलेखन और स्तर की जांच पर जोर दिया जाता है।
Level 2 − Compilation and Linking
इस स्तर पर, यह जाँच की जाती है कि सॉफ्टवेयर सभी आधिकारिक प्लेटफार्मों और ऑपरेटिंग सिस्टम को संकलित और लिंक कर सकता है।
Level 3 − Routine Running
इस स्तर पर, यह जाँच की जाती है कि सॉफ्टवेयर कई प्रकार की परिस्थितियों में ठीक से चल सकता है जैसे कि निश्चित संख्या में घटनाएँ और छोटे और बड़े आकार के आकार आदि।
Level 4 − Performance test
इस अंतिम स्तर पर, यह जाँच की जाती है कि सॉफ़्टवेयर का प्रदर्शन पहले निर्दिष्ट प्रदर्शन स्तर को संतुष्ट करता है।